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

Side by Side Diff: media/base/android/media_codec_video_decoder.h

Issue 1242913004: MediaCodecPlayer implementation (stage 3 - browser seek and surface change) (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@mtplayer-seek
Patch Set: Fixed the check whether surface is empty, faster stopping after SyncStop, cleanup Created 5 years, 5 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
OLDNEW
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 MEDIA_BASE_ANDROID_MEDIA_CODEC_VIDEO_DECODER_H_ 5 #ifndef MEDIA_BASE_ANDROID_MEDIA_CODEC_VIDEO_DECODER_H_
6 #define MEDIA_BASE_ANDROID_MEDIA_CODEC_VIDEO_DECODER_H_ 6 #define MEDIA_BASE_ANDROID_MEDIA_CODEC_VIDEO_DECODER_H_
7 7
8 #include <set> 8 #include <set>
9 #include "media/base/android/media_codec_decoder.h" 9 #include "media/base/android/media_codec_decoder.h"
10 #include "ui/gfx/geometry/size.h" 10 #include "ui/gfx/geometry/size.h"
(...skipping 26 matching lines...) Expand all
37 const base::Closure& codec_created_cb); 37 const base::Closure& codec_created_cb);
38 ~MediaCodecVideoDecoder() override; 38 ~MediaCodecVideoDecoder() override;
39 39
40 const char* class_name() const override; 40 const char* class_name() const override;
41 41
42 bool HasStream() const override; 42 bool HasStream() const override;
43 void SetDemuxerConfigs(const DemuxerConfigs& configs) override; 43 void SetDemuxerConfigs(const DemuxerConfigs& configs) override;
44 void ReleaseDecoderResources() override; 44 void ReleaseDecoderResources() override;
45 45
46 // Stores the video surface to use with upcoming Configure() 46 // Stores the video surface to use with upcoming Configure()
47 void SetPendingSurface(gfx::ScopedJavaSurface surface); 47 void SetVideoSurface(gfx::ScopedJavaSurface surface);
48 48
49 // Returns true if there is a video surface to use. 49 // Returns true if there is a video surface to use.
50 bool HasPendingSurface() const; 50 bool HasVideoSurface() const;
51 51
52 protected: 52 protected:
53 bool IsCodecReconfigureNeeded(const DemuxerConfigs& curr, 53 bool IsCodecReconfigureNeeded(const DemuxerConfigs& curr,
54 const DemuxerConfigs& next) const override; 54 const DemuxerConfigs& next) const override;
55 ConfigStatus ConfigureInternal() override; 55 ConfigStatus ConfigureInternal() override;
56 void SynchronizePTSWithTime(base::TimeDelta current_time) override; 56 void SynchronizePTSWithTime(base::TimeDelta current_time) override;
57 void OnOutputFormatChanged() override; 57 void OnOutputFormatChanged() override;
58 void Render(int buffer_index, 58 void Render(int buffer_index,
59 size_t size, 59 size_t size,
60 bool render_output, 60 bool render_output,
61 base::TimeDelta pts, 61 base::TimeDelta pts,
62 bool eos_encountered) override; 62 bool eos_encountered) override;
63 63
64 int NumDelayedRenderTasks() const override; 64 int NumDelayedRenderTasks() const override;
65 void ReleaseDelayedBuffers() override; 65 void ReleaseDelayedBuffers() override;
66 void ClearDelayedBuffers() override;
66 67
67 #ifndef NDEBUG 68 #ifndef NDEBUG
68 void VerifyUnitIsKeyFrame(const AccessUnit* unit) const override; 69 void VerifyUnitIsKeyFrame(const AccessUnit* unit) const override;
69 #endif 70 #endif
70 71
71 private: 72 private:
72 // A helper method that releases output buffers and does 73 // A helper method that releases output buffers and does
73 // post-release checks. Might be called by Render() or posted 74 // post-release checks. Might be called by Render() or posted
74 // for later execution. 75 // for later execution.
75 void ReleaseOutputBuffer(int buffer_index, 76 void ReleaseOutputBuffer(int buffer_index,
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after
107 108
108 // Mantain the last seen PTS for stand-alone EOS. 109 // Mantain the last seen PTS for stand-alone EOS.
109 base::TimeDelta last_seen_pts_; 110 base::TimeDelta last_seen_pts_;
110 111
111 DISALLOW_COPY_AND_ASSIGN(MediaCodecVideoDecoder); 112 DISALLOW_COPY_AND_ASSIGN(MediaCodecVideoDecoder);
112 }; 113 };
113 114
114 } // namespace media 115 } // namespace media
115 116
116 #endif // MEDIA_BASE_ANDROID_MEDIA_CODEC_VIDEO_DECODER_H_ 117 #endif // MEDIA_BASE_ANDROID_MEDIA_CODEC_VIDEO_DECODER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698