| Index: webkit/glue/webcursor_aurax11.cc
|
| diff --git a/webkit/glue/webcursor_aurax11.cc b/webkit/glue/webcursor_aurax11.cc
|
| index b3f698900688279d109a280aaeb58f4c3f235a95..fe221e29f80bd7b183adad5ee8ac74b8b6fca83d 100644
|
| --- a/webkit/glue/webcursor_aurax11.cc
|
| +++ b/webkit/glue/webcursor_aurax11.cc
|
| @@ -10,6 +10,7 @@
|
|
|
| #include "base/logging.h"
|
| #include "third_party/WebKit/Source/WebKit/chromium/public/WebCursorInfo.h"
|
| +#include "third_party/skia/include/core/SkUnPreMultiply.h"
|
| #include "ui/base/cursor/cursor.h"
|
| #include "ui/base/x/x11_util.h"
|
|
|
| @@ -17,13 +18,35 @@ const ui::PlatformCursor WebCursor::GetPlatformCursor() {
|
| if (platform_cursor_)
|
| return platform_cursor_;
|
|
|
| - SkBitmap bitmap;
|
| - bitmap.setConfig(SkBitmap::kARGB_8888_Config,
|
| - custom_size_.width(), custom_size_.height());
|
| - bitmap.allocPixels();
|
| - memcpy(bitmap.getAddr32(0, 0), custom_data_.data(), custom_data_.size());
|
| + XcursorImage* image =
|
| + XcursorImageCreate(custom_size_.width(), custom_size_.height());
|
| + image->xhot = hotspot_.x();
|
| + image->yhot = hotspot_.y();
|
| + uint32* pixels = image->pixels;
|
| +
|
| + if (custom_size_.width() && custom_size_.height()) {
|
| + SkBitmap bitmap;
|
| + bitmap.setConfig(SkBitmap::kARGB_8888_Config,
|
| + custom_size_.width(), custom_size_.height());
|
| + bitmap.allocPixels();
|
| + memcpy(bitmap.getAddr32(0, 0), custom_data_.data(), custom_data_.size());
|
| +
|
| + bitmap.lockPixels();
|
| + int height = bitmap.height(), width = bitmap.width();
|
| + for (int y = 0, i = 0; y < height; y++) {
|
| + for (int x = 0; x < width; x++) {
|
| + uint32 pixel = bitmap.getAddr32(0, y)[x];
|
| + int alpha = SkColorGetA(pixel);
|
| + if (alpha != 0 && alpha != 255)
|
| + pixels[i] = SkUnPreMultiply::PMColorToColor(pixel);
|
| + else
|
| + pixels[i] = pixel;
|
| + ++i;
|
| + }
|
| + }
|
| + bitmap.unlockPixels();
|
| + }
|
|
|
| - XcursorImage* image = ui::SkBitmapToXcursorImage(&bitmap, hotspot_);
|
| platform_cursor_ = ui::CreateReffedCustomXCursor(image);
|
| return platform_cursor_;
|
| }
|
|
|