Skip to content


Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
Browse files

Fix an issue where textbox borders were not drawn correctly in transp…

…arency layers.

This also fixes the issue where textboxes on windows in Titanium with
a transparent background are insensitive to clicks.
[#356 state:resolved]
  • Loading branch information...
commit 86622c75a357b11cf664d2659b5a037b5caeb61b 1 parent 02fca0a
Martin Robinson mrobinson authored
Showing with 10 additions and 1 deletion.
  1. +10 −1 WebCore/platform/graphics/win/GraphicsContextCairoWin.cpp
11 WebCore/platform/graphics/win/GraphicsContextCairoWin.cpp
@@ -100,9 +100,18 @@ void GraphicsContext::releaseWindowsContext(HDC hdc, const IntRect& dstRect, boo
GetObject(bitmap, sizeof(info), &info);
ASSERT(info.bmBitsPixel == 32);
+ unsigned char* bytes = reinterpret_cast<unsigned char*>(info.bmBits);
+ // If this context does not support alpha blending, then it may have
+ // been drawn with GDI functions which always set the alpha channel
+ // to zero. We need to manually set the bitmap to be fully opaque.
+ if (!supportAlphaBlend)
+ for (size_t i = 0; i < info.bmHeight * info.bmWidthBytes; i += 4)
+ bytes[i + 3] = 255;
// Need to make a cairo_surface_t out of the bitmap's pixel buffer and then draw
// it into our context.
- cairo_surface_t* image = cairo_image_surface_create_for_data((unsigned char*)info.bmBits,
+ cairo_surface_t* image = cairo_image_surface_create_for_data(bytes,
Please sign in to comment.
Something went wrong with that request. Please try again.