Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 CHROMECAST_PUBLIC_CAST_MEDIA_SHLIB_H_ | 5 #ifndef CHROMECAST_PUBLIC_CAST_MEDIA_SHLIB_H_ |
| 6 #define CHROMECAST_PUBLIC_CAST_MEDIA_SHLIB_H_ | 6 #define CHROMECAST_PUBLIC_CAST_MEDIA_SHLIB_H_ |
| 7 | 7 |
| 8 #include <string> | 8 #include <string> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| 11 #include "chromecast_export.h" | 11 #include "chromecast_export.h" |
| 12 | 12 |
| 13 namespace chromecast { | 13 namespace chromecast { |
| 14 namespace media { | 14 namespace media { |
| 15 | 15 |
| 16 class MediaPipelineBackend; | |
| 17 struct MediaPipelineDeviceParams; | |
| 16 class VideoPlane; | 18 class VideoPlane; |
| 17 | 19 |
| 18 // Provides access to platform-specific media systems and hardware resources. | 20 // Provides access to platform-specific media systems and hardware resources. |
| 19 // In cast_shell, all usage is from the browser process. An implementation is | 21 // In cast_shell, all usage is from the browser process. An implementation is |
| 20 // assumed to be in an uninitialized state initially. When uninitialized, no | 22 // assumed to be in an uninitialized state initially. When uninitialized, no |
| 21 // API calls will be made except for Initialize, which brings the implementation | 23 // API calls will be made except for Initialize, which brings the implementation |
| 22 // into an initialized state. A call to Finalize returns the implementation to | 24 // into an initialized state. A call to Finalize returns the implementation to |
| 23 // its uninitialized state. The implementation must support multiple | 25 // its uninitialized state. The implementation must support multiple |
| 24 // transitions between these states, to support resource grant/revoke events and | 26 // transitions between these states, to support resource grant/revoke events and |
| 25 // also to allow multiple unit tests to bring up the media systems in isolation | 27 // also to allow multiple unit tests to bring up the media systems in isolation |
| 26 // from other tests. | 28 // from other tests. |
| 27 class CHROMECAST_EXPORT CastMediaShlib { | 29 class CHROMECAST_EXPORT CastMediaShlib { |
| 28 public: | 30 public: |
| 29 // Initializes platform-specific media systems. Only called when in an | 31 // Initializes platform-specific media systems. Only called when in an |
| 30 // uninitialized state. | 32 // uninitialized state. |
| 31 static void Initialize(const std::vector<std::string>& argv); | 33 static void Initialize(const std::vector<std::string>& argv); |
| 32 | 34 |
| 33 // Tears down platform-specific media systems and returns to the uninitialized | 35 // Tears down platform-specific media systems and returns to the uninitialized |
| 34 // state. The implementation must release all media-related hardware | 36 // state. The implementation must release all media-related hardware |
| 35 // resources. | 37 // resources. |
| 36 static void Finalize(); | 38 static void Finalize(); |
| 37 | 39 |
| 38 // Gets the VideoPlane instance for managing the hardware video plane. | 40 // Gets the VideoPlane instance for managing the hardware video plane. |
| 39 // While an implementation is in an initialized state, this function may be | 41 // While an implementation is in an initialized state, this function may be |
| 40 // called at any time. The VideoPlane object must be destroyed in Finalize. | 42 // called at any time. The VideoPlane object must be destroyed in Finalize. |
| 41 static VideoPlane* GetVideoPlane(); | 43 static VideoPlane* GetVideoPlane(); |
|
alokp
2015/08/10 20:30:25
Please document ownership for the returned VideoPl
| |
| 44 | |
| 45 // Creates a factory object for a media pipeline backend. Called in the | |
| 46 // browser process, any number of times (once per media pipeline). Each call | |
| 47 // must instantiate a new factory object | |
| 48 static MediaPipelineBackend* CreateMediaPipelineBackend( | |
|
alokp
2015/08/10 20:30:25
Who owns the returned MediaPipelineBackend? I am a
| |
| 49 const MediaPipelineDeviceParams& params); | |
| 42 }; | 50 }; |
| 43 | 51 |
| 44 } // namespace media | 52 } // namespace media |
| 45 } // namespace chromecast | 53 } // namespace chromecast |
| 46 | 54 |
| 47 #endif // CHROMECAST_PUBLIC_CAST_MEDIA_SHLIB_H_ | 55 #endif // CHROMECAST_PUBLIC_CAST_MEDIA_SHLIB_H_ |
| OLD | NEW |