Commit e6c349d6 authored by Huw Davies's avatar Huw Davies Committed by Alexandre Julliard

gdi32: Use the helper to draw the glyphs.

parent 3e751732
...@@ -453,7 +453,7 @@ static void draw_glyph( dib_info *dib, int x, int y, const GLYPHMETRICS *metrics ...@@ -453,7 +453,7 @@ static void draw_glyph( dib_info *dib, int x, int y, const GLYPHMETRICS *metrics
rect.top = y - metrics->gmptGlyphOrigin.y; rect.top = y - metrics->gmptGlyphOrigin.y;
rect.right = rect.left + metrics->gmBlackBoxX; rect.right = rect.left + metrics->gmBlackBoxX;
rect.bottom = rect.top + metrics->gmBlackBoxY; rect.bottom = rect.top + metrics->gmBlackBoxY;
add_bounds_rect( bounds, &rect ); if (bounds) add_bounds_rect( bounds, &rect );
for (i = 0; i < clipped_rects->count; i++) for (i = 0; i < clipped_rects->count; i++)
{ {
...@@ -564,11 +564,15 @@ BOOL render_aa_text_bitmapinfo( HDC hdc, BITMAPINFO *info, struct gdi_image_bits ...@@ -564,11 +564,15 @@ BOOL render_aa_text_bitmapinfo( HDC hdc, BITMAPINFO *info, struct gdi_image_bits
COLORREF fg, bg; COLORREF fg, bg;
DWORD fg_pixel, bg_pixel; DWORD fg_pixel, bg_pixel;
struct intensity_range glyph_intensities[17]; struct intensity_range glyph_intensities[17];
struct clipped_rects visrect;
assert( info->bmiHeader.biBitCount > 8 ); /* mono and indexed formats don't support anti-aliasing */ assert( info->bmiHeader.biBitCount > 8 ); /* mono and indexed formats don't support anti-aliasing */
init_dib_info_from_bitmapinfo( &dib, info, bits->ptr ); init_dib_info_from_bitmapinfo( &dib, info, bits->ptr );
visrect.count = 1;
visrect.rects = &src->visrect;
fg = make_rgb_colorref( hdc, &dib, GetTextColor( hdc ), &got_pixel, &fg_pixel); fg = make_rgb_colorref( hdc, &dib, GetTextColor( hdc ), &got_pixel, &fg_pixel);
if (!got_pixel) fg_pixel = dib.funcs->colorref_to_pixel( &dib, fg ); if (!got_pixel) fg_pixel = dib.funcs->colorref_to_pixel( &dib, fg );
...@@ -595,24 +599,8 @@ BOOL render_aa_text_bitmapinfo( HDC hdc, BITMAPINFO *info, struct gdi_image_bits ...@@ -595,24 +599,8 @@ BOOL render_aa_text_bitmapinfo( HDC hdc, BITMAPINFO *info, struct gdi_image_bits
if (err) continue; if (err) continue;
if (glyph_dib.bits.ptr) if (glyph_dib.bits.ptr)
{ draw_glyph( &dib, x, y, &metrics, &glyph_dib, fg_pixel, glyph_intensities, &visrect, NULL );
RECT rect, clipped_rect;
POINT src_origin;
rect.left = x + metrics.gmptGlyphOrigin.x;
rect.top = y - metrics.gmptGlyphOrigin.y;
rect.right = rect.left + metrics.gmBlackBoxX;
rect.bottom = rect.top + metrics.gmBlackBoxY;
if (intersect_rect( &clipped_rect, &rect, &src->visrect ))
{
src_origin.x = clipped_rect.left - rect.left;
src_origin.y = clipped_rect.top - rect.top;
dib.funcs->draw_glyph( &dib, &clipped_rect, &glyph_dib, &src_origin,
fg_pixel, glyph_intensities );
}
}
free_dib_info( &glyph_dib ); free_dib_info( &glyph_dib );
if (dx) if (dx)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment