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

Side by Side Diff: ppapi/proxy/media_stream_video_track_resource.cc

Issue 101463008: [NOT FOR REVIEW][PPAPI] Implement MediaStreamVideoTrack pepper API (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@lkgr
Patch Set: Update Created 6 years, 11 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
(Empty)
1 // Copyright (c) 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 #include "ppapi/proxy/media_stream_video_track_resource.h"
6
7 #include "ppapi/proxy/video_frame_resource.h"
8 #include "ppapi/shared_impl/media_stream_frame.h"
9 #include "ppapi/thunk/enter.h"
10
11 namespace ppapi {
12 namespace proxy {
13
14 MediaStreamVideoTrackResource::MediaStreamVideoTrackResource(
15 Connection connection,
16 PP_Instance instance,
17 int pending_renderer_id,
18 const std::string& id)
19 : MediaStreamTrackResourceBase(
20 connection, instance, pending_renderer_id, id),
21 get_frame_output_(NULL) {
22 }
23
24 MediaStreamVideoTrackResource::~MediaStreamVideoTrackResource() {
25 }
26
27 thunk::PPB_MediaStreamVideoTrack_API*
28 MediaStreamVideoTrackResource::AsPPB_MediaStreamVideoTrack_API() {
29 return this;
30 }
31
32 int32_t MediaStreamVideoTrackResource::Configure(uint32_t max_buffered_frames) {
33 // TODO(penghuang): redesign and implement Configure() to support format,
34 // size, etc.
35 return PP_ERROR_NOTSUPPORTED;
36 }
37
38 int32_t MediaStreamVideoTrackResource::GetFrame(
39 PP_Resource* frame,
40 const scoped_refptr<ppapi::TrackedCallback>& callback) {
41 if (has_ended())
42 return PP_ERROR_FAILED;
43
44 if (TrackedCallback::IsPending(get_frame_callback_))
45 return PP_ERROR_INPROGRESS;
46
47 *frame = GetVideoFrame();
48 if (*frame)
49 return PP_OK;
50
51 get_frame_output_ = frame;
52 get_frame_callback_ = callback;
53 return PP_OK_COMPLETIONPENDING;
54 }
55
56 int32_t MediaStreamVideoTrackResource::RecycleFrame(PP_Resource frame) {
57 thunk::EnterResourceNoLock<thunk::PPB_VideoFrame_API>enter_frame(frame, true);
58 if (enter_frame.failed())
59 return PP_ERROR_BADRESOURCE;
60
61 VideoFrameResource* frame_resource =
62 static_cast<VideoFrameResource*>(enter_frame.resource());
63 if (frame_resource->index() < 0)
64 return PP_ERROR_BADRESOURCE;
65
66 HostEnqueueFrame(frame_resource->index());
67 frame_resource->invalidate();
68 return PP_OK;
69 }
70
71 void MediaStreamVideoTrackResource::Close() {
72 if (TrackedCallback::IsPending(get_frame_callback_)) {
73 *get_frame_output_ = 0;
74 get_frame_callback_->PostRun(PP_ERROR_FAILED);
75 get_frame_callback_ = NULL;
76 get_frame_output_ = 0;
77 }
78 MediaStreamTrackResourceBase::Close();
79 }
80
81 void MediaStreamVideoTrackResource::OnNewFrameEnqueued() {
82 if (TrackedCallback::IsPending(get_frame_callback_)) {
83 *get_frame_output_ = GetVideoFrame();
84 get_frame_callback_->PostRun(PP_OK);
85 get_frame_callback_ = NULL;
86 get_frame_output_ = 0;
87 }
88 }
89
90 PP_Resource MediaStreamVideoTrackResource::GetVideoFrame() {
91 int32_t index = DequeueFrame();
92 if (index < 0)
93 return 0;
94 MediaStreamFrame::Video* frame = &(GetFramePointer(index)->video);
95 return (new VideoFrameResource(pp_instance(), index, frame))->GetReference();
96 }
97
98 } // namespace proxy
99 } // namespace ppapi
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698