OLD | NEW |
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 #import "chrome/browser/ui/cocoa/media_picker/desktop_media_picker_controller.h" | 5 #import "chrome/browser/ui/cocoa/media_picker/desktop_media_picker_controller_de
precated.h" |
6 | 6 |
7 #include <utility> | 7 #include <utility> |
8 | 8 |
9 #include "base/bind.h" | 9 #include "base/bind.h" |
10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
11 #import "base/mac/bundle_locations.h" | 11 #import "base/mac/bundle_locations.h" |
12 #include "base/strings/sys_string_conversions.h" | 12 #include "base/strings/sys_string_conversions.h" |
13 #include "chrome/browser/media/combined_desktop_media_list.h" | 13 #include "chrome/browser/media/combined_desktop_media_list.h" |
14 #import "chrome/browser/ui/cocoa/key_equivalent_constants.h" | 14 #import "chrome/browser/ui/cocoa/key_equivalent_constants.h" |
15 #import "chrome/browser/ui/cocoa/media_picker/desktop_media_picker_item.h" | 15 #import "chrome/browser/ui/cocoa/media_picker/desktop_media_picker_item.h" |
(...skipping 16 matching lines...) Expand all Loading... |
32 const int kMinimumContentWidth = 500; | 32 const int kMinimumContentWidth = 500; |
33 const int kMinimumContentHeight = 390; | 33 const int kMinimumContentHeight = 390; |
34 const int kThumbnailWidth = 150; | 34 const int kThumbnailWidth = 150; |
35 const int kThumbnailHeight = 150; | 35 const int kThumbnailHeight = 150; |
36 const int kFramePadding = 20; | 36 const int kFramePadding = 20; |
37 const int kControlSpacing = 10; | 37 const int kControlSpacing = 10; |
38 const int kExcessButtonPadding = 6; | 38 const int kExcessButtonPadding = 6; |
39 | 39 |
40 } // namespace | 40 } // namespace |
41 | 41 |
42 @interface DesktopMediaPickerController (Private) | 42 @interface DesktopMediaPickerControllerDeprecated (Private) |
43 | 43 |
44 // Populate the window with controls and views. | 44 // Populate the window with controls and views. |
45 - (void)initializeContentsWithAppName:(const base::string16&)appName; | 45 - (void)initializeContentsWithAppName:(const base::string16&)appName; |
46 | 46 |
47 // Create a |NSTextField| with label traits given |width|. Frame height is | 47 // Create a |NSTextField| with label traits given |width|. Frame height is |
48 // automatically adjusted to fit. | 48 // automatically adjusted to fit. |
49 - (NSTextField*)createTextFieldWithText:(NSString*)text | 49 - (NSTextField*)createTextFieldWithText:(NSString*)text |
50 frameWidth:(CGFloat)width; | 50 frameWidth:(CGFloat)width; |
51 | 51 |
52 // Create a button with |title|, with size adjusted to fit. | 52 // Create a button with |title|, with size adjusted to fit. |
53 - (NSButton*)createButtonWithTitle:(NSString*)title; | 53 - (NSButton*)createButtonWithTitle:(NSString*)title; |
54 | 54 |
55 // Report result by invoking |doneCallback_|. The callback is invoked only on | 55 // Report result by invoking |doneCallback_|. The callback is invoked only on |
56 // the first call to |reportResult:|. Subsequent calls will be no-ops. | 56 // the first call to |reportResult:|. Subsequent calls will be no-ops. |
57 - (void)reportResult:(content::DesktopMediaID)sourceID; | 57 - (void)reportResult:(content::DesktopMediaID)sourceID; |
58 | 58 |
59 // Action handlers. | 59 // Action handlers. |
60 - (void)sharePressed:(id)sender; | 60 - (void)sharePressed:(id)sender; |
61 - (void)cancelPressed:(id)sender; | 61 - (void)cancelPressed:(id)sender; |
62 | 62 |
63 @end | 63 @end |
64 | 64 |
65 @implementation DesktopMediaPickerController | 65 @implementation DesktopMediaPickerControllerDeprecated |
66 | 66 |
67 - (id)initWithScreenList:(std::unique_ptr<DesktopMediaList>)screen_list | 67 - (id)initWithScreenList:(std::unique_ptr<DesktopMediaList>)screen_list |
68 windowList:(std::unique_ptr<DesktopMediaList>)window_list | 68 windowList:(std::unique_ptr<DesktopMediaList>)window_list |
69 tabList:(std::unique_ptr<DesktopMediaList>)tab_list | 69 tabList:(std::unique_ptr<DesktopMediaList>)tab_list |
70 parent:(NSWindow*)parent | 70 parent:(NSWindow*)parent |
71 callback:(const DesktopMediaPicker::DoneCallback&)callback | 71 callback:(const DesktopMediaPicker::DoneCallback&)callback |
72 appName:(const base::string16&)appName | 72 appName:(const base::string16&)appName |
73 targetName:(const base::string16&)targetName | 73 targetName:(const base::string16&)targetName |
74 requestAudio:(bool)requestAudio { | 74 requestAudio:(bool)requestAudio { |
75 const NSUInteger kStyleMask = | 75 const NSUInteger kStyleMask = |
76 NSTitledWindowMask | NSClosableWindowMask | NSResizableWindowMask; | 76 NSTitledWindowMask | NSClosableWindowMask | NSResizableWindowMask; |
77 base::scoped_nsobject<NSWindow> window( | 77 base::scoped_nsobject<NSWindow> window([[NSWindow alloc] |
78 [[NSWindow alloc] initWithContentRect:ui::kWindowSizeDeterminedLater | 78 initWithContentRect:ui::kWindowSizeDeterminedLater |
79 styleMask:kStyleMask | 79 styleMask:kStyleMask |
80 backing:NSBackingStoreBuffered | 80 backing:NSBackingStoreBuffered |
81 defer:NO]); | 81 defer:NO]); |
82 | 82 |
83 if ((self = [super initWithWindow:window])) { | 83 if ((self = [super initWithWindow:window])) { |
84 [parent addChildWindow:window ordered:NSWindowAbove]; | 84 [parent addChildWindow:window ordered:NSWindowAbove]; |
85 [window setDelegate:self]; | 85 [window setDelegate:self]; |
86 [self initializeContentsWithAppName:appName | 86 [self initializeContentsWithAppName:appName |
87 targetName:targetName | 87 targetName:targetName |
88 requestAudio:requestAudio]; | 88 requestAudio:requestAudio]; |
89 std::vector<std::unique_ptr<DesktopMediaList>> media_lists; | 89 std::vector<std::unique_ptr<DesktopMediaList>> media_lists; |
90 if (screen_list) | 90 if (screen_list) |
91 media_lists.push_back(std::move(screen_list)); | 91 media_lists.push_back(std::move(screen_list)); |
92 | 92 |
93 if (window_list) | 93 if (window_list) |
94 media_lists.push_back(std::move(window_list)); | 94 media_lists.push_back(std::move(window_list)); |
95 | 95 |
96 if (tab_list) | 96 if (tab_list) |
97 media_lists.push_back(std::move(tab_list)); | 97 media_lists.push_back(std::move(tab_list)); |
98 | 98 |
99 if (media_lists.size() > 1) | 99 if (media_lists.size() > 1) |
100 media_list_.reset(new CombinedDesktopMediaList(media_lists)); | 100 media_list_.reset(new CombinedDesktopMediaList(media_lists)); |
101 else | 101 else |
102 media_list_ = std::move(media_lists[0]); | 102 media_list_ = std::move(media_lists[0]); |
103 media_list_->SetViewDialogWindowId(content::DesktopMediaID( | 103 media_list_->SetViewDialogWindowId(content::DesktopMediaID( |
104 content::DesktopMediaID::TYPE_WINDOW, [window windowNumber])); | 104 content::DesktopMediaID::TYPE_WINDOW, [window windowNumber])); |
105 doneCallback_ = callback; | 105 doneCallback_ = callback; |
106 items_.reset([[NSMutableArray alloc] init]); | 106 items_.reset([[NSMutableArray alloc] init]); |
107 bridge_.reset(new DesktopMediaPickerBridge(self)); | 107 bridge_.reset(new DesktopMediaPickerBridge(self)); |
108 } | 108 } |
109 return self; | 109 return self; |
110 } | 110 } |
111 | 111 |
112 - (void)dealloc { | 112 - (void)dealloc { |
113 [shareButton_ setTarget:nil]; | 113 [shareButton_ setTarget:nil]; |
114 [cancelButton_ setTarget:nil]; | 114 [cancelButton_ setTarget:nil]; |
(...skipping 14 matching lines...) Expand all Loading... |
129 NSPoint origin = NSMakePoint(kFramePadding, kFramePadding); | 129 NSPoint origin = NSMakePoint(kFramePadding, kFramePadding); |
130 | 130 |
131 // Set the dialog's title. | 131 // Set the dialog's title. |
132 NSString* titleText = l10n_util::GetNSStringF( | 132 NSString* titleText = l10n_util::GetNSStringF( |
133 IDS_DESKTOP_MEDIA_PICKER_TITLE_DEPRECATED, appName); | 133 IDS_DESKTOP_MEDIA_PICKER_TITLE_DEPRECATED, appName); |
134 [[self window] setTitle:titleText]; | 134 [[self window] setTitle:titleText]; |
135 | 135 |
136 // Set the dialog's description. | 136 // Set the dialog's description. |
137 NSString* descriptionText; | 137 NSString* descriptionText; |
138 if (appName == targetName) { | 138 if (appName == targetName) { |
139 descriptionText = l10n_util::GetNSStringF( | 139 descriptionText = |
140 IDS_DESKTOP_MEDIA_PICKER_TEXT, appName); | 140 l10n_util::GetNSStringF(IDS_DESKTOP_MEDIA_PICKER_TEXT, appName); |
141 } else { | 141 } else { |
142 descriptionText = l10n_util::GetNSStringF( | 142 descriptionText = l10n_util::GetNSStringF( |
143 IDS_DESKTOP_MEDIA_PICKER_TEXT_DELEGATED, appName, targetName); | 143 IDS_DESKTOP_MEDIA_PICKER_TEXT_DELEGATED, appName, targetName); |
144 } | 144 } |
145 NSTextField* description = [self createTextFieldWithText:descriptionText | 145 NSTextField* description = |
146 frameWidth:kPaddedWidth]; | 146 [self createTextFieldWithText:descriptionText frameWidth:kPaddedWidth]; |
147 [description setFrameOrigin:origin]; | 147 [description setFrameOrigin:origin]; |
148 [content addSubview:description]; | 148 [content addSubview:description]; |
149 origin.y += NSHeight([description frame]) + kControlSpacing; | 149 origin.y += NSHeight([description frame]) + kControlSpacing; |
150 | 150 |
151 // Create the image browser. | 151 // Create the image browser. |
152 sourceBrowser_.reset([[IKImageBrowserView alloc] initWithFrame:NSZeroRect]); | 152 sourceBrowser_.reset([[IKImageBrowserView alloc] initWithFrame:NSZeroRect]); |
153 NSUInteger cellStyle = IKCellsStyleShadowed | IKCellsStyleTitled; | 153 NSUInteger cellStyle = IKCellsStyleShadowed | IKCellsStyleTitled; |
154 [sourceBrowser_ setDelegate:self]; | 154 [sourceBrowser_ setDelegate:self]; |
155 [sourceBrowser_ setDataSource:self]; | 155 [sourceBrowser_ setDataSource:self]; |
156 [sourceBrowser_ setCellsStyleMask:cellStyle]; | 156 [sourceBrowser_ setCellsStyleMask:cellStyle]; |
157 [sourceBrowser_ setCellSize:NSMakeSize(kThumbnailWidth, kThumbnailHeight)]; | 157 [sourceBrowser_ setCellSize:NSMakeSize(kThumbnailWidth, kThumbnailHeight)]; |
158 [sourceBrowser_ setAllowsMultipleSelection:NO]; | 158 [sourceBrowser_ setAllowsMultipleSelection:NO]; |
159 | 159 |
160 // Create a scroll view to host the image browser. | 160 // Create a scroll view to host the image browser. |
161 NSRect imageBrowserScrollFrame = NSMakeRect( | 161 NSRect imageBrowserScrollFrame = |
162 origin.x, origin.y, kPaddedWidth, 350); | 162 NSMakeRect(origin.x, origin.y, kPaddedWidth, 350); |
163 base::scoped_nsobject<NSScrollView> imageBrowserScroll( | 163 base::scoped_nsobject<NSScrollView> imageBrowserScroll( |
164 [[NSScrollView alloc] initWithFrame:imageBrowserScrollFrame]); | 164 [[NSScrollView alloc] initWithFrame:imageBrowserScrollFrame]); |
165 [imageBrowserScroll setHasVerticalScroller:YES]; | 165 [imageBrowserScroll setHasVerticalScroller:YES]; |
166 [imageBrowserScroll setDocumentView:sourceBrowser_]; | 166 [imageBrowserScroll setDocumentView:sourceBrowser_]; |
167 [imageBrowserScroll setBorderType:NSBezelBorder]; | 167 [imageBrowserScroll setBorderType:NSBezelBorder]; |
168 [imageBrowserScroll setAutoresizingMask: | 168 [imageBrowserScroll |
169 NSViewWidthSizable | NSViewHeightSizable]; | 169 setAutoresizingMask:NSViewWidthSizable | NSViewHeightSizable]; |
170 [content addSubview:imageBrowserScroll]; | 170 [content addSubview:imageBrowserScroll]; |
171 origin.y += NSHeight(imageBrowserScrollFrame) + kControlSpacing; | 171 origin.y += NSHeight(imageBrowserScrollFrame) + kControlSpacing; |
172 | 172 |
173 // Create a checkbox for audio sharing. | 173 // Create a checkbox for audio sharing. |
174 if (requestAudio) { | 174 if (requestAudio) { |
175 audioShareCheckbox_.reset([[NSButton alloc] initWithFrame:NSZeroRect]); | 175 audioShareCheckbox_.reset([[NSButton alloc] initWithFrame:NSZeroRect]); |
176 [audioShareCheckbox_ setFrameOrigin:origin]; | 176 [audioShareCheckbox_ setFrameOrigin:origin]; |
177 [audioShareCheckbox_ | 177 [audioShareCheckbox_ |
178 setAutoresizingMask:NSViewMaxXMargin | NSViewMinYMargin]; | 178 setAutoresizingMask:NSViewMaxXMargin | NSViewMinYMargin]; |
179 [audioShareCheckbox_ setButtonType:NSSwitchButton]; | 179 [audioShareCheckbox_ setButtonType:NSSwitchButton]; |
180 audioShareState_ = NSOnState; | 180 audioShareState_ = NSOnState; |
181 [audioShareCheckbox_ | 181 [audioShareCheckbox_ |
182 setTitle:l10n_util::GetNSString(IDS_DESKTOP_MEDIA_PICKER_AUDIO_SHARE)]; | 182 setTitle:l10n_util::GetNSString(IDS_DESKTOP_MEDIA_PICKER_AUDIO_SHARE)]; |
183 [audioShareCheckbox_ sizeToFit]; | 183 [audioShareCheckbox_ sizeToFit]; |
184 [audioShareCheckbox_ setEnabled:NO]; | 184 [audioShareCheckbox_ setEnabled:NO]; |
185 [audioShareCheckbox_ | 185 [audioShareCheckbox_ |
186 setToolTip:l10n_util::GetNSString( | 186 setToolTip:l10n_util::GetNSString( |
187 IDS_DESKTOP_MEDIA_PICKER_AUDIO_SHARE_TOOLTIP_MAC)]; | 187 IDS_DESKTOP_MEDIA_PICKER_AUDIO_SHARE_TOOLTIP_MAC)]; |
188 [content addSubview:audioShareCheckbox_]; | 188 [content addSubview:audioShareCheckbox_]; |
189 origin.y += NSHeight([audioShareCheckbox_ frame]) + kControlSpacing; | 189 origin.y += NSHeight([audioShareCheckbox_ frame]) + kControlSpacing; |
190 } | 190 } |
191 | 191 |
192 // Create the share button. | 192 // Create the share button. |
193 shareButton_ = [self createButtonWithTitle:l10n_util::GetNSString( | 193 shareButton_ = |
194 IDS_DESKTOP_MEDIA_PICKER_SHARE)]; | 194 [self createButtonWithTitle:l10n_util::GetNSString( |
| 195 IDS_DESKTOP_MEDIA_PICKER_SHARE)]; |
195 origin.x = kInitialContentWidth - kFramePadding - | 196 origin.x = kInitialContentWidth - kFramePadding - |
196 (NSWidth([shareButton_ frame]) - kExcessButtonPadding); | 197 (NSWidth([shareButton_ frame]) - kExcessButtonPadding); |
197 [shareButton_ setEnabled:NO]; | 198 [shareButton_ setEnabled:NO]; |
198 [shareButton_ setFrameOrigin:origin]; | 199 [shareButton_ setFrameOrigin:origin]; |
199 [shareButton_ setAutoresizingMask:NSViewMinXMargin | NSViewMinYMargin]; | 200 [shareButton_ setAutoresizingMask:NSViewMinXMargin | NSViewMinYMargin]; |
200 [shareButton_ setTarget:self]; | 201 [shareButton_ setTarget:self]; |
201 [shareButton_ setKeyEquivalent:kKeyEquivalentReturn]; | 202 [shareButton_ setKeyEquivalent:kKeyEquivalentReturn]; |
202 [shareButton_ setAction:@selector(sharePressed:)]; | 203 [shareButton_ setAction:@selector(sharePressed:)]; |
203 [content addSubview:shareButton_]; | 204 [content addSubview:shareButton_]; |
204 | 205 |
205 // Create the cancel button. | 206 // Create the cancel button. |
206 cancelButton_ = | 207 cancelButton_ = |
207 [self createButtonWithTitle:l10n_util::GetNSString(IDS_CANCEL)]; | 208 [self createButtonWithTitle:l10n_util::GetNSString(IDS_CANCEL)]; |
208 origin.x -= kControlSpacing + | 209 origin.x -= kControlSpacing + |
209 (NSWidth([cancelButton_ frame]) - (kExcessButtonPadding * 2)); | 210 (NSWidth([cancelButton_ frame]) - (kExcessButtonPadding * 2)); |
210 [cancelButton_ setFrameOrigin:origin]; | 211 [cancelButton_ setFrameOrigin:origin]; |
211 [cancelButton_ setAutoresizingMask:NSViewMinXMargin | NSViewMinYMargin]; | 212 [cancelButton_ setAutoresizingMask:NSViewMinXMargin | NSViewMinYMargin]; |
212 [cancelButton_ setTarget:self]; | 213 [cancelButton_ setTarget:self]; |
213 [cancelButton_ setKeyEquivalent:kKeyEquivalentEscape]; | 214 [cancelButton_ setKeyEquivalent:kKeyEquivalentEscape]; |
214 [cancelButton_ setAction:@selector(cancelPressed:)]; | 215 [cancelButton_ setAction:@selector(cancelPressed:)]; |
215 [content addSubview:cancelButton_]; | 216 [content addSubview:cancelButton_]; |
216 origin.y += kFramePadding + | 217 origin.y += |
217 (NSHeight([cancelButton_ frame]) - kExcessButtonPadding); | 218 kFramePadding + (NSHeight([cancelButton_ frame]) - kExcessButtonPadding); |
218 | 219 |
219 // Resize window to fit. | 220 // Resize window to fit. |
220 [[[self window] contentView] setAutoresizesSubviews:NO]; | 221 [[[self window] contentView] setAutoresizesSubviews:NO]; |
221 [[self window] setContentSize:NSMakeSize(kInitialContentWidth, origin.y)]; | 222 [[self window] setContentSize:NSMakeSize(kInitialContentWidth, origin.y)]; |
222 [[self window] setContentMinSize: | 223 [[self window] setContentMinSize:NSMakeSize(kMinimumContentWidth, |
223 NSMakeSize(kMinimumContentWidth, kMinimumContentHeight)]; | 224 kMinimumContentHeight)]; |
224 [[[self window] contentView] setAutoresizesSubviews:YES]; | 225 [[[self window] contentView] setAutoresizesSubviews:YES]; |
225 | 226 |
226 // Make sourceBrowser_ get keyboard focus. | 227 // Make sourceBrowser_ get keyboard focus. |
227 [[self window] makeFirstResponder:sourceBrowser_]; | 228 [[self window] makeFirstResponder:sourceBrowser_]; |
228 } | 229 } |
229 | 230 |
230 - (void)showWindow:(id)sender { | 231 - (void)showWindow:(id)sender { |
231 // Signal the media_list to start sending thumbnails. |bridge_| is used as the | 232 // Signal the media_list to start sending thumbnails. |bridge_| is used as the |
232 // observer, and will forward notifications to this object. | 233 // observer, and will forward notifications to this object. |
233 media_list_->SetThumbnailSize(gfx::Size(kThumbnailWidth, kThumbnailHeight)); | 234 media_list_->SetThumbnailSize(gfx::Size(kThumbnailWidth, kThumbnailHeight)); |
(...skipping 16 matching lines...) Expand all Loading... |
250 content::WebContents* tab = content::WebContents::FromRenderFrameHost( | 251 content::WebContents* tab = content::WebContents::FromRenderFrameHost( |
251 content::RenderFrameHost::FromID( | 252 content::RenderFrameHost::FromID( |
252 sourceID.web_contents_id.render_process_id, | 253 sourceID.web_contents_id.render_process_id, |
253 sourceID.web_contents_id.main_render_frame_id)); | 254 sourceID.web_contents_id.main_render_frame_id)); |
254 if (tab) | 255 if (tab) |
255 tab->GetDelegate()->ActivateContents(tab); | 256 tab->GetDelegate()->ActivateContents(tab); |
256 } | 257 } |
257 | 258 |
258 // Notify the |callback_| asynchronously because it may release the | 259 // Notify the |callback_| asynchronously because it may release the |
259 // controller. | 260 // controller. |
260 content::BrowserThread::PostTask( | 261 content::BrowserThread::PostTask(content::BrowserThread::UI, FROM_HERE, |
261 content::BrowserThread::UI, FROM_HERE, | 262 base::Bind(doneCallback_, sourceID)); |
262 base::Bind(doneCallback_, sourceID)); | |
263 doneCallback_.Reset(); | 263 doneCallback_.Reset(); |
264 } | 264 } |
265 | 265 |
266 - (void)sharePressed:(id)sender { | 266 - (void)sharePressed:(id)sender { |
267 NSIndexSet* indexes = [sourceBrowser_ selectionIndexes]; | 267 NSIndexSet* indexes = [sourceBrowser_ selectionIndexes]; |
268 NSUInteger selectedIndex = [indexes firstIndex]; | 268 NSUInteger selectedIndex = [indexes firstIndex]; |
269 DesktopMediaPickerItem* item = | 269 DesktopMediaPickerItem* item = [items_ objectAtIndex:selectedIndex]; |
270 [items_ objectAtIndex:selectedIndex]; | |
271 [self reportResult:[item sourceID]]; | 270 [self reportResult:[item sourceID]]; |
272 [self close]; | 271 [self close]; |
273 } | 272 } |
274 | 273 |
275 - (void)cancelPressed:(id)sender { | 274 - (void)cancelPressed:(id)sender { |
276 [self reportResult:content::DesktopMediaID()]; | 275 [self reportResult:content::DesktopMediaID()]; |
277 [self close]; | 276 [self close]; |
278 } | 277 } |
279 | 278 |
280 - (NSTextField*)createTextFieldWithText:(NSString*)text | 279 - (NSTextField*)createTextFieldWithText:(NSString*)text |
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
314 NSWindow* window = [self window]; | 313 NSWindow* window = [self window]; |
315 [[window parentWindow] removeChildWindow:window]; | 314 [[window parentWindow] removeChildWindow:window]; |
316 } | 315 } |
317 | 316 |
318 #pragma mark IKImageBrowserDataSource | 317 #pragma mark IKImageBrowserDataSource |
319 | 318 |
320 - (NSUInteger)numberOfItemsInImageBrowser:(IKImageBrowserView*)browser { | 319 - (NSUInteger)numberOfItemsInImageBrowser:(IKImageBrowserView*)browser { |
321 return [items_ count]; | 320 return [items_ count]; |
322 } | 321 } |
323 | 322 |
324 - (id)imageBrowser:(IKImageBrowserView *)browser | 323 - (id)imageBrowser:(IKImageBrowserView*)browser itemAtIndex:(NSUInteger)index { |
325 itemAtIndex:(NSUInteger)index { | |
326 return [items_ objectAtIndex:index]; | 324 return [items_ objectAtIndex:index]; |
327 } | 325 } |
328 | 326 |
329 #pragma mark IKImageBrowserDelegate | 327 #pragma mark IKImageBrowserDelegate |
330 | 328 |
331 - (void)imageBrowser:(IKImageBrowserView *)browser | 329 - (void)imageBrowser:(IKImageBrowserView*)browser |
332 cellWasDoubleClickedAtIndex:(NSUInteger)index { | 330 cellWasDoubleClickedAtIndex:(NSUInteger)index { |
333 DesktopMediaPickerItem* item = [items_ objectAtIndex:index]; | 331 DesktopMediaPickerItem* item = [items_ objectAtIndex:index]; |
334 [self reportResult:[item sourceID]]; | 332 [self reportResult:[item sourceID]]; |
335 [self close]; | 333 [self close]; |
336 } | 334 } |
337 | 335 |
338 - (void)imageBrowserSelectionDidChange:(IKImageBrowserView*)browser { | 336 - (void)imageBrowserSelectionDidChange:(IKImageBrowserView*)browser { |
339 NSIndexSet* indexes = [sourceBrowser_ selectionIndexes]; | 337 NSIndexSet* indexes = [sourceBrowser_ selectionIndexes]; |
340 | 338 |
341 // Enable or disable the OK button based on whether we have a selection. | 339 // Enable or disable the OK button based on whether we have a selection. |
342 [shareButton_ setEnabled:([indexes count] > 0)]; | 340 [shareButton_ setEnabled:([indexes count] > 0)]; |
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
378 } | 376 } |
379 [audioShareCheckbox_ setToolTip:@""]; | 377 [audioShareCheckbox_ setToolTip:@""]; |
380 break; | 378 break; |
381 case content::DesktopMediaID::TYPE_NONE: | 379 case content::DesktopMediaID::TYPE_NONE: |
382 NOTREACHED(); | 380 NOTREACHED(); |
383 } | 381 } |
384 } | 382 } |
385 | 383 |
386 #pragma mark DesktopMediaPickerObserver | 384 #pragma mark DesktopMediaPickerObserver |
387 | 385 |
388 - (void)sourceAddedAtIndex:(int)index { | 386 - (void)sourceAddedForList:(DesktopMediaList*)list AtIndex:(int)index { |
389 const DesktopMediaList::Source& source = media_list_->GetSource(index); | 387 const DesktopMediaList::Source& source = media_list_->GetSource(index); |
390 NSString* imageTitle = base::SysUTF16ToNSString(source.name); | 388 NSString* imageTitle = base::SysUTF16ToNSString(source.name); |
391 base::scoped_nsobject<DesktopMediaPickerItem> item( | 389 base::scoped_nsobject<DesktopMediaPickerItem> item( |
392 [[DesktopMediaPickerItem alloc] initWithSourceId:source.id | 390 [[DesktopMediaPickerItem alloc] initWithSourceId:source.id |
393 imageUID:++lastImageUID_ | 391 imageUID:++lastImageUID_ |
394 imageTitle:imageTitle]); | 392 imageTitle:imageTitle]); |
395 [items_ insertObject:item atIndex:index]; | 393 [items_ insertObject:item atIndex:index]; |
396 [sourceBrowser_ reloadData]; | 394 [sourceBrowser_ reloadData]; |
397 | 395 |
398 NSString* autoselectSource = base::SysUTF8ToNSString( | 396 NSString* autoselectSource = base::SysUTF8ToNSString( |
399 base::CommandLine::ForCurrentProcess()->GetSwitchValueASCII( | 397 base::CommandLine::ForCurrentProcess()->GetSwitchValueASCII( |
400 switches::kAutoSelectDesktopCaptureSource)); | 398 switches::kAutoSelectDesktopCaptureSource)); |
401 | 399 |
402 if ([autoselectSource isEqualToString:imageTitle]) { | 400 if ([autoselectSource isEqualToString:imageTitle]) { |
403 [self reportResult:[item sourceID]]; | 401 [self reportResult:[item sourceID]]; |
404 [self close]; | 402 [self close]; |
405 } | 403 } |
406 } | 404 } |
407 | 405 |
408 - (void)sourceRemovedAtIndex:(int)index { | 406 - (void)sourceRemovedForList:(DesktopMediaList*)list AtIndex:(int)index { |
409 if ([[sourceBrowser_ selectionIndexes] containsIndex:index]) { | 407 if ([[sourceBrowser_ selectionIndexes] containsIndex:index]) { |
410 // Selected item was removed. Clear selection. | 408 // Selected item was removed. Clear selection. |
411 [sourceBrowser_ setSelectionIndexes:[NSIndexSet indexSet] | 409 [sourceBrowser_ setSelectionIndexes:[NSIndexSet indexSet] |
412 byExtendingSelection:FALSE]; | 410 byExtendingSelection:FALSE]; |
413 } | 411 } |
414 [items_ removeObjectAtIndex:index]; | 412 [items_ removeObjectAtIndex:index]; |
415 [sourceBrowser_ reloadData]; | 413 [sourceBrowser_ reloadData]; |
416 } | 414 } |
417 | 415 |
418 - (void)sourceMovedFrom:(int)oldIndex to:(int)newIndex { | 416 - (void)sourceMovedForList:(DesktopMediaList*)list |
| 417 From:(int)oldIndex |
| 418 to:(int)newIndex { |
419 base::scoped_nsobject<DesktopMediaPickerItem> item( | 419 base::scoped_nsobject<DesktopMediaPickerItem> item( |
420 [[items_ objectAtIndex:oldIndex] retain]); | 420 [[items_ objectAtIndex:oldIndex] retain]); |
421 [items_ removeObjectAtIndex:oldIndex]; | 421 [items_ removeObjectAtIndex:oldIndex]; |
422 [items_ insertObject:item atIndex:newIndex]; | 422 [items_ insertObject:item atIndex:newIndex]; |
423 [sourceBrowser_ reloadData]; | 423 [sourceBrowser_ reloadData]; |
424 } | 424 } |
425 | 425 |
426 - (void)sourceNameChangedAtIndex:(int)index { | 426 - (void)sourceNameChangedForList:(DesktopMediaList*)list AtIndex:(int)index { |
427 DesktopMediaPickerItem* item = [items_ objectAtIndex:index]; | 427 DesktopMediaPickerItem* item = [items_ objectAtIndex:index]; |
428 const DesktopMediaList::Source& source = media_list_->GetSource(index); | 428 const DesktopMediaList::Source& source = media_list_->GetSource(index); |
429 [item setImageTitle:base::SysUTF16ToNSString(source.name)]; | 429 [item setImageTitle:base::SysUTF16ToNSString(source.name)]; |
430 [sourceBrowser_ reloadData]; | 430 [sourceBrowser_ reloadData]; |
431 } | 431 } |
432 | 432 |
433 - (void)sourceThumbnailChangedAtIndex:(int)index { | 433 - (void)sourceThumbnailChangedForList:(DesktopMediaList*)list |
| 434 AtIndex:(int)index { |
434 const DesktopMediaList::Source& source = media_list_->GetSource(index); | 435 const DesktopMediaList::Source& source = media_list_->GetSource(index); |
435 NSImage* image = gfx::NSImageFromImageSkia(source.thumbnail); | 436 NSImage* image = gfx::NSImageFromImageSkia(source.thumbnail); |
436 | 437 |
437 DesktopMediaPickerItem* item = [items_ objectAtIndex:index]; | 438 DesktopMediaPickerItem* item = [items_ objectAtIndex:index]; |
438 [item setImageRepresentation:image]; | 439 [item setImageRepresentation:image]; |
439 [sourceBrowser_ reloadData]; | 440 [sourceBrowser_ reloadData]; |
440 } | 441 } |
441 | 442 |
442 @end // @interface DesktopMediaPickerController | 443 @end // @interface DesktopMediaPickerController |
OLD | NEW |