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

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

Issue 413433002: Refactor BubbleDelegateView::use_focuseless() (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Don't reopen the bubble without good reason Created 6 years, 5 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 | Annotate | Revision Log
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/zoom_bubble_view.h" 5 #include "chrome/browser/ui/views/location_bar/zoom_bubble_view.h"
6 6
7 #include "base/i18n/rtl.h" 7 #include "base/i18n/rtl.h"
8 #include "base/strings/stringprintf.h" 8 #include "base/strings/stringprintf.h"
9 #include "chrome/browser/chrome_notification_types.h" 9 #include "chrome/browser/chrome_notification_types.h"
10 #include "chrome/browser/chrome_page_zoom.h" 10 #include "chrome/browser/chrome_page_zoom.h"
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after
56 bool anchor_to_view = !is_fullscreen || 56 bool anchor_to_view = !is_fullscreen ||
57 browser_view->immersive_mode_controller()->IsRevealed(); 57 browser_view->immersive_mode_controller()->IsRevealed();
58 views::View* anchor_view = anchor_to_view ? 58 views::View* anchor_view = anchor_to_view ?
59 browser_view->GetLocationBarView()->zoom_view() : NULL; 59 browser_view->GetLocationBarView()->zoom_view() : NULL;
60 60
61 // Find the extension that initiated the zoom change, if any. 61 // Find the extension that initiated the zoom change, if any.
62 ZoomController* zoom_controller = 62 ZoomController* zoom_controller =
63 ZoomController::FromWebContents(web_contents); 63 ZoomController::FromWebContents(web_contents);
64 const extensions::Extension* extension = zoom_controller->last_extension(); 64 const extensions::Extension* extension = zoom_controller->last_extension();
65 65
66 // If the bubble is already showing in this window, its |auto_close_| value 66 // If the bubble is already showing in this window and the zoom change was not
67 // is equal to |auto_close|, and the zoom change was not initiated by an 67 // initiated by an extension, then the bubble can be reused and only the label
68 // extension, then the bubble can be reused and only the label text needs to 68 // text needs to be updated.
69 // be updated.
70 if (zoom_bubble_ && 69 if (zoom_bubble_ &&
71 zoom_bubble_->GetAnchorView() == anchor_view && 70 zoom_bubble_->GetAnchorView() == anchor_view &&
72 zoom_bubble_->auto_close_ == auto_close &&
73 !extension) { 71 !extension) {
74 zoom_bubble_->Refresh(); 72 zoom_bubble_->Refresh();
75 return; 73 return;
76 } 74 }
77 75
78 // If the bubble is already showing but its |auto_close_| value is not equal 76 // If the bubble is already showing but in the different tab, the current
msw 2014/07/25 15:38:38 nit: "in a different"
vasilii 2014/07/25 15:48:20 Done.
79 // to |auto_close|, the bubble's focus properties must change, so the 77 // bubble must be closed and a new one created.
80 // current bubble must be closed and a new one created.
81 CloseBubble(); 78 CloseBubble();
82 79
83 zoom_bubble_ = new ZoomBubbleView(anchor_view, 80 zoom_bubble_ = new ZoomBubbleView(anchor_view,
84 web_contents, 81 web_contents,
85 auto_close, 82 auto_close,
86 browser_view->immersive_mode_controller(), 83 browser_view->immersive_mode_controller(),
87 browser->fullscreen_controller()); 84 browser->fullscreen_controller());
88 85
89 // If the zoom change was initiated by an extension, capture the relevent 86 // If the zoom change was initiated by an extension, capture the relevent
90 // information from it. 87 // information from it.
91 if (extension) 88 if (extension)
92 zoom_bubble_->SetExtensionInfo(extension); 89 zoom_bubble_->SetExtensionInfo(extension);
93 90
94 // If we do not have an anchor view, parent the bubble to the content area. 91 // If we do not have an anchor view, parent the bubble to the content area.
95 if (!anchor_to_view) 92 if (!anchor_to_view)
96 zoom_bubble_->set_parent_window(web_contents->GetTopLevelNativeWindow()); 93 zoom_bubble_->set_parent_window(web_contents->GetTopLevelNativeWindow());
97 94
98 views::BubbleDelegateView::CreateBubble(zoom_bubble_); 95 views::BubbleDelegateView::CreateBubble(zoom_bubble_);
99 96
100 // Adjust for fullscreen after creation as it relies on the content size. 97 // Adjust for fullscreen after creation as it relies on the content size.
101 if (is_fullscreen) 98 if (is_fullscreen)
102 zoom_bubble_->AdjustForFullscreen(browser_view->GetBoundsInScreen()); 99 zoom_bubble_->AdjustForFullscreen(browser_view->GetBoundsInScreen());
103 100
104 if (zoom_bubble_->use_focusless()) 101 if (auto_close)
105 zoom_bubble_->GetWidget()->ShowInactive(); 102 zoom_bubble_->GetWidget()->ShowInactive();
106 else 103 else
107 zoom_bubble_->GetWidget()->Show(); 104 zoom_bubble_->GetWidget()->Show();
108 } 105 }
109 106
110 // static 107 // static
111 void ZoomBubbleView::CloseBubble() { 108 void ZoomBubbleView::CloseBubble() {
112 if (zoom_bubble_) 109 if (zoom_bubble_)
113 zoom_bubble_->Close(); 110 zoom_bubble_->Close();
114 } 111 }
(...skipping 17 matching lines...) Expand all
132 FullscreenController* fullscreen_controller) 129 FullscreenController* fullscreen_controller)
133 : BubbleDelegateView(anchor_view, anchor_view ? 130 : BubbleDelegateView(anchor_view, anchor_view ?
134 views::BubbleBorder::TOP_RIGHT : views::BubbleBorder::NONE), 131 views::BubbleBorder::TOP_RIGHT : views::BubbleBorder::NONE),
135 image_button_(NULL), 132 image_button_(NULL),
136 label_(NULL), 133 label_(NULL),
137 web_contents_(web_contents), 134 web_contents_(web_contents),
138 auto_close_(auto_close), 135 auto_close_(auto_close),
139 immersive_mode_controller_(immersive_mode_controller) { 136 immersive_mode_controller_(immersive_mode_controller) {
140 // Compensate for built-in vertical padding in the anchor view's image. 137 // Compensate for built-in vertical padding in the anchor view's image.
141 set_anchor_view_insets(gfx::Insets(5, 0, 5, 0)); 138 set_anchor_view_insets(gfx::Insets(5, 0, 5, 0));
142 set_use_focusless(auto_close);
143 set_notify_enter_exit_on_child(true); 139 set_notify_enter_exit_on_child(true);
144 140
145 // Add observers to close the bubble if the fullscreen state or immersive 141 // Add observers to close the bubble if the fullscreen state or immersive
146 // fullscreen revealed state changes. 142 // fullscreen revealed state changes.
147 registrar_.Add(this, 143 registrar_.Add(this,
148 chrome::NOTIFICATION_FULLSCREEN_CHANGED, 144 chrome::NOTIFICATION_FULLSCREEN_CHANGED,
149 content::Source<FullscreenController>(fullscreen_controller)); 145 content::Source<FullscreenController>(fullscreen_controller));
150 immersive_mode_controller_->AddObserver(this); 146 immersive_mode_controller_->AddObserver(this);
151 } 147 }
152 148
(...skipping 90 matching lines...) Expand 10 before | Expand all | Expand 10 after
243 } 239 }
244 240
245 void ZoomBubbleView::OnExtensionIconImageChanged( 241 void ZoomBubbleView::OnExtensionIconImageChanged(
246 extensions::IconImage* /* image */) { 242 extensions::IconImage* /* image */) {
247 image_button_->SetImage(views::Button::STATE_NORMAL, 243 image_button_->SetImage(views::Button::STATE_NORMAL,
248 &extension_info_.icon_image->image_skia()); 244 &extension_info_.icon_image->image_skia());
249 image_button_->SchedulePaint(); 245 image_button_->SchedulePaint();
250 } 246 }
251 247
252 void ZoomBubbleView::OnMouseEntered(const ui::MouseEvent& event) { 248 void ZoomBubbleView::OnMouseEntered(const ui::MouseEvent& event) {
253 set_use_focusless(false);
254 StopTimer(); 249 StopTimer();
255 } 250 }
256 251
257 void ZoomBubbleView::OnMouseExited(const ui::MouseEvent& event) { 252 void ZoomBubbleView::OnMouseExited(const ui::MouseEvent& event) {
258 set_use_focusless(auto_close_);
259 StartTimerIfNecessary(); 253 StartTimerIfNecessary();
260 } 254 }
261 255
262 void ZoomBubbleView::OnGestureEvent(ui::GestureEvent* event) { 256 void ZoomBubbleView::OnGestureEvent(ui::GestureEvent* event) {
263 if (!zoom_bubble_ || !zoom_bubble_->auto_close_ || 257 if (!zoom_bubble_ || !zoom_bubble_->auto_close_ ||
264 event->type() != ui::ET_GESTURE_TAP) { 258 event->type() != ui::ET_GESTURE_TAP) {
265 return; 259 return;
266 } 260 }
267 261
268 // If an auto-closing bubble was tapped, show a non-auto-closing bubble in 262 auto_close_ = false;
269 // its place. 263 StopTimer();
270 ShowBubble(zoom_bubble_->web_contents_, false);
271 event->SetHandled(); 264 event->SetHandled();
272 } 265 }
273 266
274 void ZoomBubbleView::ButtonPressed(views::Button* sender, 267 void ZoomBubbleView::ButtonPressed(views::Button* sender,
275 const ui::Event& event) { 268 const ui::Event& event) {
276 if (sender == image_button_) { 269 if (sender == image_button_) {
277 DCHECK(extension_info_.icon_image) << "Invalid button press."; 270 DCHECK(extension_info_.icon_image) << "Invalid button press.";
278 Browser* browser = chrome::FindBrowserWithWebContents(web_contents_); 271 Browser* browser = chrome::FindBrowserWithWebContents(web_contents_);
279 chrome::AddSelectedTabWithURL( 272 chrome::AddSelectedTabWithURL(
280 browser, 273 browser,
(...skipping 78 matching lines...) Expand 10 before | Expand all | Expand 10 after
359 void ZoomBubbleView::WindowClosing() { 352 void ZoomBubbleView::WindowClosing() {
360 // |zoom_bubble_| can be a new bubble by this point (as Close(); doesn't 353 // |zoom_bubble_| can be a new bubble by this point (as Close(); doesn't
361 // call this right away). Only set to NULL when it's this bubble. 354 // call this right away). Only set to NULL when it's this bubble.
362 if (zoom_bubble_ == this) 355 if (zoom_bubble_ == this)
363 zoom_bubble_ = NULL; 356 zoom_bubble_ = NULL;
364 } 357 }
365 358
366 ZoomBubbleView::ZoomBubbleExtensionInfo::ZoomBubbleExtensionInfo() {} 359 ZoomBubbleView::ZoomBubbleExtensionInfo::ZoomBubbleExtensionInfo() {}
367 360
368 ZoomBubbleView::ZoomBubbleExtensionInfo::~ZoomBubbleExtensionInfo() {} 361 ZoomBubbleView::ZoomBubbleExtensionInfo::~ZoomBubbleExtensionInfo() {}
OLDNEW
« no previous file with comments | « chrome/browser/ui/views/autofill/tooltip_icon.cc ('k') | chrome/browser/ui/views/passwords/manage_passwords_bubble_view.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698