OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 MEDIA_MOJO_SERVICES_MOJO_MEDIA_CLIENT_H_ | 5 #ifndef MEDIA_MOJO_SERVICES_MOJO_MEDIA_CLIENT_H_ |
6 #define MEDIA_MOJO_SERVICES_MOJO_MEDIA_CLIENT_H_ | 6 #define MEDIA_MOJO_SERVICES_MOJO_MEDIA_CLIENT_H_ |
7 | 7 |
8 #include <memory> | 8 #include <memory> |
9 | 9 |
10 #include "media/base/audio_decoder.h" | 10 #include "media/base/audio_decoder.h" |
11 #include "media/base/audio_renderer_sink.h" | 11 #include "media/base/audio_renderer_sink.h" |
12 #include "media/base/cdm_factory.h" | 12 #include "media/base/cdm_factory.h" |
13 #include "media/base/media_log.h" | 13 #include "media/base/media_log.h" |
14 #include "media/base/renderer_factory.h" | 14 #include "media/base/renderer_factory.h" |
15 #include "media/base/video_renderer_sink.h" | 15 #include "media/base/video_renderer_sink.h" |
16 | 16 |
17 namespace base { | 17 namespace base { |
18 class SingleThreadTaskRunner; | 18 class SingleThreadTaskRunner; |
19 } | 19 } |
20 | 20 |
21 namespace mojo { | |
22 namespace shell { | 21 namespace shell { |
23 namespace mojom { | 22 namespace mojom { |
24 class InterfaceProvider; | 23 class InterfaceProvider; |
25 } | 24 } |
26 } | 25 } |
27 } | |
28 | 26 |
29 namespace media { | 27 namespace media { |
30 | 28 |
31 class MojoMediaClient { | 29 class MojoMediaClient { |
32 public: | 30 public: |
33 virtual ~MojoMediaClient(); | 31 virtual ~MojoMediaClient(); |
34 | 32 |
35 // Called exactly once before any other method. | 33 // Called exactly once before any other method. |
36 virtual void Initialize(); | 34 virtual void Initialize(); |
37 | 35 |
(...skipping 10 matching lines...) Expand all Loading... |
48 // The output sink used for rendering audio or video respectively. They will | 46 // The output sink used for rendering audio or video respectively. They will |
49 // be used in the CreateRenderer() call on the RendererFactory returned by | 47 // be used in the CreateRenderer() call on the RendererFactory returned by |
50 // CreateRendererFactory(). May be null if the RendererFactory doesn't need an | 48 // CreateRendererFactory(). May be null if the RendererFactory doesn't need an |
51 // audio or video sink. If not null, the sink must be owned by the client. | 49 // audio or video sink. If not null, the sink must be owned by the client. |
52 virtual AudioRendererSink* CreateAudioRendererSink(); | 50 virtual AudioRendererSink* CreateAudioRendererSink(); |
53 virtual VideoRendererSink* CreateVideoRendererSink( | 51 virtual VideoRendererSink* CreateVideoRendererSink( |
54 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner); | 52 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner); |
55 | 53 |
56 // Returns the CdmFactory to be used by MojoCdmService. | 54 // Returns the CdmFactory to be used by MojoCdmService. |
57 virtual std::unique_ptr<CdmFactory> CreateCdmFactory( | 55 virtual std::unique_ptr<CdmFactory> CreateCdmFactory( |
58 mojo::shell::mojom::InterfaceProvider* interface_provider); | 56 shell::mojom::InterfaceProvider* interface_provider); |
59 | 57 |
60 protected: | 58 protected: |
61 MojoMediaClient(); | 59 MojoMediaClient(); |
62 }; | 60 }; |
63 | 61 |
64 } // namespace media | 62 } // namespace media |
65 | 63 |
66 #endif // MEDIA_MOJO_SERVICES_MOJO_MEDIA_CLIENT_H_ | 64 #endif // MEDIA_MOJO_SERVICES_MOJO_MEDIA_CLIENT_H_ |
OLD | NEW |