Index: ppapi/examples/video_capture/video_capture.cc |
diff --git a/ppapi/examples/video_capture/video_capture.cc b/ppapi/examples/video_capture/video_capture.cc |
index 63e2cb80312a3dbaf17959e08625add21afb4409..512cca4c642752dbd1dfab494062f87f82cff673 100644 |
--- a/ppapi/examples/video_capture/video_capture.cc |
+++ b/ppapi/examples/video_capture/video_capture.cc |
@@ -1,4 +1,4 @@ |
-// Copyright (c) 2011 The Chromium Authors. All rights reserved. |
+// Copyright (c) 2012 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. |
@@ -8,9 +8,11 @@ |
#include <map> |
#include <vector> |
+#include "ppapi/c/dev/ppb_video_capture_dev.h" |
#include "ppapi/c/pp_errors.h" |
#include "ppapi/c/ppb_opengles2.h" |
#include "ppapi/cpp/dev/buffer_dev.h" |
+#include "ppapi/cpp/dev/device_ref_dev.h" |
#include "ppapi/cpp/dev/video_capture_dev.h" |
#include "ppapi/cpp/dev/video_capture_client_dev.h" |
#include "ppapi/cpp/completion_callback.h" |
@@ -19,6 +21,7 @@ |
#include "ppapi/cpp/instance.h" |
#include "ppapi/cpp/module.h" |
#include "ppapi/cpp/rect.h" |
+#include "ppapi/cpp/var.h" |
#include "ppapi/lib/gl/include/GLES2/gl2.h" |
#include "ppapi/utility/completion_callback_factory.h" |
@@ -49,6 +52,7 @@ class VCDemoInstance : public pp::Instance, |
// pp::Instance implementation (see PPP_Instance). |
virtual void DidChangeView(const pp::Rect& position, |
const pp::Rect& clip_ignored); |
+ virtual void HandleMessage(const pp::Var& message_data); |
// pp::Graphics3DClient implementation. |
virtual void Graphics3DContextLost() { |
@@ -107,13 +111,16 @@ class VCDemoInstance : public pp::Instance, |
// GL-related functions. |
void InitGL(); |
- void InitializeCapture(); |
GLuint CreateTexture(int32_t width, int32_t height, int unit); |
void CreateGLObjects(); |
void CreateShader(GLuint program, GLenum type, const char* source, int size); |
void PaintFinished(int32_t result); |
void CreateYUVTextures(); |
+ void Open(const pp::DeviceRef_Dev& device); |
+ void EnumerateDevicesFinished(int32_t result); |
+ void OpenFinished(int32_t result); |
+ |
pp::Size position_size_; |
bool is_painting_; |
bool needs_paint_; |
@@ -130,6 +137,8 @@ class VCDemoInstance : public pp::Instance, |
// Owned data. |
pp::Graphics3D* context_; |
+ |
+ std::vector<pp::DeviceRef_Dev> devices_; |
}; |
VCDemoInstance::VCDemoInstance(PP_Instance instance, pp::Module* module) |
@@ -147,7 +156,10 @@ VCDemoInstance::VCDemoInstance(PP_Instance instance, pp::Module* module) |
gles2_if_ = static_cast<const struct PPB_OpenGLES2*>( |
module->GetBrowserInterface(PPB_OPENGLES2_INTERFACE)); |
assert(gles2_if_); |
- InitializeCapture(); |
+ |
+ capture_info_.width = 320; |
+ capture_info_.height = 240; |
+ capture_info_.frames_per_second = 30; |
} |
VCDemoInstance::~VCDemoInstance() { |
@@ -169,12 +181,33 @@ void VCDemoInstance::DidChangeView( |
Render(); |
} |
-void VCDemoInstance::InitializeCapture() { |
- capture_info_.width = 320; |
- capture_info_.height = 240; |
- capture_info_.frames_per_second = 30; |
- |
- video_capture_.StartCapture(capture_info_, 4); |
+void VCDemoInstance::HandleMessage(const pp::Var& message_data) { |
+ if (message_data.is_string()) { |
+ std::string event = message_data.AsString(); |
+ if (event == "PageInitialized") { |
+ pp::CompletionCallback callback = callback_factory_.NewCallback( |
+ &VCDemoInstance::EnumerateDevicesFinished); |
+ video_capture_.EnumerateDevices(&devices_, callback); |
+ } else if (event == "UseDefault") { |
+ Open(pp::DeviceRef_Dev()); |
+ } else if (event == "UseDefault(v0.1)") { |
+ const PPB_VideoCapture_Dev_0_1* video_capture_0_1 = |
+ static_cast<const PPB_VideoCapture_Dev_0_1*>( |
+ pp::Module::Get()->GetBrowserInterface( |
+ PPB_VIDEOCAPTURE_DEV_INTERFACE_0_1)); |
+ video_capture_0_1->StartCapture(video_capture_.pp_resource(), |
+ &capture_info_, 4); |
+ } else if (event == "Stop") { |
+ video_capture_.StopCapture(); |
+ } |
+ } else if (message_data.is_number()) { |
+ int index = message_data.AsInt(); |
+ if (index >= 0 && index < static_cast<int>(devices_.size())) { |
+ Open(devices_[index]); |
+ } else { |
+ assert(false); |
+ } |
+ } |
} |
void VCDemoInstance::InitGL() { |
@@ -364,6 +397,39 @@ void VCDemoInstance::CreateYUVTextures() { |
texture_v_ = CreateTexture(width, height, 2); |
} |
+void VCDemoInstance::Open(const pp::DeviceRef_Dev& device) { |
+ pp::CompletionCallback callback = callback_factory_.NewCallback( |
+ &VCDemoInstance::OpenFinished); |
+ video_capture_.Open(device, capture_info_, 4, callback); |
+} |
+ |
+void VCDemoInstance::EnumerateDevicesFinished(int32_t result) { |
+ static const char* const kDelimiter = "#__#"; |
+ |
+ if (result == PP_OK) { |
+ std::string device_names; |
+ for (size_t index = 0; index < devices_.size(); ++index) { |
+ pp::Var name = devices_[index].GetName(); |
+ assert(name.is_string()); |
+ |
+ if (index != 0) |
+ device_names += kDelimiter; |
+ device_names += name.AsString(); |
+ } |
+ PostMessage(pp::Var(device_names)); |
+ } else { |
+ PostMessage(pp::Var("EnumerationFailed")); |
+ } |
+} |
+ |
+void VCDemoInstance::OpenFinished(int32_t result) { |
+ if (result == PP_OK) { |
+ video_capture_.StartCapture(); |
+ } else { |
+ PostMessage(pp::Var("OpenFailed")); |
+ } |
+} |
+ |
pp::Instance* VCDemoModule::CreateInstance(PP_Instance instance) { |
return new VCDemoInstance(instance, this); |
} |