| 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 CONTENT_RENDERER_MEDIA_MEDIA_RECORDER_HANDLER_H_ | 5 #ifndef CONTENT_RENDERER_MEDIA_MEDIA_RECORDER_HANDLER_H_ |
| 6 #define CONTENT_RENDERER_MEDIA_MEDIA_RECORDER_HANDLER_H_ | 6 #define CONTENT_RENDERER_MEDIA_MEDIA_RECORDER_HANDLER_H_ |
| 7 | 7 |
| 8 #include <memory> | 8 #include <memory> |
| 9 | 9 |
| 10 #include "base/compiler_specific.h" | 10 #include "base/compiler_specific.h" |
| (...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 84 | 84 |
| 85 // Bound to the main render thread. | 85 // Bound to the main render thread. |
| 86 base::ThreadChecker main_render_thread_checker_; | 86 base::ThreadChecker main_render_thread_checker_; |
| 87 | 87 |
| 88 // Sanitized video and audio bitrate settings passed on initialize(). | 88 // Sanitized video and audio bitrate settings passed on initialize(). |
| 89 int32_t video_bits_per_second_; | 89 int32_t video_bits_per_second_; |
| 90 int32_t audio_bits_per_second_; | 90 int32_t audio_bits_per_second_; |
| 91 | 91 |
| 92 // Force using VP9 for video encoding, otherwise VP8 will be used by default. | 92 // Force using VP9 for video encoding, otherwise VP8 will be used by default. |
| 93 bool use_vp9_; | 93 bool use_vp9_; |
| 94 bool use_h264_; // TODO(mcasas): this is a makeshift solution. |
| 94 | 95 |
| 95 // |client_| has no notion of time, thus may configure us via start(timeslice) | 96 // |client_| has no notion of time, thus may configure us via start(timeslice) |
| 96 // to notify it after a certain |timeslice_| has passed. We use a moving | 97 // to notify it after a certain |timeslice_| has passed. We use a moving |
| 97 // |slice_origin_timestamp_| to track those time chunks. | 98 // |slice_origin_timestamp_| to track those time chunks. |
| 98 base::TimeDelta timeslice_; | 99 base::TimeDelta timeslice_; |
| 99 base::TimeTicks slice_origin_timestamp_; | 100 base::TimeTicks slice_origin_timestamp_; |
| 100 | 101 |
| 101 bool recording_; | 102 bool recording_; |
| 102 blink::WebMediaStream media_stream_; // The MediaStream being recorded. | 103 blink::WebMediaStream media_stream_; // The MediaStream being recorded. |
| 103 | 104 |
| 104 // |client_| is a weak pointer, and is valid for the lifetime of this object. | 105 // |client_| is a weak pointer, and is valid for the lifetime of this object. |
| 105 blink::WebMediaRecorderHandlerClient* client_; | 106 blink::WebMediaRecorderHandlerClient* client_; |
| 106 | 107 |
| 107 ScopedVector<VideoTrackRecorder> video_recorders_; | 108 ScopedVector<VideoTrackRecorder> video_recorders_; |
| 108 ScopedVector<AudioTrackRecorder> audio_recorders_; | 109 ScopedVector<AudioTrackRecorder> audio_recorders_; |
| 109 | 110 |
| 110 // Worker class doing the actual Webm Muxing work. | 111 // Worker class doing the actual Webm Muxing work. |
| 111 std::unique_ptr<media::WebmMuxer> webm_muxer_; | 112 std::unique_ptr<media::WebmMuxer> webm_muxer_; |
| 112 | 113 |
| 113 base::WeakPtrFactory<MediaRecorderHandler> weak_factory_; | 114 base::WeakPtrFactory<MediaRecorderHandler> weak_factory_; |
| 114 | 115 |
| 115 DISALLOW_COPY_AND_ASSIGN(MediaRecorderHandler); | 116 DISALLOW_COPY_AND_ASSIGN(MediaRecorderHandler); |
| 116 }; | 117 }; |
| 117 | 118 |
| 118 } // namespace content | 119 } // namespace content |
| 119 #endif // CONTENT_RENDERER_MEDIA_MEDIA_RECORDER_HANDLER_H_ | 120 #endif // CONTENT_RENDERER_MEDIA_MEDIA_RECORDER_HANDLER_H_ |
| OLD | NEW |