X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/88051436131bee9c96803e444708ea52163f9491..a1a48c8a955d64abde7fd97ddf21f9469c2b5ee7:/src/gtk/cursor.cpp diff --git a/src/gtk/cursor.cpp b/src/gtk/cursor.cpp index 67148c8a74..63a0340630 100644 --- a/src/gtk/cursor.cpp +++ b/src/gtk/cursor.cpp @@ -82,7 +82,7 @@ wxCursor::wxCursor( int cursorId ) case wxCURSOR_ARROW: // fall through to default case wxCURSOR_DEFAULT: gdk_cur = GDK_LEFT_PTR; break; case wxCURSOR_RIGHT_ARROW: gdk_cur = GDK_RIGHT_PTR; break; - case wxCURSOR_HAND: gdk_cur = GDK_HAND1; break; + case wxCURSOR_HAND: gdk_cur = GDK_HAND2; break; case wxCURSOR_CROSS: gdk_cur = GDK_CROSSHAIR; break; case wxCURSOR_SIZEWE: gdk_cur = GDK_SB_H_DOUBLE_ARROW; break; case wxCURSOR_SIZENS: gdk_cur = GDK_SB_V_DOUBLE_ARROW; break; @@ -201,8 +201,29 @@ wxCursor::wxCursor( const wxImage & image ) return; } + unsigned long keyMaskColor = 0; + GdkPixmap* mask; + if (bHasMask) + { + keyMaskColor = wxImageHistogram::MakeKey( + image.GetMaskRed(), image.GetMaskGreen(), image.GetMaskBlue()); + // get mask before image is modified + wxBitmap bitmap(image, 1); + mask = bitmap.GetMask()->GetBitmap(); + g_object_ref(mask); + } + else + { + const int size = ((w + 7) / 8) * h; + char* bits = new char[size]; + memset(bits, 0xff, size); + mask = gdk_bitmap_create_from_data( + wxGetRootWindow()->window, bits, w, h); + delete[] bits; + } + // modify image so wxBitmap can be used to convert to pixmap - image_copy.UnShare(); + image_copy.SetMask(false); int i, j; wxByte* data = image_copy.GetData(); for (j = 0; j < h; j++) @@ -219,28 +240,8 @@ wxCursor::wxCursor( const wxImage & image ) } } } - wxBitmap bitmap(image_copy, 1); - unsigned long keyMaskColor = 0; - GdkPixmap* mask; - if (bHasMask) - { - keyMaskColor = wxImageHistogram::MakeKey( - image.GetMaskRed(), image.GetMaskGreen(), image.GetMaskBlue()); - mask = bitmap.GetMask()->GetBitmap(); - g_object_ref(mask); - } - else - { - const int size = ((w + 7) / 8) * h; - char* bits = new char[size]; - memset(bits, 0xff, size); - mask = gdk_bitmap_create_from_data( - bitmap.GetPixmap(), bits, w, h); - delete[] bits; - } - // find the most frequent color(s) wxImageHistogram histogram; image.ComputeHistogram(histogram);