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

Side by Side Diff: chrome/browser/media/media_stream_capture_indicator.h

Issue 11027044: Add a class to replace ImageLoadingTracker with a nicer API. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: remove unused code Created 8 years, 1 month 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 | Annotate | Revision Log
OLDNEW
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_MEDIA_MEDIA_STREAM_CAPTURE_INDICATOR_H_ 5 #ifndef CHROME_BROWSER_MEDIA_MEDIA_STREAM_CAPTURE_INDICATOR_H_
6 #define CHROME_BROWSER_MEDIA_MEDIA_STREAM_CAPTURE_INDICATOR_H_ 6 #define CHROME_BROWSER_MEDIA_MEDIA_STREAM_CAPTURE_INDICATOR_H_
7 7
8 #include <string> 8 #include <string>
9 #include <vector> 9 #include <vector>
10 10
11 #include "base/memory/scoped_ptr.h" 11 #include "base/memory/scoped_ptr.h"
12 #include "chrome/browser/extensions/image_loading_tracker.h"
13 #include "content/public/common/media_stream_request.h" 12 #include "content/public/common/media_stream_request.h"
14 #include "ui/base/models/simple_menu_model.h" 13 #include "ui/base/models/simple_menu_model.h"
15 #include "ui/gfx/image/image_skia.h" 14 #include "ui/gfx/image/image_skia.h"
16 15
17 class StatusIcon; 16 class StatusIcon;
18 class StatusTray; 17 class StatusTray;
19 18
20 // This indicator is owned by MediaInternals and deleted when MediaInternals 19 // This indicator is owned by MediaInternals and deleted when MediaInternals
21 // is deleted. 20 // is deleted.
22 class MediaStreamCaptureIndicator : public ui::SimpleMenuModel::Delegate, 21 class MediaStreamCaptureIndicator : public ui::SimpleMenuModel::Delegate {
23 public ImageLoadingTracker::Observer {
24 public: 22 public:
25 MediaStreamCaptureIndicator(); 23 MediaStreamCaptureIndicator();
26 virtual ~MediaStreamCaptureIndicator(); 24 virtual ~MediaStreamCaptureIndicator();
27 25
28 // Overrides from SimpleMenuModel::Delegate implementation. 26 // Overrides from SimpleMenuModel::Delegate implementation.
29 virtual bool IsCommandIdChecked(int command_id) const OVERRIDE; 27 virtual bool IsCommandIdChecked(int command_id) const OVERRIDE;
30 virtual bool IsCommandIdEnabled(int command_id) const OVERRIDE; 28 virtual bool IsCommandIdEnabled(int command_id) const OVERRIDE;
31 virtual bool GetAcceleratorForCommandId( 29 virtual bool GetAcceleratorForCommandId(
32 int command_id, 30 int command_id,
33 ui::Accelerator* accelerator) OVERRIDE; 31 ui::Accelerator* accelerator) OVERRIDE;
34 virtual void ExecuteCommand(int command_id) OVERRIDE; 32 virtual void ExecuteCommand(int command_id) OVERRIDE;
35 33
36 // Called on IO thread when MediaStream opens new capture devices. 34 // Called on IO thread when MediaStream opens new capture devices.
37 void CaptureDevicesOpened(int render_process_id, 35 void CaptureDevicesOpened(int render_process_id,
38 int render_view_id, 36 int render_view_id,
39 const content::MediaStreamDevices& devices); 37 const content::MediaStreamDevices& devices);
40 38
41 // Called on IO thread when MediaStream closes the opened devices. 39 // Called on IO thread when MediaStream closes the opened devices.
42 void CaptureDevicesClosed(int render_process_id, 40 void CaptureDevicesClosed(int render_process_id,
43 int render_view_id, 41 int render_view_id,
44 const content::MediaStreamDevices& devices); 42 const content::MediaStreamDevices& devices);
45 43
46 // Returns true if the render process is capturing media. 44 // Returns true if the render process is capturing media.
47 bool IsProcessCapturing(int render_process_id, int render_view_id) const; 45 bool IsProcessCapturing(int render_process_id, int render_view_id) const;
48 46
49 // ImageLoadingTracker::Observer implementation. 47 // ImageLoader callback.
50 virtual void OnImageLoaded(const gfx::Image& image, 48 void OnImageLoaded(const string16& message, const gfx::Image& image);
51 const std::string& extension_id,
52 int index) OVERRIDE;
53 49
54 private: 50 private:
55 // Struct to store the usage information of the capture devices for each tab. 51 // Struct to store the usage information of the capture devices for each tab.
56 // TODO(estade): this should be called CaptureDeviceContents; not all the 52 // TODO(estade): this should be called CaptureDeviceContents; not all the
57 // render views it represents are tabs. 53 // render views it represents are tabs.
58 struct CaptureDeviceTab { 54 struct CaptureDeviceTab {
59 CaptureDeviceTab(int render_process_id, 55 CaptureDeviceTab(int render_process_id,
60 int render_view_id) 56 int render_view_id)
61 : render_process_id(render_process_id), 57 : render_process_id(render_process_id),
62 render_view_id(render_view_id), 58 render_view_id(render_view_id),
(...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after
119 115
120 // Updates the status tray menu with the new device list. This call will be 116 // Updates the status tray menu with the new device list. This call will be
121 // triggered by both AddCaptureDeviceTab() and RemoveCaptureDeviceTab(). 117 // triggered by both AddCaptureDeviceTab() and RemoveCaptureDeviceTab().
122 void UpdateStatusTrayIconContextMenu(); 118 void UpdateStatusTrayIconContextMenu();
123 119
124 // Updates the status tray tooltip and image according to which kind of 120 // Updates the status tray tooltip and image according to which kind of
125 // devices are being used. This function is called by 121 // devices are being used. This function is called by
126 // UpdateStatusTrayIconContextMenu(). 122 // UpdateStatusTrayIconContextMenu().
127 void UpdateStatusTrayIconDisplay(bool audio, bool video); 123 void UpdateStatusTrayIconDisplay(bool audio, bool video);
128 124
129 // Initializes image loading state.
130 void EnsureImageLoadingTracker();
131
132 // Reference to our status icon - owned by the StatusTray. If null, 125 // Reference to our status icon - owned by the StatusTray. If null,
133 // the platform doesn't support status icons. 126 // the platform doesn't support status icons.
134 StatusIcon* status_icon_; 127 StatusIcon* status_icon_;
135 128
136 // These images are owned by ResourceBundle and need not be destroyed. 129 // These images are owned by ResourceBundle and need not be destroyed.
137 gfx::ImageSkia* mic_image_; 130 gfx::ImageSkia* mic_image_;
138 gfx::ImageSkia* camera_image_; 131 gfx::ImageSkia* camera_image_;
139 gfx::ImageSkia* balloon_image_; 132 gfx::ImageSkia* balloon_image_;
140 133
141 // A list that contains the usage information of the opened capture devices. 134 // A list that contains the usage information of the opened capture devices.
142 typedef std::vector<CaptureDeviceTab> CaptureDeviceTabs; 135 typedef std::vector<CaptureDeviceTab> CaptureDeviceTabs;
143 CaptureDeviceTabs tabs_; 136 CaptureDeviceTabs tabs_;
144 137
145 // Tracks the load of extension icons.
146 scoped_ptr<ImageLoadingTracker> tracker_;
147 // The messages to display when extension images are loaded. The index
148 // corresponds to the index of the associated LoadImage request.
149 std::map<int, string16> pending_messages_;
150 // Tracks the number of requests to |tracker_|.
151 int request_index_;
152
153 base::WeakPtrFactory<MediaStreamCaptureIndicator> weak_ptr_factory_; 138 base::WeakPtrFactory<MediaStreamCaptureIndicator> weak_ptr_factory_;
139 base::WeakPtrFactory<MediaStreamCaptureIndicator> icon_tracker_;
154 140
155 DISALLOW_COPY_AND_ASSIGN(MediaStreamCaptureIndicator); 141 DISALLOW_COPY_AND_ASSIGN(MediaStreamCaptureIndicator);
156 }; 142 };
157 143
158 #endif // CHROME_BROWSER_MEDIA_MEDIA_STREAM_CAPTURE_INDICATOR_H_ 144 #endif // CHROME_BROWSER_MEDIA_MEDIA_STREAM_CAPTURE_INDICATOR_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698