summaryrefslogtreecommitdiffstats
path: root/chrome/browser/drag_utils.cc
diff options
context:
space:
mode:
authorbrettw@chromium.org <brettw@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-03-04 22:57:01 +0000
committerbrettw@chromium.org <brettw@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-03-04 22:57:01 +0000
commite078d3267684d1c8649cc717401d5c0e4df7526f (patch)
tree56b9e03accd46f72d174666e0cd08e1ef391dfe1 /chrome/browser/drag_utils.cc
parenta9afef66567d4ec2de0ea0be84afd71dda2812ff (diff)
downloadchromium_src-e078d3267684d1c8649cc717401d5c0e4df7526f.zip
chromium_src-e078d3267684d1c8649cc717401d5c0e4df7526f.tar.gz
chromium_src-e078d3267684d1c8649cc717401d5c0e4df7526f.tar.bz2
Fix transparency for dragged downloads and links by using the halo text
routines. This also removes CreateDragImageForLink which is never called. Review URL: http://codereview.chromium.org/39082 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@10934 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/drag_utils.cc')
-rw-r--r--chrome/browser/drag_utils.cc65
1 files changed, 9 insertions, 56 deletions
diff --git a/chrome/browser/drag_utils.cc b/chrome/browser/drag_utils.cc
index 8bcfd69..4383411 100644
--- a/chrome/browser/drag_utils.cc
+++ b/chrome/browser/drag_utils.cc
@@ -15,6 +15,7 @@
#include "chrome/browser/views/bookmark_bar_view.h"
#include "chrome/common/gfx/chrome_canvas.h"
#include "chrome/common/gfx/chrome_font.h"
+#include "chrome/common/l10n_util.h"
#include "chrome/common/os_exchange_data.h"
#include "chrome/common/resource_bundle.h"
#include "chrome/common/win_util.h"
@@ -81,56 +82,6 @@ static HBITMAP CreateBitmapFromCanvas(const ChromeCanvas& canvas,
return bitmap;
}
-void CreateDragImageForLink(const GURL& url,
- const std::wstring& title,
- IDataObject* data_object) {
- // First calculate our dimensions.
- ChromeFont title_font =
- ResourceBundle::GetSharedInstance().GetFont(ResourceBundle::BaseFont).
- DeriveFont(0, ChromeFont::BOLD);
- ChromeFont url_font =
- ResourceBundle::GetSharedInstance().GetFont(ResourceBundle::SmallFont);
- const int title_height = title_font.height();
- const int url_height = url_font.height();
- const int width = kLinkDragImageMaxWidth;
- const int height = kLinkDragImageVPadding * 2 + kLinkDragImageVSpacing +
- title_height + url_height;
-
- // Now create a canvas and render the dragged representation into it.
- ChromeCanvas canvas(width, height, true);
-
- // Paint the alpha layer
- canvas.FillRectInt(SK_ColorWHITE, 0, 0,
- kLinkDragImageMaxWidth, height); // kLinkDragImageTransparentColor
-
- // Paint the background
- SkPaint paint;
- paint.setFlags(SkPaint::kAntiAlias_Flag);
- paint.setStyle(SkPaint::kFill_Style);
- paint.setColor(kLinkDragImageBGColor);
- SkRect bounds_rect;
- bounds_rect.set(0, 0, SkIntToScalar(width), SkIntToScalar(height));
- canvas.drawRoundRect(bounds_rect, 3, 3, paint);
-
- // Paint the link title
- canvas.DrawStringInt(title, title_font, kLinkDragImageTextColor,
- kLinkDragImageHPadding, kLinkDragImageVPadding,
- kLinkDragImageMaxWidth - 2 * kLinkDragImageHPadding,
- title_height);
-
- // Paint the link URL
- canvas.DrawStringInt(UTF8ToWide(url.spec()), url_font,
- kLinkDragImageTextColor, kLinkDragImageHPadding,
- kLinkDragImageVPadding + title_height +
- kLinkDragImageVSpacing,
- kLinkDragImageMaxWidth - 2 * kLinkDragImageHPadding,
- url_height);
-
- SetDragImageOnDataObject(canvas, kLinkDragImageMaxWidth, height,
- kLinkDragImageMaxWidth / 2,
- height - kLinkDragImageVPadding, data_object);
-}
-
void SetURLAndDragImage(const GURL& url,
const std::wstring& title,
const SkBitmap& icon,
@@ -171,16 +122,19 @@ void CreateDragImageForFile(const std::wstring& file_name,
ChromeFont font = rb.GetFont(ResourceBundle::BaseFont);
const int width = kFileDragImageMaxWidth;
- const int height = font.height() + icon->height() + kLinkDragImageVPadding;
+ // Add +2 here to allow room for the halo.
+ const int height = font.height() + icon->height() +
+ kLinkDragImageVPadding + 2;
ChromeCanvas canvas(width, height, false /* translucent */);
// Paint the icon.
canvas.DrawBitmapInt(*icon, (width - icon->width()) / 2, 0);
- // Paint the file name.
- canvas.DrawStringInt(name, font, kFileDragImageTextColor,
- 0, icon->height() + kLinkDragImageVPadding,
- width, font.height(), ChromeCanvas::TEXT_ALIGN_CENTER);
+ // 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(),
+ ChromeCanvas::TEXT_ALIGN_CENTER);
SetDragImageOnDataObject(canvas, width, height, width / 2,
kLinkDragImageVPadding, data_object);
@@ -204,4 +158,3 @@ void SetDragImageOnDataObject(const ChromeCanvas& canvas,
}
} // namespace drag_utils
-