Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2516)

Unified Diff: athena/home/athena_start_page_view.cc

Issue 473623002: Redesign the home card bottom state. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: fix Created 6 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « athena/home/athena_start_page_view.h ('k') | athena/home/bottom_home_view.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: athena/home/athena_start_page_view.cc
diff --git a/athena/home/athena_start_page_view.cc b/athena/home/athena_start_page_view.cc
new file mode 100644
index 0000000000000000000000000000000000000000..259c093af870fcc664a3bd14a2de4ad47d4418f0
--- /dev/null
+++ b/athena/home/athena_start_page_view.cc
@@ -0,0 +1,192 @@
+// Copyright 2014 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "athena/home/athena_start_page_view.h"
+
+#include "third_party/skia/include/core/SkPaint.h"
+#include "third_party/skia/include/core/SkPath.h"
+#include "ui/app_list/app_list_item.h"
+#include "ui/app_list/app_list_item_list.h"
+#include "ui/app_list/app_list_model.h"
+#include "ui/app_list/app_list_view_delegate.h"
+#include "ui/app_list/views/search_box_view.h"
+#include "ui/gfx/canvas.h"
+#include "ui/views/background.h"
+#include "ui/views/border.h"
+#include "ui/views/layout/box_layout.h"
+#include "ui/views/layout/fill_layout.h"
+#include "ui/views/painter.h"
+
+namespace {
+
+const size_t kMaxIconNum = 3;
+const int kIconSize = 50;
+const int kIconMargin = 25;
+
+const int kCornerRadius = 1;
+
+// The preferred height for VISIBLE_BOTTOM state.
+const int kPreferredHeightBottom = 100;
+
+class PlaceHolderButton : public views::ImageButton,
+ public views::ButtonListener {
+ public:
+ PlaceHolderButton()
+ : ImageButton(this) {
+ gfx::Canvas canvas(gfx::Size(kIconSize, kIconSize), 1.0f, true);
+ SkPaint paint;
+ paint.setStyle(SkPaint::kFill_Style);
+ paint.setColor(SkColorSetRGB(86, 119, 252));
+ paint.setFlags(SkPaint::kAntiAlias_Flag);
+ canvas.DrawCircle(
+ gfx::Point(kIconSize / 2, kIconSize / 2), kIconSize / 2, paint);
+
+ scoped_ptr<gfx::ImageSkia> image(
+ new gfx::ImageSkia(canvas.ExtractImageRep()));
+ SetImage(STATE_NORMAL, image.get());
+ }
+
+ private:
+ // views::ButtonListener:
+ virtual void ButtonPressed(views::Button* sender,
+ const ui::Event& event) OVERRIDE {
+ // Do nothing: remove these place holders.
+ }
+
+ DISALLOW_COPY_AND_ASSIGN(PlaceHolderButton);
+};
+
+class AppIconButton : public views::ImageButton,
+ public views::ButtonListener {
+ public:
+ explicit AppIconButton(app_list::AppListItem* item)
+ : ImageButton(this),
+ item_(item) {
+ // TODO(mukai): icon should be resized.
+ SetImage(STATE_NORMAL, &item->icon());
+ }
+
+ private:
+ // views::ButtonListener:
+ virtual void ButtonPressed(views::Button* sender,
+ const ui::Event& event) OVERRIDE {
+ DCHECK_EQ(sender, this);
+ item_->Activate(event.flags());
+ }
+
+ app_list::AppListItem* item_;
+
+ DISALLOW_COPY_AND_ASSIGN(AppIconButton);
+};
+
+// The background to paint the round rectangle of the view area.
+class RoundRectBackground : public views::Background {
+ public:
+ RoundRectBackground(SkColor color, int corner_radius)
+ : color_(color),
+ corner_radius_(corner_radius) {}
+ virtual ~RoundRectBackground() {}
+
+ private:
+ // views::Background:
+ virtual void Paint(gfx::Canvas* canvas, views::View* view) const OVERRIDE {
+ SkPaint paint;
+ paint.setStyle(SkPaint::kFill_Style);
+ paint.setColor(color_);
+ canvas->DrawRoundRect(view->GetContentsBounds(), corner_radius_, paint);
+ }
+
+ SkColor color_;
+ int corner_radius_;
+
+ DISALLOW_COPY_AND_ASSIGN(RoundRectBackground);
+};
+
+// The border to draw 1px width round rectangle of the specified view area.
+class RoundRectBorder : public views::Border {
sadrul 2014/08/14 03:03:27 Maybe you could use views::RoundRectPainter instea
Jun Mukai 2014/08/14 16:49:36 Done.
+ public:
+ RoundRectBorder(SkColor color, int corner_radius)
+ : color_(color),
+ corner_radius_(corner_radius) {}
+ virtual ~RoundRectBorder() {}
+
+ private:
+ static const int kBorderWidth = 1;
+
+ // views::Border:
+ virtual void Paint(const views::View& view, gfx::Canvas* canvas) OVERRIDE {
+ SkPaint paint;
+ paint.setStyle(SkPaint::kStroke_Style);
+ paint.setColor(color_);
+ paint.setStrokeWidth(kBorderWidth);
+ gfx::Rect bounds = view.GetLocalBounds();
+ bounds.Inset(kBorderWidth, kBorderWidth);
+ canvas->DrawRoundRect(bounds, corner_radius_, paint);
+ }
+ virtual gfx::Insets GetInsets() const OVERRIDE {
+ return gfx::Insets(kBorderWidth, kBorderWidth, kBorderWidth, kBorderWidth);
+ }
+ virtual gfx::Size GetMinimumSize() const OVERRIDE {
+ return gfx::Size();
+ }
+
+ SkColor color_;
+ int corner_radius_;
+
+ DISALLOW_COPY_AND_ASSIGN(RoundRectBorder);
+};
+
+} // namespace
+
+namespace athena {
+
+AthenaStartPageView::AthenaStartPageView(
+ app_list::AppListViewDelegate* view_delegate) {
+ app_list::AppListItemList* top_level =
+ view_delegate->GetModel()->top_level_item_list();
+
+ views::View* container = new views::View();
+ AddChildView(container);
+
+ views::BoxLayout* box_layout = new views::BoxLayout(
+ views::BoxLayout::kHorizontal, kIconMargin, kIconMargin, kIconMargin);
+ box_layout->set_main_axis_alignment(
+ views::BoxLayout::MAIN_AXIS_ALIGNMENT_CENTER);
+ box_layout->set_cross_axis_alignment(
+ views::BoxLayout::CROSS_AXIS_ALIGNMENT_CENTER);
+ container->SetLayoutManager(box_layout);
+ for (size_t i = 0; i < std::min(top_level->item_count(), kMaxIconNum); ++i)
+ container->AddChildView(new AppIconButton(top_level->item_at(i)));
+
+ views::View* search_box_container = new views::View();
+ search_box_container->set_background(
+ new RoundRectBackground(SK_ColorWHITE, kCornerRadius));
+ search_box_container->SetBorder(scoped_ptr<views::Border>(
+ new RoundRectBorder(SK_ColorGRAY, kCornerRadius)));
+ search_box_container->SetLayoutManager(new views::FillLayout());
+ search_box_container->AddChildView(
+ new app_list::SearchBoxView(this, view_delegate));
+ container->AddChildView(search_box_container);
+ box_layout->SetFlexForView(search_box_container, 1);
+
+ for (size_t i = 0; i < kMaxIconNum; ++i)
+ container->AddChildView(new PlaceHolderButton());
+
+ set_background(views::Background::CreateSolidBackground(
+ 255, 255, 255, 255 * 0.9));
+}
+
+AthenaStartPageView::~AthenaStartPageView() {}
+
+void AthenaStartPageView::Layout() {
+ gfx::Rect container_bounds = bounds();
+ container_bounds.set_height(kPreferredHeightBottom);
+ child_at(0)->SetBoundsRect(container_bounds);
sadrul 2014/08/14 03:03:27 Maybe keep track of |app_icon_container_| (or some
Jun Mukai 2014/08/14 16:49:36 Done. Since it also contains the search box, named
+}
+
+void AthenaStartPageView::QueryChanged(app_list::SearchBoxView* sender) {
+ // Nothing needs to be done.
+}
+
+} // namespace athena
« no previous file with comments | « athena/home/athena_start_page_view.h ('k') | athena/home/bottom_home_view.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698