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 #ifndef CONTENT_BROWSER_HOST_ZOOM_MAP_IMPL_H_ | 5 #ifndef CONTENT_BROWSER_HOST_ZOOM_MAP_IMPL_H_ |
6 #define CONTENT_BROWSER_HOST_ZOOM_MAP_IMPL_H_ | 6 #define CONTENT_BROWSER_HOST_ZOOM_MAP_IMPL_H_ |
7 | 7 |
8 #include <map> | 8 #include <map> |
9 #include <string> | 9 #include <string> |
10 #include <vector> | 10 #include <vector> |
(...skipping 28 matching lines...) Expand all Loading... | |
39 double level) OVERRIDE; | 39 double level) OVERRIDE; |
40 virtual void SetZoomLevelForHostAndScheme( | 40 virtual void SetZoomLevelForHostAndScheme( |
41 const std::string& scheme, | 41 const std::string& scheme, |
42 const std::string& host, | 42 const std::string& host, |
43 double level) OVERRIDE; | 43 double level) OVERRIDE; |
44 virtual double GetDefaultZoomLevel() const OVERRIDE; | 44 virtual double GetDefaultZoomLevel() const OVERRIDE; |
45 virtual void SetDefaultZoomLevel(double level) OVERRIDE; | 45 virtual void SetDefaultZoomLevel(double level) OVERRIDE; |
46 virtual scoped_ptr<Subscription> AddZoomLevelChangedCallback( | 46 virtual scoped_ptr<Subscription> AddZoomLevelChangedCallback( |
47 const ZoomLevelChangedCallback& callback) OVERRIDE; | 47 const ZoomLevelChangedCallback& callback) OVERRIDE; |
48 | 48 |
49 // Returns the current zoom level for the specified WebContents. This may | |
50 // be a temporary zoom level, depending on UsesTemporarySoomLevel(). | |
Peter Kasting
2014/05/28 22:49:58
Nit: Soom -> Zoom
wjmaclean
2014/05/29 14:49:45
Done.
| |
51 double GetZoomLevelForWebContents( | |
52 const WebContents& web_contents) const; | |
53 | |
54 // Sets the zoom level for this WebContents. If this WebContents is using | |
55 // a temporary zoom level, then level is only applied to this WebContents. | |
56 // Otherwise, the level will be applied on a host level. | |
57 void SetZoomLevelForWebContents(const WebContents& web_contents, | |
58 double level); | |
59 | |
60 // Sets the zoom level for the specified view. The level may be set for only | |
61 // this view, or for the host, depending on UsesTemporaryZoomLevel(). | |
62 void SetZoomLevelForView(int render_process_id, | |
63 int render_view_id, | |
64 double level, | |
65 const std::string& host); | |
66 | |
67 // Returns true if the view specified has its zoom level managed separately | |
68 // from the host specification. | |
Peter Kasting
2014/05/28 22:49:58
Nit: How about:
Returns whether the view manages
wjmaclean
2014/05/29 14:49:45
Sure, sounds good.
| |
69 bool UsesTemporaryZoomLevel(int render_process_id, int render_view_id) const; | |
70 | |
71 // Causes the view specified to have its zoom level set independently of other | |
72 // tabs displaying content from the same host, if uses_temporary_zoom_settings | |
73 // is true. | |
Peter Kasting
2014/05/28 22:49:58
Nit: How about:
Sets whether the view manages its
wjmaclean
2014/05/29 14:49:45
Sure, good wording!
| |
74 void SetUsesTemporaryZoomLevel(int render_process_id, | |
75 int render_view_id, | |
76 bool uses_temporary_zoom_settings); | |
Peter Kasting
2014/05/28 22:49:58
Nit: I'd call this arg "...level" and not "...sett
wjmaclean
2014/05/29 14:49:45
Done.
| |
77 | |
49 // Returns the temporary zoom level that's only valid for the lifetime of | 78 // Returns the temporary zoom level that's only valid for the lifetime of |
50 // the given WebContents (i.e. isn't saved and doesn't affect other | 79 // the given WebContents (i.e. isn't saved and doesn't affect other |
51 // WebContentses) if it exists, the default zoom level otherwise. | 80 // WebContentses) if it exists, the default zoom level otherwise. |
52 // | 81 // |
53 // This may be called on any thread. | 82 // This may be called on any thread. |
54 double GetTemporaryZoomLevel(int render_process_id, | 83 double GetTemporaryZoomLevel(int render_process_id, |
55 int render_view_id) const; | 84 int render_view_id) const; |
56 | 85 |
57 // Sets the temporary zoom level that's only valid for the lifetime of this | 86 // Sets the temporary zoom level that's only valid for the lifetime of this |
58 // WebContents. | 87 // WebContents. |
(...skipping 17 matching lines...) Expand all Loading... | |
76 // Callbacks called when zoom level changes. | 105 // Callbacks called when zoom level changes. |
77 base::CallbackList<void(const ZoomLevelChange&)> | 106 base::CallbackList<void(const ZoomLevelChange&)> |
78 zoom_level_changed_callbacks_; | 107 zoom_level_changed_callbacks_; |
79 | 108 |
80 // Copy of the pref data, so that we can read it on the IO thread. | 109 // Copy of the pref data, so that we can read it on the IO thread. |
81 HostZoomLevels host_zoom_levels_; | 110 HostZoomLevels host_zoom_levels_; |
82 SchemeHostZoomLevels scheme_host_zoom_levels_; | 111 SchemeHostZoomLevels scheme_host_zoom_levels_; |
83 double default_zoom_level_; | 112 double default_zoom_level_; |
84 | 113 |
85 struct TemporaryZoomLevel { | 114 struct TemporaryZoomLevel { |
86 int render_process_id; | 115 int render_process_id; |
Peter Kasting
2014/05/28 22:49:58
Nit: Members below functions
wjmaclean
2014/05/29 14:49:45
Done.
| |
87 int render_view_id; | 116 int render_view_id; |
88 double zoom_level; | 117 double zoom_level; |
118 | |
119 TemporaryZoomLevel(int process_id, int view_id, double level) | |
120 : render_process_id(process_id), | |
121 render_view_id(view_id), | |
122 zoom_level(level) {} | |
Peter Kasting
2014/05/28 22:49:58
Nit: Since you have a .cc file anyway, I'd just mo
wjmaclean
2014/05/29 14:49:45
Done.
| |
123 | |
124 TemporaryZoomLevel(int process_id, int view_id) | |
125 : render_process_id(process_id), | |
126 render_view_id(view_id), | |
127 zoom_level(0.0) {} | |
128 | |
129 bool operator==(const TemporaryZoomLevel& other) const { | |
130 return other.render_process_id == render_process_id && | |
131 other.render_view_id == render_view_id; | |
132 } | |
89 }; | 133 }; |
90 | 134 |
91 // Don't expect more than a couple of tabs that are using a temporary zoom | 135 // Don't expect more than a couple of tabs that are using a temporary zoom |
92 // level, so vector is fine for now. | 136 // level, so vector is fine for now. |
93 std::vector<TemporaryZoomLevel> temporary_zoom_levels_; | 137 typedef std::vector<TemporaryZoomLevel> TemporaryZoomLevelList; |
Peter Kasting
2014/05/28 22:49:58
Don't put "list" in the name, especially when the
wjmaclean
2014/05/29 14:49:45
Done.
| |
138 TemporaryZoomLevelList temporary_zoom_levels_; | |
94 | 139 |
95 // Used around accesses to |host_zoom_levels_|, |default_zoom_level_| and | 140 // Used around accesses to |host_zoom_levels_|, |default_zoom_level_| and |
96 // |temporary_zoom_levels_| to guarantee thread safety. | 141 // |temporary_zoom_levels_| to guarantee thread safety. |
97 mutable base::Lock lock_; | 142 mutable base::Lock lock_; |
98 | 143 |
99 NotificationRegistrar registrar_; | 144 NotificationRegistrar registrar_; |
100 | 145 |
101 DISALLOW_COPY_AND_ASSIGN(HostZoomMapImpl); | 146 DISALLOW_COPY_AND_ASSIGN(HostZoomMapImpl); |
102 }; | 147 }; |
103 | 148 |
104 } // namespace content | 149 } // namespace content |
105 | 150 |
106 #endif // CONTENT_BROWSER_HOST_ZOOM_MAP_IMPL_H_ | 151 #endif // CONTENT_BROWSER_HOST_ZOOM_MAP_IMPL_H_ |
OLD | NEW |