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

Unified Diff: chrome/browser/ui/zoom/zoom_tab_helper.h

Issue 10444040: Tracks changes to zoom icon and zoom percentage. Notifies browser window if the icon should be chan… (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Created 8 years, 7 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/zoom/zoom_tab_helper.h
diff --git a/chrome/browser/ui/zoom/zoom_tab_helper.h b/chrome/browser/ui/zoom/zoom_tab_helper.h
new file mode 100644
index 0000000000000000000000000000000000000000..5392915f26c15a0516f58c9aedf4a1a4aab8d85c
--- /dev/null
+++ b/chrome/browser/ui/zoom/zoom_tab_helper.h
@@ -0,0 +1,72 @@
+// 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.
+
+#ifndef CHROME_BROWSER_UI_ZOOM_ZOOM_TAB_HELPER_H_
+#define CHROME_BROWSER_UI_ZOOM_ZOOM_TAB_HELPER_H_
+#pragma once
+
+#include "chrome/browser/prefs/pref_member.h"
+#include "content/public/browser/notification_observer.h"
+#include "content/public/browser/notification_registrar.h"
+#include "content/public/browser/web_contents_observer.h"
+
+class TabContentsWrapper;
+class ZoomTabHelperDelegate;
+
+// Per-tab class to manage the Omnibox zoom icon.
+class ZoomTabHelper : public content::NotificationObserver,
Ben Goodger (Google) 2012/05/29 18:04:41 ZoomController
Kyle Horimoto 2012/05/31 23:13:52 Done.
+ public content::WebContentsObserver {
+ public:
+ explicit ZoomTabHelper(TabContentsWrapper* tab_contents);
+ virtual ~ZoomTabHelper();
+
+ enum ZoomIconState {
tfarina 2012/05/29 18:09:12 nit: this should goes first in this section (i.e,
Kyle Horimoto 2012/05/31 23:13:52 Done.
+ NONE = 0,
+ ZOOM_PLUS_ICON,
+ ZOOM_MINUS_ICON,
+ };
+
+ ZoomIconState zoom_icon_status() const { return zoom_icon_state_; }
tfarina 2012/05/29 18:09:12 nit: zoom_icon_state()
Kyle Horimoto 2012/05/31 23:13:52 Done.
+ int zoom_percent() const { return zoom_percent_; }
+
+ ZoomTabHelperDelegate* delegate() const { return delegate_; }
+ void set_delegate(ZoomTabHelperDelegate* d) { delegate_ = d; }
+
+ // content::WebContentsObserver overrides:
+ virtual void DidNavigateMainFrame(
tfarina 2012/05/29 18:09:12 I bet you can make this and Observe private.
Kyle Horimoto 2012/05/31 23:13:52 Done.
+ const content::LoadCommittedDetails& details,
+ const content::FrameNavigateParams& params) OVERRIDE;
tfarina 2012/05/29 18:09:12 include compiler_specific.h for OVERRIDE
Kyle Horimoto 2012/05/31 23:13:52 Done.
+
+ // content::NotificationObserver overrides:
+ virtual void Observe(int type,
+ const content::NotificationSource& source,
+ const content::NotificationDetails& details) OVERRIDE;
+
+ private:
+ // Updates the zoom icon and zoom percentage based on current values and
+ // notifies the delegate if changes have occurred.
+ void UpdateState();
+
+ // The current zoom icon state.
+ ZoomIconState zoom_icon_state_;
+
+ // The current zoom percentage.
+ int zoom_percent_;
+
+ // Registers and unregisters notifications.
tfarina 2012/05/29 18:09:12 nit: I'd remove this comment, it doesn't add much,
Kyle Horimoto 2012/05/31 23:13:52 Done.
+ content::NotificationRegistrar registrar_;
+
+ // Used to access the default zoom level preference.
+ DoublePrefMember default_zoom_level_;
+
+ // Owning TabContentsWrapper.
tfarina 2012/05/29 18:09:12 I guess you don't own TabContentsWrapper.
Kyle Horimoto 2012/05/31 23:13:52 No, it owns this.
tfarina 2012/05/31 23:21:00 You don't own TabContentsWrapper. This is a weak p
Kyle Horimoto 2012/05/31 23:37:20 Not quite sure what you're trying to say here. Thi
+ TabContentsWrapper* tab_contents_wrapper_;
Ben Goodger (Google) 2012/05/29 18:04:41 you don't appear to use this as a TabContentsWrapp
Kyle Horimoto 2012/05/31 23:13:52 Actually, I do use it as a TabContentsWrapper. It
+
+ // Delegate receiving notifications on state changes.
+ ZoomTabHelperDelegate* delegate_;
+
+ DISALLOW_COPY_AND_ASSIGN(ZoomTabHelper);
tfarina 2012/05/29 18:09:12 include basictypes.h for this.
Kyle Horimoto 2012/05/31 23:13:52 Done.
+};
+
+#endif // CHROME_BROWSER_UI_ZOOM_ZOOM_TAB_HELPER_H_

Powered by Google App Engine
This is Rietveld 408576698