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

Side by Side Diff: chrome/browser/ui/cocoa/tabs/alert_indicator_button_cocoa.h

Issue 1827083004: UI: Rename MediaState to AlertState (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@bluetooth-tab-indicator
Patch Set: Keep gypi ordered Created 4 years, 8 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 unified diff | Download patch
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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_COCOA_TABS_MEDIA_INDICATOR_BUTTON_COCOA_H_ 5 #ifndef CHROME_BROWSER_UI_COCOA_TABS_ALERT_INDICATOR_BUTTON_COCOA_H_
6 #define CHROME_BROWSER_UI_COCOA_TABS_MEDIA_INDICATOR_BUTTON_COCOA_H_ 6 #define CHROME_BROWSER_UI_COCOA_TABS_ALERT_INDICATOR_BUTTON_COCOA_H_
7 7
8 #import "base/mac/scoped_nsobject.h" 8 #import "base/mac/scoped_nsobject.h"
9 #include "base/memory/scoped_ptr.h" 9 #include "base/memory/scoped_ptr.h"
10 #include "chrome/browser/ui/tabs/tab_utils.h" 10 #include "chrome/browser/ui/tabs/tab_utils.h"
11 #import "ui/base/cocoa/hover_button.h" 11 #import "ui/base/cocoa/hover_button.h"
12 12
13 namespace gfx { 13 namespace gfx {
14 class Animation; 14 class Animation;
15 class AnimationDelegate; 15 class AnimationDelegate;
16 } // namespace gfx 16 } // namespace gfx
17 17
18 // This is an HoverButton subclass that serves as both the media indicator icon 18 // This is an HoverButton subclass that serves as both the alert indicator icon
19 // (audio, tab capture, etc.), and as a mute button. It is meant to only be 19 // (audio, tab capture, etc.), and as a mute button. It is meant to only be
20 // used as a subview of TabView. 20 // used as a subview of TabView.
21 // 21 //
22 // When the indicator is transitioned to the audio playing or muting state, the 22 // When the indicator is transitioned to the audio playing or muting state, the
23 // button functionality is enabled and begins handling mouse events. Otherwise, 23 // button functionality is enabled and begins handling mouse events. Otherwise,
24 // this view behaves like an image and all mouse events will be handled by the 24 // this view behaves like an image and all mouse events will be handled by the
25 // its superview. 25 // its superview.
26 // 26 //
27 // Note: Send the |-setClickTarget:withAction:| message instead of the 27 // Note: Send the |-setClickTarget:withAction:| message instead of the
28 // |-setTarget:| and |-setAction:| messages to be notified of button clicks. 28 // |-setTarget:| and |-setAction:| messages to be notified of button clicks.
29 @interface MediaIndicatorButton : HoverButton { 29 @interface AlertIndicatorButton : HoverButton {
30 @private 30 @private
31 class FadeAnimationDelegate; 31 class FadeAnimationDelegate;
32 32
33 // Current TabMediaState. When animating fade-in/out, this reflects the 33 // Current TabAlertState. When animating fade-in/out, this reflects the
34 // indicator state at the end of the animation. 34 // indicator state at the end of the animation.
35 TabMediaState mediaState_; 35 TabAlertState alertState_;
36 36
37 // Media indicator fade-in/out animation (i.e., only on show/hide, not a 37 // Alert indicator fade-in/out animation (i.e., only on show/hide, not a
38 // continuous animation). 38 // continuous animation).
39 scoped_ptr<gfx::AnimationDelegate> fadeAnimationDelegate_; 39 scoped_ptr<gfx::AnimationDelegate> fadeAnimationDelegate_;
40 scoped_ptr<gfx::Animation> fadeAnimation_; 40 scoped_ptr<gfx::Animation> fadeAnimation_;
41 TabMediaState showingMediaState_; 41 TabAlertState showingAlertState_;
42 42
43 // Target and action invoked whenever a fade-in/out animation completes. This 43 // Target and action invoked whenever a fade-in/out animation completes. This
44 // is used by TabController to layout the TabView after an indicator has 44 // is used by TabController to layout the TabView after an indicator has
45 // completely faded out. 45 // completely faded out.
46 id animationDoneTarget_; // weak 46 id animationDoneTarget_; // weak
47 SEL animationDoneAction_; 47 SEL animationDoneAction_;
48 48
49 // The image to show when the mouse hovers over the button. 49 // The image to show when the mouse hovers over the button.
50 base::scoped_nsobject<NSImage> affordanceImage_; 50 base::scoped_nsobject<NSImage> affordanceImage_;
51 51
52 // Target and action invoked whenever an enabled button is clicked. 52 // Target and action invoked whenever an enabled button is clicked.
53 id clickTarget_; // weak 53 id clickTarget_; // weak
54 SEL clickAction_; 54 SEL clickAction_;
55 } 55 }
56 56
57 @property(readonly, nonatomic) TabMediaState showingMediaState; 57 @property(readonly, nonatomic) TabAlertState showingAlertState;
58 58
59 // Initialize a new MediaIndicatorButton in TAB_MEDIA_STATE_NONE (i.e., a 59 // Initialize a new AlertIndicatorButton in TabAlertState::NONE (i.e., a
60 // non-active indicator). 60 // non-active indicator).
61 - (id)init; 61 - (id)init;
62 62
63 // Updates button images, starts fade animations, and activates/deactivates 63 // Updates button images, starts fade animations, and activates/deactivates
64 // button functionality as appropriate. 64 // button functionality as appropriate.
65 - (void)transitionToMediaState:(TabMediaState)nextState; 65 - (void)transitionToAlertState:(TabAlertState)nextState;
66 66
67 // Determines whether the MediaIndicatorButtonCocoa will be clickable for 67 // Determines whether the AlertIndicatorButtonCocoa will be clickable for
68 // toggling muting. This should be called whenever the frame of this view is 68 // toggling muting. This should be called whenever the frame of this view is
69 // changed, and also whenever the active/inactive state of the tab has changed. 69 // changed, and also whenever the active/inactive state of the tab has changed.
70 // Internally, |-transitionToMediaState:| will call this. 70 // Internally, |-transitionToAlertState:| will call this.
71 - (void)updateEnabledForMuteToggle; 71 - (void)updateEnabledForMuteToggle;
72 72
73 // Register a message be sent to |target| whenever fade animations complete. A 73 // Register a message be sent to |target| whenever fade animations complete. A
74 // weak reference on |target| is held. 74 // weak reference on |target| is held.
75 - (void)setAnimationDoneTarget:(id)target withAction:(SEL)action; 75 - (void)setAnimationDoneTarget:(id)target withAction:(SEL)action;
76 76
77 // Request a message be sent to |target| whenever the enabled button has been 77 // Request a message be sent to |target| whenever the enabled button has been
78 // clicked. A weak reference on |target| is held. 78 // clicked. A weak reference on |target| is held.
79 - (void)setClickTarget:(id)target withAction:(SEL)action; 79 - (void)setClickTarget:(id)target withAction:(SEL)action;
80 80
81 @end 81 @end
82 82
83 #endif // CHROME_BROWSER_UI_COCOA_TABS_MEDIA_INDICATOR_BUTTON_COCOA_H_ 83 #endif // CHROME_BROWSER_UI_COCOA_TABS_ALERT_INDICATOR_BUTTON_COCOA_H_
OLDNEW
« no previous file with comments | « chrome/browser/ui/cocoa/tabs/OWNERS ('k') | chrome/browser/ui/cocoa/tabs/alert_indicator_button_cocoa.mm » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698