diff options
author | cinap_lenrek <cinap_lenrek@felloff.net> | 2014-07-21 18:10:58 +0200 |
---|---|---|
committer | cinap_lenrek <cinap_lenrek@felloff.net> | 2014-07-21 18:10:58 +0200 |
commit | 168b9f3de4088ed08987e62da3c593e98bdaab29 (patch) | |
tree | 998bc7e4939204299270761ee11f7f61d82a0f60 /sys/src | |
parent | 1021caa3950b8e7c5c739a24d7839468c7bf062a (diff) |
libdraw: add missing borderop() (thanks aiju)
Diffstat (limited to 'sys/src')
-rw-r--r-- | sys/src/libdraw/border.c | 24 |
1 files changed, 15 insertions, 9 deletions
diff --git a/sys/src/libdraw/border.c b/sys/src/libdraw/border.c index 22637dfad..52eaa1524 100644 --- a/sys/src/libdraw/border.c +++ b/sys/src/libdraw/border.c @@ -3,19 +3,25 @@ #include <draw.h> void -border(Image *im, Rectangle r, int i, Image *color, Point sp) +borderop(Image *im, Rectangle r, int i, Image *color, Point sp, Drawop op) { if(i < 0){ r = insetrect(r, i); sp = addpt(sp, Pt(i,i)); i = -i; } - draw(im, Rect(r.min.x, r.min.y, r.max.x, r.min.y+i), - color, nil, sp); - draw(im, Rect(r.min.x, r.max.y-i, r.max.x, r.max.y), - color, nil, Pt(sp.x, sp.y+Dy(r)-i)); - draw(im, Rect(r.min.x, r.min.y+i, r.min.x+i, r.max.y-i), - color, nil, Pt(sp.x, sp.y+i)); - draw(im, Rect(r.max.x-i, r.min.y+i, r.max.x, r.max.y-i), - color, nil, Pt(sp.x+Dx(r)-i, sp.y+i)); + drawop(im, Rect(r.min.x, r.min.y, r.max.x, r.min.y+i), + color, nil, sp, op); + drawop(im, Rect(r.min.x, r.max.y-i, r.max.x, r.max.y), + color, nil, Pt(sp.x, sp.y+Dy(r)-i), op); + drawop(im, Rect(r.min.x, r.min.y+i, r.min.x+i, r.max.y-i), + color, nil, Pt(sp.x, sp.y+i), op); + drawop(im, Rect(r.max.x-i, r.min.y+i, r.max.x, r.max.y-i), + color, nil, Pt(sp.x+Dx(r)-i, sp.y+i), op); +} + +void +border(Image *im, Rectangle r, int i, Image *color, Point sp) +{ + borderop(im, r, i, color, sp, SoverD); } |