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 // This is the main interface for the cast sender. All configuration are done | 5 // This is the main interface for the cast sender. All configuration are done |
6 // at creation. | 6 // at creation. |
7 // | 7 // |
8 // The FrameInput and PacketReciever interfaces should normally be accessed from | 8 // The FrameInput and PacketReciever interfaces should normally be accessed from |
9 // the IO thread. However they are allowed to be called from any thread. | 9 // the IO thread. However they are allowed to be called from any thread. |
10 | 10 |
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
44 // done with |audio_bus|; it does not mean that the encoded data has been | 44 // done with |audio_bus|; it does not mean that the encoded data has been |
45 // sent out. | 45 // sent out. |
46 virtual void InsertAudio(const AudioBus* audio_bus, | 46 virtual void InsertAudio(const AudioBus* audio_bus, |
47 const base::TimeTicks& recorded_time, | 47 const base::TimeTicks& recorded_time, |
48 const base::Closure& done_callback) = 0; | 48 const base::Closure& done_callback) = 0; |
49 | 49 |
50 // The audio_frame must be valid until the callback is called. | 50 // The audio_frame must be valid until the callback is called. |
51 // The callback is called from the main cast thread as soon as | 51 // The callback is called from the main cast thread as soon as |
52 // the cast sender is done with the frame; it does not mean that the encoded | 52 // the cast sender is done with the frame; it does not mean that the encoded |
53 // frame has been sent out. | 53 // frame has been sent out. |
54 virtual void InsertCodedAudioFrame(const EncodedAudioFrame* audio_frame, | 54 virtual void InsertCodedAudioFrame( |
55 const base::TimeTicks& recorded_time, | 55 const transport::EncodedAudioFrame* audio_frame, |
56 const base::Closure callback) = 0; | 56 const base::TimeTicks& recorded_time, |
| 57 const base::Closure callback) = 0; |
57 | 58 |
58 protected: | 59 protected: |
59 virtual ~FrameInput() {} | 60 virtual ~FrameInput() {} |
60 | 61 |
61 private: | 62 private: |
62 friend class base::RefCountedThreadSafe<FrameInput>; | 63 friend class base::RefCountedThreadSafe<FrameInput>; |
63 }; | 64 }; |
64 | 65 |
65 // This Class is thread safe. | 66 // This Class is thread safe. |
66 // The provided PacketSender object will always be called form the main cast | 67 // The provided PacketSender object will always be called form the main cast |
(...skipping 10 matching lines...) Expand all Loading... |
77 | 78 |
78 virtual ~CastSender() {} | 79 virtual ~CastSender() {} |
79 | 80 |
80 // All audio and video frames for the session should be inserted to this | 81 // All audio and video frames for the session should be inserted to this |
81 // object. | 82 // object. |
82 // Can be called from any thread. | 83 // Can be called from any thread. |
83 virtual scoped_refptr<FrameInput> frame_input() = 0; | 84 virtual scoped_refptr<FrameInput> frame_input() = 0; |
84 | 85 |
85 // All RTCP packets for the session should be inserted to this object. | 86 // All RTCP packets for the session should be inserted to this object. |
86 // Can be called from any thread. | 87 // Can be called from any thread. |
87 virtual scoped_refptr<PacketReceiver> packet_receiver() = 0; | 88 virtual scoped_refptr<transport::PacketReceiver> packet_receiver() = 0; |
88 }; | 89 }; |
89 | 90 |
90 } // namespace cast | 91 } // namespace cast |
91 } // namespace media | 92 } // namespace media |
92 | 93 |
93 #endif // MEDIA_CAST_CAST_SENDER_H_ | 94 #endif // MEDIA_CAST_CAST_SENDER_H_ |
OLD | NEW |