diff options
author | YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp> | 2008-08-30 04:54:55 +0000 |
---|---|---|
committer | YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp> | 2008-08-30 04:54:55 +0000 |
commit | d5bf63ccbdf7f9d51ef6163202c1382cb98c14e3 (patch) | |
tree | 176b2b9714d2c78a6c3cb651aab58c41299820e3 | |
parent | e19d93614a2cca921b672192a2da9f813821abfa (diff) | |
download | emacs-d5bf63ccbdf7f9d51ef6163202c1382cb98c14e3.tar.gz |
[USE_CG_DRAWING] (mac_draw_cg_image): Fix coordinate flipping.
-rw-r--r-- | src/macterm.c | 18 |
1 files changed, 8 insertions, 10 deletions
diff --git a/src/macterm.c b/src/macterm.c index dee084065a1..0ec3c75e638 100644 --- a/src/macterm.c +++ b/src/macterm.c @@ -559,27 +559,25 @@ mac_draw_cg_image (image, f, gc, src_x, src_y, width, height, int dest_x, dest_y, overlay_p; { CGContextRef context; - CGFloat port_height = FRAME_PIXEL_HEIGHT (f); - CGRect dest_rect = mac_rect_make (f, dest_x, dest_y, width, height); + CGRect dest_rect, bounds; context = mac_begin_cg_clip (f, gc); + dest_rect = mac_rect_make (f, dest_x, dest_y, width, height); + bounds = mac_rect_make (f, dest_x - src_x, dest_y - src_y, + CGImageGetWidth (image), CGImageGetHeight (image)); if (!overlay_p) { CG_SET_FILL_COLOR_WITH_GC_BACKGROUND (context, gc); CGContextFillRect (context, dest_rect); } CGContextClipToRect (context, dest_rect); + CGContextTranslateCTM (context, + CGRectGetMinX (bounds), CGRectGetMaxY (bounds)); CGContextScaleCTM (context, 1, -1); - CGContextTranslateCTM (context, 0, -port_height); if (CGImageIsMask (image)) CG_SET_FILL_COLOR_WITH_GC_FOREGROUND (context, gc); - CGContextDrawImage (context, - mac_rect_make (f, dest_x - src_x, - port_height - (dest_y - src_y - + CGImageGetHeight (image)), - CGImageGetWidth (image), - CGImageGetHeight (image)), - image); + bounds.origin = CGPointZero; + CGContextDrawImage (context, bounds, image); mac_end_cg_clip (f); } |