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

Unified Diff: chrome/browser/ui/views/location_bar/zoom_bubble_view.cc

Issue 10494004: Implements a zoom icon in the Omnibox for Views. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Created 8 years, 6 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
Index: chrome/browser/ui/views/location_bar/zoom_bubble_view.cc
diff --git a/chrome/browser/ui/views/location_bar/zoom_bubble_view.cc b/chrome/browser/ui/views/location_bar/zoom_bubble_view.cc
new file mode 100644
index 0000000000000000000000000000000000000000..145ba83cb447cab8c4c80ddafe22b44097954d75
--- /dev/null
+++ b/chrome/browser/ui/views/location_bar/zoom_bubble_view.cc
@@ -0,0 +1,101 @@
+// Copyright (c) 2012 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 "chrome/browser/ui/views/location_bar/zoom_bubble_view.h"
+
+#include "base/bind.h"
+#include "base/message_loop.h"
+#include "grit/generated_resources.h"
+#include "ui/base/l10n/l10n_util.h"
+#include "ui/views/layout/fill_layout.h"
+
+namespace {
+
+// The number of milliseconds the bubble should stay on the screen for if it
+// will automatically close.
+const int kBubbleCloseDelay = 400;
+
+}
+
+// static
+ZoomBubbleView* ZoomBubbleView::zoom_bubble_ = NULL;
+
+// static
+void ZoomBubbleView::ShowBubble(views::View* anchor_view,
+ int zoom_percent,
+ bool auto_close) {
+ // If the bubble is already showing in this window and its |auto_close_| value
+ // is equal to |auto_close|, the bubble can be reused and only the label text
+ // needs to be updated.
+ if (zoom_bubble_ &&
+ zoom_bubble_->anchor_view() == anchor_view &&
+ zoom_bubble_->auto_close_ == auto_close) {
+ zoom_bubble_->label_->SetText(
+ l10n_util::GetStringFUTF16Int(IDS_ZOOM_PERCENT, zoom_percent));
+
+ if (auto_close) {
+ // If the bubble should be closed automatically, reset the timer so that
+ // it will show for the full amount of time instead of only what remained
+ // from the previous time.
+ zoom_bubble_->timer_.Reset();
+ }
+ } else {
+ // If the bubble is already showing but its |auto_close_| value is not equal
+ // to |auto_close|, the bubble's focus properties must change, so the
+ // current bubble must be closed and a new one created.
+ if (zoom_bubble_)
+ zoom_bubble_->Close();
+
+ zoom_bubble_ = new ZoomBubbleView(anchor_view, zoom_percent, auto_close);
+ views::BubbleDelegateView::CreateBubble(zoom_bubble_);
+ zoom_bubble_->Show();
+ }
+}
+
+// static
+void ZoomBubbleView::CloseBubble() {
+ if (zoom_bubble_)
+ zoom_bubble_->Close();
+}
+
+// static
+bool ZoomBubbleView::IsShowing() {
+ return zoom_bubble_ != NULL;
+}
+
+void ZoomBubbleView::WindowClosing() {
+ DCHECK(zoom_bubble_ == this);
+ zoom_bubble_ = NULL;
+}
+
+void ZoomBubbleView::Init() {
+ SetLayoutManager(new views::FillLayout());
+ label_ = new views::Label(
+ l10n_util::GetStringFUTF16Int(IDS_ZOOM_PERCENT, zoom_percent_));
+ AddChildView(label_);
+
+ if (auto_close_) {
+ timer_.Start(
+ FROM_HERE,
+ base::TimeDelta::FromMilliseconds(kBubbleCloseDelay),
+ this,
+ &ZoomBubbleView::Close);
+ }
+}
+
+ZoomBubbleView::ZoomBubbleView(views::View* anchor_view,
+ int zoom_percent,
+ bool auto_close)
+ : BubbleDelegateView(anchor_view, views::BubbleBorder::TOP_RIGHT),
+ zoom_percent_(zoom_percent),
+ auto_close_(auto_close) {
+ set_use_focusless(auto_close);
+}
+
+ZoomBubbleView::~ZoomBubbleView() {
+}
+
+void ZoomBubbleView::Close() {
+ GetWidget()->Close();
+}
« no previous file with comments | « chrome/browser/ui/views/location_bar/zoom_bubble_view.h ('k') | chrome/browser/ui/views/location_bar/zoom_view.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698