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

Unified Diff: media/base/android/media_codec_video_decoder.h

Issue 1128383003: Implementation of MediaCodecPlayer stage 1 (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Removed unused media_codec_player_state.h and .cc Created 5 years, 7 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 side-by-side diff with in-line comments
Download patch
Index: media/base/android/media_codec_video_decoder.h
diff --git a/media/base/android/media_codec_video_decoder.h b/media/base/android/media_codec_video_decoder.h
new file mode 100644
index 0000000000000000000000000000000000000000..655b1de82effd3963512c25babdc70676a161f89
--- /dev/null
+++ b/media/base/android/media_codec_video_decoder.h
@@ -0,0 +1,82 @@
+// Copyright 2015 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef MEDIA_BASE_ANDROID_MEDIA_CODEC_VIDEO_DECODER_H_
+#define MEDIA_BASE_ANDROID_MEDIA_CODEC_VIDEO_DECODER_H_
+
+#include <set>
+#include "media/base/android/media_codec_decoder.h"
+#include "ui/gl/android/scoped_java_surface.h"
+
+namespace media {
+
+// Video decoder for MediaCodecPlayer
+class MediaCodecVideoDecoder : public MediaCodecDecoder {
+ public:
+ MediaCodecVideoDecoder(
+ const scoped_refptr<base::SingleThreadTaskRunner>& media_runner,
+ const scoped_refptr<base::SingleThreadTaskRunner>& ui_runner,
+ const base::Closure& request_data_cb,
+ const base::Closure& starvation_cb,
+ const base::Closure& stop_done_cb,
+ const base::Closure& error_cb,
+ const base::Closure& request_resources_cb);
+ ~MediaCodecVideoDecoder() override;
+
+ const char * class_name() const override { return "VideoDecoder"; }
+
+ bool HasStream() const override;
+ void ReleaseDecoderResources() override;
+
+ // Stores the video surface to use with upcoming Configure()
+ void SetPendingSurface(gfx::ScopedJavaSurface surface);
+
+ // Returns true if there is a video surface to use.
+ bool HasPendingSurface() const;
+
+ // Return the fideo frame dimensions.
+ int GetVideoWidth() const;
+ int GetVideoHeight() const;
+
+ protected:
+ bool IsCodecReconfigureNeeded(const DemuxerConfigs& curr,
+ const DemuxerConfigs& next) const override;
+ ConfigStatus ConfigureInternal() override;
+ void SynchronizePTSWithTime(base::TimeDelta current_time) override;
+ void Render(int buffer_index, size_t size, bool render_output,
+ base::TimeDelta pts, bool eos_encountered) override;
+
+ int NumDelayedRenderTasks() const override;
+ void ReleaseDelayedBuffers() override;
+
+ private:
+ // A helper method that releases output buffers and does
+ // post-release checks. Might be called by Render() or posted
+ // for later execution.
+ void ReleaseOutputBuffer(int buffer_index, bool render,
+ bool eos_encountered);
+
+ // Data.
+
+ // Video surface that we render to.
+ gfx::ScopedJavaSurface surface_;
+
+ // Inform the caller that the MediaCodec is created.
+ base::Closure request_resources_cb_;
+
+ std::set<int> delayed_buffers_;
+
+ // Associate presentation timestamps with time
+ base::TimeTicks start_time_ticks_;
+ base::TimeDelta start_pts_;
+
+ // Mantain last seen PTS for stand-alone EOS
+ base::TimeDelta last_seen_pts_;
+
+ DISALLOW_COPY_AND_ASSIGN(MediaCodecVideoDecoder);
+};
+
+} // namespace media
+
+#endif // MEDIA_BASE_ANDROID_MEDIA_CODEC_VIDEO_DECODER_H_

Powered by Google App Engine
This is Rietveld 408576698