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

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

Issue 128683003: [PPAPI] Implement media stream video track API (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@video_track_impl_cl
Patch Set: Fix review issues 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/shared_impl/var.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 Close();
26 }
27
28 thunk::PPB_MediaStreamVideoTrack_API*
29 MediaStreamVideoTrackResource::AsPPB_MediaStreamVideoTrack_API() {
30 return this;
31 }
32
33 PP_Var MediaStreamVideoTrackResource::GetId() {
34 return StringVar::StringToPPVar(id());
35 }
36
37 PP_Bool MediaStreamVideoTrackResource::HasEnded() {
38 return PP_FromBool(has_ended());
39 }
40
41 int32_t MediaStreamVideoTrackResource::Configure(uint32_t max_buffered_frames) {
42 // TODO(penghuang): redesign and implement Configure() to support format,
43 // size, etc.
44 return PP_ERROR_NOTSUPPORTED;
45 }
46
47 int32_t MediaStreamVideoTrackResource::GetFrame(
48 PP_Resource* frame,
49 scoped_refptr<TrackedCallback> callback) {
50 if (has_ended())
51 return PP_ERROR_FAILED;
52
53 if (TrackedCallback::IsPending(get_frame_callback_))
54 return PP_ERROR_INPROGRESS;
55
56 *frame = GetVideoFrame();
57 if (*frame)
58 return PP_OK;
59
60 get_frame_output_ = frame;
61 get_frame_callback_ = callback;
62 return PP_OK_COMPLETIONPENDING;
63 }
64
65 int32_t MediaStreamVideoTrackResource::RecycleFrame(PP_Resource frame) {
66 FrameMap::iterator it = frames_.find(frame);
67 if (it == frames_.end())
68 return PP_ERROR_BADRESOURCE;
69
70 scoped_refptr<VideoFrameResource> frame_resource = it->second;
71 frames_.erase(it);
72
73 if (has_ended())
74 return PP_OK;
75
76 DCHECK_GE(frame_resource->GetFrameBufferIndex(), 0);
77
78 SendEnqueueFrameMessageToHost(frame_resource->GetFrameBufferIndex());
79 frame_resource->Invalidate();
80 return PP_OK;
81 }
82
83 void MediaStreamVideoTrackResource::Close() {
84 if (has_ended())
85 return;
86
87 if (TrackedCallback::IsPending(get_frame_callback_)) {
88 *get_frame_output_ = 0;
89 get_frame_callback_->PostAbort();
90 get_frame_callback_ = NULL;
91 get_frame_output_ = 0;
92 }
93
94 ReleaseFrames();
95 MediaStreamTrackResourceBase::CloseInternal();
96 }
97
98 void MediaStreamVideoTrackResource::OnNewFrameEnqueued() {
99 if (TrackedCallback::IsPending(get_frame_callback_)) {
100 *get_frame_output_ = GetVideoFrame();
101 get_frame_output_ = NULL;
102 scoped_refptr<TrackedCallback> callback;
103 callback.swap(get_frame_callback_);
104 callback->Run(PP_OK);
105 }
106 }
107
108 PP_Resource MediaStreamVideoTrackResource::GetVideoFrame() {
109 int32_t index = frame_buffer()->DequeueFrame();
110 if (index < 0)
111 return 0;
112 MediaStreamFrame* frame = frame_buffer()->GetFramePointer(index);
113 scoped_refptr<VideoFrameResource> resource =
114 new VideoFrameResource(pp_instance(), index, frame);
115 // Add |pp_resource()| and |resource| into |frames_|.
116 // |frames_| uses scoped_ptr<> to hold a ref of |resource|. It keeps the
117 // resource alive.
118 frames_.insert(FrameMap::value_type(resource->pp_resource(), resource));
119 return resource->GetReference();
120 }
121
122 void MediaStreamVideoTrackResource::ReleaseFrames() {
123 FrameMap::iterator it = frames_.begin();
124 while (it != frames_.end()) {
125 // Just invalidate and release VideoFrameResorce, but keep PP_Resource.
126 // So plugin can still use |RecycleFrame()|.
127 it->second->Invalidate();
128 it->second = NULL;
129 }
130 }
131
132 } // namespace proxy
133 } // namespace ppapi
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698