Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 57 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 68 // extension, then the bubble can be reused and only the label text needs to | 68 // extension, then the bubble can be reused and only the label text needs to |
| 69 // be updated. | 69 // be updated. |
| 70 if (zoom_bubble_ && | 70 if (zoom_bubble_ && |
| 71 zoom_bubble_->GetAnchorView() == anchor_view && | 71 zoom_bubble_->GetAnchorView() == anchor_view && |
| 72 zoom_bubble_->auto_close_ == auto_close && | 72 zoom_bubble_->auto_close_ == auto_close && |
| 73 !extension) { | 73 !extension) { |
| 74 zoom_bubble_->Refresh(); | 74 zoom_bubble_->Refresh(); |
| 75 return; | 75 return; |
| 76 } | 76 } |
| 77 | 77 |
| 78 // If the bubble is already showing but its |auto_close_| value is not equal | 78 // If the bubble is already showing but its |auto_close_| value is not equal |
|
msw
2014/07/23 18:57:00
I wonder if this is still true/necessary?
Dan Beam
2014/07/23 23:03:34
this only happens on ctrl+ and a click on the zoom
vasilii
2014/07/24 16:32:13
I reproduced this case.
msw
2014/07/24 16:52:27
Why do we need to recreate the bubble on click aft
| |
| 79 // to |auto_close|, the bubble's focus properties must change, so the | 79 // to |auto_close|, the bubble's focus properties must change, so the |
| 80 // current bubble must be closed and a new one created. | 80 // current bubble must be closed and a new one created. |
| 81 CloseBubble(); | 81 CloseBubble(); |
| 82 | 82 |
| 83 zoom_bubble_ = new ZoomBubbleView(anchor_view, | 83 zoom_bubble_ = new ZoomBubbleView(anchor_view, |
| 84 web_contents, | 84 web_contents, |
| 85 auto_close, | 85 auto_close, |
| 86 browser_view->immersive_mode_controller(), | 86 browser_view->immersive_mode_controller(), |
| 87 browser->fullscreen_controller()); | 87 browser->fullscreen_controller()); |
| 88 | 88 |
| 89 // If the zoom change was initiated by an extension, capture the relevent | 89 // If the zoom change was initiated by an extension, capture the relevent |
| 90 // information from it. | 90 // information from it. |
| 91 if (extension) | 91 if (extension) |
| 92 zoom_bubble_->SetExtensionInfo(extension); | 92 zoom_bubble_->SetExtensionInfo(extension); |
| 93 | 93 |
| 94 // If we do not have an anchor view, parent the bubble to the content area. | 94 // If we do not have an anchor view, parent the bubble to the content area. |
| 95 if (!anchor_to_view) | 95 if (!anchor_to_view) |
| 96 zoom_bubble_->set_parent_window(web_contents->GetTopLevelNativeWindow()); | 96 zoom_bubble_->set_parent_window(web_contents->GetTopLevelNativeWindow()); |
| 97 | 97 |
| 98 views::BubbleDelegateView::CreateBubble(zoom_bubble_); | 98 views::BubbleDelegateView::CreateBubble(zoom_bubble_); |
| 99 | 99 |
| 100 // Adjust for fullscreen after creation as it relies on the content size. | 100 // Adjust for fullscreen after creation as it relies on the content size. |
| 101 if (is_fullscreen) | 101 if (is_fullscreen) |
| 102 zoom_bubble_->AdjustForFullscreen(browser_view->GetBoundsInScreen()); | 102 zoom_bubble_->AdjustForFullscreen(browser_view->GetBoundsInScreen()); |
| 103 | 103 |
| 104 if (zoom_bubble_->use_focusless()) | 104 if (zoom_bubble_->can_activate()) |
|
msw
2014/07/23 18:57:00
nit: I think this can just call Show and it'll res
Dan Beam
2014/07/23 23:03:34
the last time i checked, can_active() { return fal
vasilii
2014/07/24 16:32:14
This line is my typo for sure.
Dan, I touched this
| |
| 105 zoom_bubble_->GetWidget()->Show(); | |
| 106 else | |
| 105 zoom_bubble_->GetWidget()->ShowInactive(); | 107 zoom_bubble_->GetWidget()->ShowInactive(); |
| 106 else | |
| 107 zoom_bubble_->GetWidget()->Show(); | |
| 108 } | 108 } |
| 109 | 109 |
| 110 // static | 110 // static |
| 111 void ZoomBubbleView::CloseBubble() { | 111 void ZoomBubbleView::CloseBubble() { |
| 112 if (zoom_bubble_) | 112 if (zoom_bubble_) |
| 113 zoom_bubble_->Close(); | 113 zoom_bubble_->Close(); |
| 114 } | 114 } |
| 115 | 115 |
| 116 // static | 116 // static |
| 117 bool ZoomBubbleView::IsShowing() { | 117 bool ZoomBubbleView::IsShowing() { |
| (...skipping 14 matching lines...) Expand all Loading... | |
| 132 FullscreenController* fullscreen_controller) | 132 FullscreenController* fullscreen_controller) |
| 133 : BubbleDelegateView(anchor_view, anchor_view ? | 133 : BubbleDelegateView(anchor_view, anchor_view ? |
| 134 views::BubbleBorder::TOP_RIGHT : views::BubbleBorder::NONE), | 134 views::BubbleBorder::TOP_RIGHT : views::BubbleBorder::NONE), |
| 135 image_button_(NULL), | 135 image_button_(NULL), |
| 136 label_(NULL), | 136 label_(NULL), |
| 137 web_contents_(web_contents), | 137 web_contents_(web_contents), |
| 138 auto_close_(auto_close), | 138 auto_close_(auto_close), |
| 139 immersive_mode_controller_(immersive_mode_controller) { | 139 immersive_mode_controller_(immersive_mode_controller) { |
| 140 // Compensate for built-in vertical padding in the anchor view's image. | 140 // Compensate for built-in vertical padding in the anchor view's image. |
| 141 set_anchor_view_insets(gfx::Insets(5, 0, 5, 0)); | 141 set_anchor_view_insets(gfx::Insets(5, 0, 5, 0)); |
| 142 set_use_focusless(auto_close); | |
|
msw
2014/07/23 18:57:00
You've removed all the calls to set_use_focusless
Dan Beam
2014/07/23 23:03:34
correct, ctrl+/- should not move focus away from t
vasilii
2014/07/24 16:32:13
ctrl+ doesn't remove focus, I checked manually.
Dan Beam
2014/07/24 23:24:51
did you check on linux chromeos, linux aura, and w
vasilii
2014/07/25 15:27:43
Yeah.
| |
| 143 set_notify_enter_exit_on_child(true); | 142 set_notify_enter_exit_on_child(true); |
| 144 | 143 |
| 145 // Add observers to close the bubble if the fullscreen state or immersive | 144 // Add observers to close the bubble if the fullscreen state or immersive |
| 146 // fullscreen revealed state changes. | 145 // fullscreen revealed state changes. |
| 147 registrar_.Add(this, | 146 registrar_.Add(this, |
| 148 chrome::NOTIFICATION_FULLSCREEN_CHANGED, | 147 chrome::NOTIFICATION_FULLSCREEN_CHANGED, |
| 149 content::Source<FullscreenController>(fullscreen_controller)); | 148 content::Source<FullscreenController>(fullscreen_controller)); |
| 150 immersive_mode_controller_->AddObserver(this); | 149 immersive_mode_controller_->AddObserver(this); |
| 151 } | 150 } |
| 152 | 151 |
| (...skipping 90 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 243 } | 242 } |
| 244 | 243 |
| 245 void ZoomBubbleView::OnExtensionIconImageChanged( | 244 void ZoomBubbleView::OnExtensionIconImageChanged( |
| 246 extensions::IconImage* /* image */) { | 245 extensions::IconImage* /* image */) { |
| 247 image_button_->SetImage(views::Button::STATE_NORMAL, | 246 image_button_->SetImage(views::Button::STATE_NORMAL, |
| 248 &extension_info_.icon_image->image_skia()); | 247 &extension_info_.icon_image->image_skia()); |
| 249 image_button_->SchedulePaint(); | 248 image_button_->SchedulePaint(); |
| 250 } | 249 } |
| 251 | 250 |
| 252 void ZoomBubbleView::OnMouseEntered(const ui::MouseEvent& event) { | 251 void ZoomBubbleView::OnMouseEntered(const ui::MouseEvent& event) { |
| 253 set_use_focusless(false); | |
| 254 StopTimer(); | 252 StopTimer(); |
| 255 } | 253 } |
| 256 | 254 |
| 257 void ZoomBubbleView::OnMouseExited(const ui::MouseEvent& event) { | 255 void ZoomBubbleView::OnMouseExited(const ui::MouseEvent& event) { |
| 258 set_use_focusless(auto_close_); | |
| 259 StartTimerIfNecessary(); | 256 StartTimerIfNecessary(); |
| 260 } | 257 } |
| 261 | 258 |
| 262 void ZoomBubbleView::OnGestureEvent(ui::GestureEvent* event) { | 259 void ZoomBubbleView::OnGestureEvent(ui::GestureEvent* event) { |
| 263 if (!zoom_bubble_ || !zoom_bubble_->auto_close_ || | 260 if (!zoom_bubble_ || !zoom_bubble_->auto_close_ || |
| 264 event->type() != ui::ET_GESTURE_TAP) { | 261 event->type() != ui::ET_GESTURE_TAP) { |
| 265 return; | 262 return; |
| 266 } | 263 } |
| 267 | 264 |
| 268 // If an auto-closing bubble was tapped, show a non-auto-closing bubble in | 265 // If an auto-closing bubble was tapped, show a non-auto-closing bubble in |
| (...skipping 90 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 359 void ZoomBubbleView::WindowClosing() { | 356 void ZoomBubbleView::WindowClosing() { |
| 360 // |zoom_bubble_| can be a new bubble by this point (as Close(); doesn't | 357 // |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. | 358 // call this right away). Only set to NULL when it's this bubble. |
| 362 if (zoom_bubble_ == this) | 359 if (zoom_bubble_ == this) |
| 363 zoom_bubble_ = NULL; | 360 zoom_bubble_ = NULL; |
| 364 } | 361 } |
| 365 | 362 |
| 366 ZoomBubbleView::ZoomBubbleExtensionInfo::ZoomBubbleExtensionInfo() {} | 363 ZoomBubbleView::ZoomBubbleExtensionInfo::ZoomBubbleExtensionInfo() {} |
| 367 | 364 |
| 368 ZoomBubbleView::ZoomBubbleExtensionInfo::~ZoomBubbleExtensionInfo() {} | 365 ZoomBubbleView::ZoomBubbleExtensionInfo::~ZoomBubbleExtensionInfo() {} |
| OLD | NEW |