diff options
Diffstat (limited to 'webkit/glue')
-rw-r--r-- | webkit/glue/webcursor_aurax11.cc | 35 |
1 files changed, 6 insertions, 29 deletions
diff --git a/webkit/glue/webcursor_aurax11.cc b/webkit/glue/webcursor_aurax11.cc index fe221e2..b3f6989 100644 --- a/webkit/glue/webcursor_aurax11.cc +++ b/webkit/glue/webcursor_aurax11.cc @@ -10,7 +10,6 @@ #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" @@ -18,35 +17,13 @@ const ui::PlatformCursor WebCursor::GetPlatformCursor() { if (platform_cursor_) return platform_cursor_; - 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(); - } + 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 = ui::SkBitmapToXcursorImage(&bitmap, hotspot_); platform_cursor_ = ui::CreateReffedCustomXCursor(image); return platform_cursor_; } |