| Index: views/drag_utils_win.cc
|
| ===================================================================
|
| --- views/drag_utils_win.cc (revision 17065)
|
| +++ views/drag_utils_win.cc (working copy)
|
| @@ -9,33 +9,11 @@
|
| #include <shobjidl.h>
|
|
|
| #include "app/gfx/canvas.h"
|
| -#include "app/gfx/font.h"
|
| -#include "app/l10n_util.h"
|
| #include "app/os_exchange_data.h"
|
| -#include "app/resource_bundle.h"
|
| -#include "base/file_util.h"
|
| #include "base/gfx/gdi_util.h"
|
| -#include "base/gfx/point.h"
|
| -#include "base/string_util.h"
|
| -#include "googleurl/src/gurl.h"
|
| -#include "grit/app_resources.h"
|
| -#include "views/controls/button/text_button.h"
|
|
|
| namespace drag_utils {
|
|
|
| -// Maximum width of the link drag image in pixels.
|
| -static const int kLinkDragImageMaxWidth = 200;
|
| -static const int kLinkDragImageVPadding = 3;
|
| -static const int kLinkDragImageVSpacing = 2;
|
| -static const int kLinkDragImageHPadding = 4;
|
| -static const SkColor kLinkDragImageBGColor = SkColorSetRGB(131, 146, 171);
|
| -//static const SkColor kLinkDragImageBGColor = SkColorSetRGB(195, 217, 255);
|
| -static const SkColor kLinkDragImageTextColor = SK_ColorBLACK;
|
| -
|
| -// File dragging pixel measurements
|
| -static const int kFileDragImageMaxWidth = 200;
|
| -static const SkColor kFileDragImageTextColor = SK_ColorBLACK;
|
| -
|
| static void SetDragImageOnDataObject(HBITMAP hbitmap,
|
| int width,
|
| int height,
|
| @@ -80,71 +58,12 @@
|
| return bitmap;
|
| }
|
|
|
| -void SetURLAndDragImage(const GURL& url,
|
| - const std::wstring& title,
|
| - const SkBitmap& icon,
|
| - OSExchangeData* data) {
|
| - DCHECK(url.is_valid() && data);
|
| -
|
| - data->SetURL(url, title);
|
| -
|
| - // Create a button to render the drag image for us.
|
| - views::TextButton button(NULL,
|
| - title.empty() ? UTF8ToWide(url.spec()) : title);
|
| - button.set_max_width(kLinkDragImageMaxWidth);
|
| - if (icon.isNull()) {
|
| - button.SetIcon(*ResourceBundle::GetSharedInstance().GetBitmapNamed(
|
| - IDR_DEFAULT_FAVICON));
|
| - } else {
|
| - button.SetIcon(icon);
|
| - }
|
| - gfx::Size prefsize = button.GetPreferredSize();
|
| - button.SetBounds(0, 0, prefsize.width(), prefsize.height());
|
| -
|
| - // Render the image.
|
| - gfx::Canvas canvas(prefsize.width(), prefsize.height(), false);
|
| - button.Paint(&canvas, true);
|
| - SetDragImageOnDataObject(canvas, prefsize.width(), prefsize.height(),
|
| - prefsize.width() / 2, prefsize.height() / 2,
|
| - data);
|
| -}
|
| -
|
| -void CreateDragImageForFile(const std::wstring& file_name,
|
| - SkBitmap* icon,
|
| - IDataObject* data_object) {
|
| - DCHECK(icon);
|
| - DCHECK(data_object);
|
| -
|
| - // Set up our text portion
|
| - const std::wstring& name = file_util::GetFilenameFromPath(file_name);
|
| - ResourceBundle& rb = ResourceBundle::GetSharedInstance();
|
| - gfx::Font font = rb.GetFont(ResourceBundle::BaseFont);
|
| -
|
| - const int width = kFileDragImageMaxWidth;
|
| - // Add +2 here to allow room for the halo.
|
| - const int height = font.height() + icon->height() +
|
| - kLinkDragImageVPadding + 2;
|
| - gfx::Canvas canvas(width, height, false /* translucent */);
|
| -
|
| - // Paint the icon.
|
| - canvas.DrawBitmapInt(*icon, (width - icon->width()) / 2, 0);
|
| -
|
| - // Paint the file name. We inset it one pixel to allow room for the halo.
|
| - canvas.DrawStringWithHalo(name, font, kFileDragImageTextColor, SK_ColorWHITE,
|
| - 1, icon->height() + kLinkDragImageVPadding + 1,
|
| - width - 2, font.height(),
|
| - gfx::Canvas::TEXT_ALIGN_CENTER);
|
| -
|
| - SetDragImageOnDataObject(canvas, width, height, width / 2,
|
| - kLinkDragImageVPadding, data_object);
|
| -}
|
| -
|
| void SetDragImageOnDataObject(const gfx::Canvas& canvas,
|
| int width,
|
| int height,
|
| int cursor_x_offset,
|
| int cursor_y_offset,
|
| - IDataObject* data_object) {
|
| + OSExchangeData* data_object) {
|
| DCHECK(data_object && width > 0 && height > 0);
|
| // SetDragImageOnDataObject(HBITMAP) takes ownership of the bitmap.
|
| HBITMAP bitmap = CreateBitmapFromCanvas(canvas, width, height);
|
|
|