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

Side by Side Diff: chrome/browser/ui/views/location_bar/page_action_with_badge_view.cc

Issue 431173002: Create ExtensionActionView class (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: merge conflict 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 unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/ui/views/location_bar/page_action_with_badge_view.h" 5 #include "chrome/browser/ui/views/location_bar/page_action_with_badge_view.h"
6 6
7 #include "chrome/browser/extensions/extension_action.h" 7 #include "chrome/browser/extensions/extension_action.h"
8 #include "chrome/browser/ui/views/location_bar/page_action_image_view.h" 8 #include "chrome/browser/ui/views/location_bar/page_action_image_view.h"
9 #include "ui/accessibility/ax_view_state.h" 9 #include "ui/accessibility/ax_view_state.h"
10 10
11 using content::WebContents;
12
13 PageActionWithBadgeView::PageActionWithBadgeView( 11 PageActionWithBadgeView::PageActionWithBadgeView(
14 PageActionImageView* image_view) { 12 PageActionImageView* image_view) : image_view_(image_view) {
15 image_view_ = image_view;
16 AddChildView(image_view_); 13 AddChildView(image_view_);
17 } 14 }
18 15
19 void PageActionWithBadgeView::GetAccessibleState( 16 void PageActionWithBadgeView::GetAccessibleState(
20 ui::AXViewState* state) { 17 ui::AXViewState* state) {
21 state->role = ui::AX_ROLE_GROUP; 18 state->role = ui::AX_ROLE_GROUP;
22 } 19 }
23 20
24 gfx::Size PageActionWithBadgeView::GetPreferredSize() const { 21 gfx::Size PageActionWithBadgeView::GetPreferredSize() const {
25 return gfx::Size(ExtensionAction::kPageActionIconMaxSize, 22 return gfx::Size(ExtensionAction::kPageActionIconMaxSize,
26 ExtensionAction::kPageActionIconMaxSize); 23 ExtensionAction::kPageActionIconMaxSize);
27 } 24 }
28 25
29 void PageActionWithBadgeView::Layout() { 26 void PageActionWithBadgeView::Layout() {
30 // We have 25 pixels of vertical space in the Omnibox to play with, so even 27 // We have 25 pixels of vertical space in the Omnibox to play with, so even
31 // sized icons (such as 16x16) have either a 5 or a 4 pixel whitespace 28 // sized icons (such as 16x16) have either a 5 or a 4 pixel whitespace
32 // (padding) above and below. It looks better to have the extra pixel above 29 // (padding) above and below. It looks better to have the extra pixel above
33 // the icon than below it, so we add a pixel. http://crbug.com/25708. 30 // the icon than below it, so we add a pixel. http://crbug.com/25708.
34 const gfx::ImageSkia& image = image_view()->GetImage(); 31 const gfx::ImageSkia& image = image_view()->GetImage();
35 int y = (image.height() + 1) % 2; // Even numbers: 1px padding. Odd: 0px. 32 int y = (image.height() + 1) % 2; // Even numbers: 1px padding. Odd: 0px.
36 image_view_->SetBounds(0, y, width(), height()); 33 image_view_->SetBounds(0, y, width(), height());
37 } 34 }
38 35
39 void PageActionWithBadgeView::UpdateVisibility(WebContents* contents, 36 void PageActionWithBadgeView::UpdateVisibility(content::WebContents* contents) {
40 const GURL& url) { 37 image_view_->UpdateVisibility(contents);
41 image_view_->UpdateVisibility(contents, url);
42 SetVisible(image_view_->visible()); 38 SetVisible(image_view_->visible());
43 } 39 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698