Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(534)

Side by Side Diff: media/cast/transport/transport_video_sender.h

Issue 314593002: [Cast] Cleanup: Remove TransportXXXXXSender, an unnecessary layer of indirection. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix CastTransportHostFilterTest.SimpleMessages. Created 6 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
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
3 // found in the LICENSE file.
4
5 #ifndef MEDIA_CAST_TRANSPORT_TRANSPORT_VIDEO_SENDER_H_
6 #define MEDIA_CAST_TRANSPORT_TRANSPORT_VIDEO_SENDER_H_
7
8 #include "base/callback.h"
9 #include "base/memory/ref_counted.h"
10 #include "base/memory/scoped_ptr.h"
11 #include "base/threading/non_thread_safe.h"
12 #include "base/time/tick_clock.h"
13 #include "media/cast/transport/cast_transport_config.h"
14 #include "media/cast/transport/rtp_sender/rtp_sender.h"
15 #include "media/cast/transport/utility/transport_encryption_handler.h"
16
17 namespace media {
18 class VideoFrame;
19
20 namespace cast {
21
22 namespace transport {
23 class PacedSender;
24
25 // Not thread safe. Only called from the main cast transport thread.
26 // This class owns all objects related to sending coded video, objects that
27 // encrypt, create RTP packets and send to network.
28 class TransportVideoSender : public base::NonThreadSafe {
29 public:
30 TransportVideoSender(
31 const CastTransportVideoConfig& config,
32 base::TickClock* clock,
33 const scoped_refptr<base::SingleThreadTaskRunner>& transport_task_runner,
34 PacedSender* const paced_packet_sender);
35
36 virtual ~TransportVideoSender();
37
38 // Handles the encoded video frames to be processed.
39 // Frames will be encrypted, packetized and transmitted to the network.
40 void SendFrame(const EncodedFrame& video_frame);
41
42 // Retransmision request.
43 void ResendPackets(
44 const MissingFramesAndPacketsMap& missing_frames_and_packets);
45
46 size_t send_packet_count() const { return rtp_sender_.send_packet_count(); }
47 size_t send_octet_count() const { return rtp_sender_.send_octet_count(); }
48 uint32 ssrc() const { return rtp_sender_.ssrc(); }
49 bool initialized() const { return initialized_; }
50
51 private:
52 // Caller must allocate the destination |encrypted_video_frame| the data
53 // member will be resized to hold the encrypted size.
54 bool EncryptVideoFrame(const EncodedFrame& encoded_frame,
55 EncodedFrame* encrypted_video_frame);
56
57 const base::TimeDelta rtp_max_delay_;
58 TransportEncryptionHandler encryptor_;
59 RtpSender rtp_sender_;
60 bool initialized_;
61
62 DISALLOW_IMPLICIT_CONSTRUCTORS(TransportVideoSender);
63 };
64
65 } // namespace transport
66 } // namespace cast
67 } // namespace media
68
69 #endif // MEDIA_CAST_TRANSPORT_TRANSPORT_VIDEO_SENDER_H_
OLDNEW
« no previous file with comments | « media/cast/transport/transport_audio_sender.cc ('k') | media/cast/transport/transport_video_sender.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698