Index: ui/app_list/app_list_folder_item.cc |
diff --git a/ui/app_list/app_list_folder_item.cc b/ui/app_list/app_list_folder_item.cc |
index b9f24abcff2826b5dceccb1c874203ce71d1fd51..a844be6ac518bd740cccfafd4b569df2173a46cb 100644 |
--- a/ui/app_list/app_list_folder_item.cc |
+++ b/ui/app_list/app_list_folder_item.cc |
@@ -7,79 +7,11 @@ |
#include "base/guid.h" |
#include "ui/app_list/app_list_constants.h" |
#include "ui/app_list/app_list_item_list.h" |
-#include "ui/gfx/canvas.h" |
+#include "ui/app_list/folder_image_source.h" |
#include "ui/gfx/geometry/rect.h" |
-#include "ui/gfx/image/canvas_image_source.h" |
-#include "ui/gfx/image/image_skia_operations.h" |
namespace app_list { |
-namespace { |
- |
-const int kItemIconDimension = 16; |
- |
-// Generates the folder icon with the top 4 child item icons laid in 2x2 tile. |
-class FolderImageSource : public gfx::CanvasImageSource { |
- public: |
- typedef std::vector<gfx::ImageSkia> Icons; |
- |
- FolderImageSource(const Icons& icons, const gfx::Size& size) |
- : gfx::CanvasImageSource(size, false), |
- icons_(icons), |
- size_(size) { |
- DCHECK(icons.size() <= kNumFolderTopItems); |
- } |
- |
- virtual ~FolderImageSource() {} |
- |
- private: |
- void DrawIcon(gfx::Canvas* canvas, |
- const gfx::ImageSkia& icon, |
- const gfx::Size icon_size, |
- int x, int y) { |
- if (icon.isNull()) |
- return; |
- |
- gfx::ImageSkia resized( |
- gfx::ImageSkiaOperations::CreateResizedImage( |
- icon, skia::ImageOperations::RESIZE_BEST, icon_size)); |
- canvas->DrawImageInt(resized, 0, 0, resized.width(), resized.height(), |
- x, y, resized.width(), resized.height(), true); |
- } |
- |
- // gfx::CanvasImageSource overrides: |
- virtual void Draw(gfx::Canvas* canvas) override { |
- // Draw folder circle. |
- gfx::Point center = gfx::Point(size().width() / 2 , size().height() / 2); |
- SkPaint paint; |
- paint.setStyle(SkPaint::kFill_Style); |
- paint.setAntiAlias(true); |
- paint.setColor(kFolderBubbleColor); |
- canvas->DrawCircle(center, size().width() / 2, paint); |
- |
- if (icons_.size() == 0) |
- return; |
- |
- // Draw top items' icons. |
- const gfx::Size item_icon_size = |
- gfx::Size(kItemIconDimension, kItemIconDimension); |
- std::vector<gfx::Rect> top_icon_bounds = |
- AppListFolderItem::GetTopIconsBounds(gfx::Rect(size())); |
- |
- for (size_t i= 0; i < kNumFolderTopItems && i < icons_.size(); ++i) { |
- DrawIcon(canvas, icons_[i], item_icon_size, |
- top_icon_bounds[i].x(), top_icon_bounds[i].y()); |
- } |
- } |
- |
- Icons icons_; |
- gfx::Size size_; |
- |
- DISALLOW_COPY_AND_ASSIGN(FolderImageSource); |
-}; |
- |
-} // namespace |
- |
AppListFolderItem::AppListFolderItem(const std::string& id, |
FolderType folder_type) |
: AppListItem(id), |
@@ -117,14 +49,13 @@ gfx::Rect AppListFolderItem::GetTargetIconRectInFolderForItem( |
for (size_t i = 0; i < top_items_.size(); ++i) { |
if (item->id() == top_items_[i]->id()) { |
std::vector<gfx::Rect> rects = |
- AppListFolderItem::GetTopIconsBounds(folder_icon_bounds); |
+ FolderImageSource::GetTopIconsBounds(folder_icon_bounds); |
return rects[i]; |
} |
} |
gfx::Rect target_rect(folder_icon_bounds); |
- target_rect.ClampToCenteredSize( |
- gfx::Size(kItemIconDimension, kItemIconDimension)); |
+ target_rect.ClampToCenteredSize(FolderImageSource::ItemIconSize()); |
return target_rect; |
} |
@@ -135,38 +66,6 @@ void AppListFolderItem::Activate(int event_flags) { |
// static |
const char AppListFolderItem::kItemType[] = "FolderItem"; |
-// static |
-std::vector<gfx::Rect> AppListFolderItem::GetTopIconsBounds( |
- const gfx::Rect& folder_icon_bounds) { |
- const int delta_to_center = 1; |
- gfx::Point icon_center = folder_icon_bounds.CenterPoint(); |
- std::vector<gfx::Rect> top_icon_bounds; |
- |
- // Get the top left icon bounds. |
- int left_x = icon_center.x() - kItemIconDimension - delta_to_center; |
- int top_y = icon_center.y() - kItemIconDimension - delta_to_center; |
- gfx::Rect top_left(left_x, top_y, kItemIconDimension, kItemIconDimension); |
- top_icon_bounds.push_back(top_left); |
- |
- // Get the top right icon bounds. |
- int right_x = icon_center.x() + delta_to_center; |
- gfx::Rect top_right(right_x, top_y, kItemIconDimension, kItemIconDimension); |
- top_icon_bounds.push_back(top_right); |
- |
- // Get the bottom left icon bounds. |
- int bottom_y = icon_center.y() + delta_to_center; |
- gfx::Rect bottom_left( |
- left_x, bottom_y, kItemIconDimension, kItemIconDimension); |
- top_icon_bounds.push_back(bottom_left); |
- |
- // Get the bottom right icon bounds. |
- gfx::Rect bottom_right( |
- right_x, bottom_y, kItemIconDimension, kItemIconDimension); |
- top_icon_bounds.push_back(bottom_right); |
- |
- return top_icon_bounds; |
-} |
- |
const char* AppListFolderItem::GetItemType() const { |
return AppListFolderItem::kItemType; |
} |