| // Copyright 2013 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef CHROME_BROWSER_MEDIA_DESKTOP_MEDIA_LIST_H_ |
| #define CHROME_BROWSER_MEDIA_DESKTOP_MEDIA_LIST_H_ |
| |
| #include "base/basictypes.h" |
| #include "base/time/time.h" |
| #include "content/public/browser/desktop_media_id.h" |
| #include "ui/gfx/image/image_skia.h" |
| |
| class DesktopMediaListObserver; |
| |
| // DesktopMediaList provides the list of desktop media source (screens, windows, |
| // tabs), and their thumbnails, to the desktop media picker dialog. It |
| // transparently updates the list in the background, and notifies the desktop |
| // media picker when something changes. |
| class DesktopMediaList { |
| public: |
| // Struct used to represent each entry in the list. |
| struct Source { |
| // Id of the source. |
| content::DesktopMediaID id; |
| |
| // Name of the source that should be shown to the user. |
| base::string16 name; |
| |
| // The thumbnail for the source. |
| gfx::ImageSkia thumbnail; |
| }; |
| |
| virtual ~DesktopMediaList() {} |
| |
| // Sets time interval between updates. By default list of sources and their |
| // thumbnail are updated once per second. If called after StartUpdating() then |
| // it will take effect only after the next update. |
| virtual void SetUpdatePeriod(base::TimeDelta period) = 0; |
| |
| // Sets size to which the thumbnails should be scaled. If called after |
| // StartUpdating() then some thumbnails may be still scaled to the old size |
| // until they are updated. |
| virtual void SetThumbnailSize(const gfx::Size& thumbnail_size) = 0; |
| |
| // Sets ID of the hosting desktop picker dialog. The window with this ID will |
| // be filtered out from the list of sources. |
| virtual void SetViewDialogWindowId(content::DesktopMediaID::Id dialog_id) = 0; |
| |
| // Starts updating the model. The model is initially empty, so OnSourceAdded() |
| // notifications will be generated for each existing source as it is |
| // enumerated. After the initial enumeration the model will be refreshed based |
| // on the update period, and notifications generated only for changes in the |
| // model. |
| virtual void StartUpdating(DesktopMediaListObserver* observer) = 0; |
| |
| virtual int GetSourceCount() const = 0; |
| virtual const Source& GetSource(int index) const = 0; |
| }; |
| |
| #endif // CHROME_BROWSER_MEDIA_DESKTOP_MEDIA_LIST_H_ |