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 #ifndef CHROME_BROWSER_UI_TABS_TAB_UTILS_H_ | 5 #ifndef CHROME_BROWSER_UI_TABS_TAB_UTILS_H_ |
| 6 #define CHROME_BROWSER_UI_TABS_TAB_UTILS_H_ | 6 #define CHROME_BROWSER_UI_TABS_TAB_UTILS_H_ |
| 7 | 7 |
| 8 #include <string> | 8 #include <string> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 #include "base/containers/hash_tables.h" |
| 11 #include "base/memory/scoped_ptr.h" | 11 #include "base/memory/scoped_ptr.h" |
| 12 #include "base/strings/string16.h" | 12 #include "base/strings/string16.h" |
| 13 #include "content/public/browser/web_contents_user_data.h" | 13 #include "content/public/browser/web_contents_user_data.h" |
| 14 | 14 |
| 15 class TabStripModel; | 15 class TabStripModel; |
| 16 | 16 |
| 17 namespace content { | 17 namespace content { |
| 18 class WebContents; | 18 class WebContents; |
| 19 } // namespace content | 19 } // namespace content |
| 20 | 20 |
| 21 namespace gfx { | 21 namespace gfx { |
| 22 class Animation; | 22 class Animation; |
| 23 class Image; | 23 class Image; |
| 24 } // namespace gfx | 24 } // namespace gfx |
| 25 | 25 |
| 26 // Media state for a tab. In reality, more than one of these may apply. See | 26 // Media state for a tab. In reality, more than one of these may apply. See |
| 27 // comments for GetTabMediaStateForContents() below. | 27 // comments for GetTabMediaStateForContents() below. |
| 28 enum TabMediaState { | 28 enum TabMediaState { |
| 29 TAB_MEDIA_STATE_NONE, | 29 TAB_MEDIA_STATE_NONE, |
| 30 TAB_MEDIA_STATE_RECORDING, // Audio/Video being recorded, consumed by tab. | 30 TAB_MEDIA_STATE_RECORDING, // Audio/Video being recorded, consumed by tab. |
| 31 TAB_MEDIA_STATE_CAPTURING, // Tab contents being captured. | 31 TAB_MEDIA_STATE_CAPTURING, // Tab contents being captured. |
| 32 TAB_MEDIA_STATE_AUDIO_PLAYING, // Audible audio is playing from the tab. | 32 TAB_MEDIA_STATE_AUDIO_PLAYING, // Audible audio is playing from the tab. |
| 33 TAB_MEDIA_STATE_AUDIO_MUTING, // Tab audio is being muted. | 33 TAB_MEDIA_STATE_AUDIO_MUTING, // Tab audio is being muted. |
| 34 }; | 34 }; |
| 35 | 35 |
| 36 enum TabMutedResult { | |
| 37 TAB_MUTED_RESULT_SUCCESS, | |
| 38 TAB_MUTED_RESULT_FAIL_NOT_ENABLED, | |
| 39 TAB_MUTED_RESULT_FAIL_TABCAPTURE, | |
| 40 TAB_MUTED_RESULT_FAIL_RATE_LIMITED, | |
| 41 }; | |
| 42 | |
| 36 namespace chrome { | 43 namespace chrome { |
| 37 | 44 |
| 38 // String to indicate reason for muted state change (user, capture, extension | 45 // String to indicate reason for muted state change (user, capture, extension |
| 39 // id, or empty string) | 46 // id, or empty string) |
| 40 extern const char kMutedToggleCauseUser[]; | 47 extern const char kMutedToggleCauseUser[]; |
| 41 extern const char kMutedToggleCauseCapture[]; | 48 extern const char kMutedToggleCauseCapture[]; |
| 42 | 49 |
| 50 // Constants for rate limiting mute updating by extensions | |
| 51 extern const int kMuteTokenBucketCostSeconds = 15; | |
|
miu
2015/07/16 00:28:26
style nit: Assignment of the constant needs to be
| |
| 52 extern const int kMuteTokenBucketCapacitySeconds = | |
| 53 3 * kMuteTokenBucketCostSeconds; | |
| 54 | |
| 43 // Logic to determine which components (i.e., close button, favicon, and media | 55 // Logic to determine which components (i.e., close button, favicon, and media |
| 44 // indicator) of a tab should be shown, given current state. |capacity| | 56 // indicator) of a tab should be shown, given current state. |capacity| |
| 45 // specifies how many components can be shown, given available tab width. | 57 // specifies how many components can be shown, given available tab width. |
| 46 // | 58 // |
| 47 // Precedence rules for deciding what to show when capacity is insufficient to | 59 // Precedence rules for deciding what to show when capacity is insufficient to |
| 48 // show everything: | 60 // show everything: |
| 49 // | 61 // |
| 50 // Active tab: Always show the close button, then the media indicator, then | 62 // Active tab: Always show the close button, then the media indicator, then |
| 51 // the favicon. | 63 // the favicon. |
| 52 // Inactive tab: Media indicator, then the favicon, then the close button. | 64 // Inactive tab: Media indicator, then the favicon, then the close button. |
| (...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 97 base::string16 AssembleTabTooltipText(const base::string16& title, | 109 base::string16 AssembleTabTooltipText(const base::string16& title, |
| 98 TabMediaState media_state); | 110 TabMediaState media_state); |
| 99 | 111 |
| 100 // Returns true if the experimental tab audio mute feature is enabled. | 112 // Returns true if the experimental tab audio mute feature is enabled. |
| 101 bool IsTabAudioMutingFeatureEnabled(); | 113 bool IsTabAudioMutingFeatureEnabled(); |
| 102 | 114 |
| 103 // Returns true if audio mute can be activated/deactivated for the given | 115 // Returns true if audio mute can be activated/deactivated for the given |
| 104 // |contents|. | 116 // |contents|. |
| 105 bool CanToggleAudioMute(content::WebContents* contents); | 117 bool CanToggleAudioMute(content::WebContents* contents); |
| 106 | 118 |
| 119 // Returns true if extension-driven muting is rate limited for a tab | |
| 120 bool IsTabAudioMutedRateLimited(content::WebContents* contents); | |
| 121 | |
| 107 // Indicates whether all audio output from |contents| is muted. | 122 // Indicates whether all audio output from |contents| is muted. |
| 108 bool IsTabAudioMuted(content::WebContents* contents); | 123 bool IsTabAudioMuted(content::WebContents* contents); |
| 109 | 124 |
| 110 // Sets whether all audio output from |contents| is muted. | 125 // Sets whether all audio output from |contents| is muted. |
| 111 // Cause is extensionid, kMutedToggleCause constant, or empty string | 126 // Cause is extensionid, kMutedToggleCause constant, or empty string |
| 112 void SetTabAudioMuted(content::WebContents* contents, | 127 TabMutedResult SetTabAudioMuted(content::WebContents* contents, |
| 113 bool mute, | 128 bool mute, |
| 114 const std::string& cause); | 129 const std::string& cause); |
| 115 | 130 |
| 116 // Get cause of mute (extensionid, kMutedToggleCause constant, or empty string) | 131 // Get cause of mute (extensionid, kMutedToggleCause constant, or empty string) |
| 117 const std::string& GetTabAudioMutedCause(content::WebContents* contents); | 132 const std::string& GetTabAudioMutedCause(content::WebContents* contents); |
| 118 | 133 |
| 134 // Update token buckets for rate limiting muting using elapsed time | |
| 135 void updateTokenBuckets(content::WebContents* contents); | |
|
miu
2015/07/16 00:28:26
Also, don't declare this function in the header fi
miu
2015/07/16 00:28:26
style: The "u" in updateTokenBuckets needs to be c
| |
| 136 | |
| 119 // Returns true if the tabs at the |indices| in |tab_strip| are all muted. | 137 // Returns true if the tabs at the |indices| in |tab_strip| are all muted. |
| 120 bool AreAllTabsMuted(const TabStripModel& tab_strip, | 138 bool AreAllTabsMuted(const TabStripModel& tab_strip, |
| 121 const std::vector<int>& indices); | 139 const std::vector<int>& indices); |
| 122 | 140 |
| 123 } // namespace chrome | 141 } // namespace chrome |
| 124 | 142 |
| 125 #endif // CHROME_BROWSER_UI_TABS_TAB_UTILS_H_ | 143 #endif // CHROME_BROWSER_UI_TABS_TAB_UTILS_H_ |
| OLD | NEW |