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

Unified Diff: ppapi/proxy/image_capture_resource.h

Issue 848863002: PPAPI: implement GetSupportedPreviewSizes (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Split ImageCapture_Config to 881743005 Created 5 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 side-by-side diff with in-line comments
Download patch
Index: ppapi/proxy/image_capture_resource.h
diff --git a/ppapi/proxy/image_capture_resource.h b/ppapi/proxy/image_capture_resource.h
new file mode 100644
index 0000000000000000000000000000000000000000..bdac79b1d9b1a790e9bd6830bd34a256fd605735
--- /dev/null
+++ b/ppapi/proxy/image_capture_resource.h
@@ -0,0 +1,85 @@
+// Copyright 2014 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 PPAPI_PROXY_IMAGE_CAPTURE_RESOURCE_H_
+#define PPAPI_PROXY_IMAGE_CAPTURE_RESOURCE_H_
+
+#include "base/basictypes.h"
+#include "base/memory/scoped_ptr.h"
+#include "ppapi/c/pp_size.h"
+#include "ppapi/proxy/connection.h"
+#include "ppapi/proxy/plugin_resource.h"
+#include "ppapi/proxy/ppapi_proxy_export.h"
+#include "ppapi/shared_impl/resource.h"
+#include "ppapi/thunk/ppb_image_capture_api.h"
+
+namespace ppapi {
+namespace proxy {
+
+class CameraCapabilitiesResource;
+class ImageCaptureConfigResource;
+
+class PPAPI_PROXY_EXPORT ImageCaptureResource
+ : public PluginResource,
+ public thunk::PPB_ImageCapture_API {
+ public:
+ ImageCaptureResource(Connection connection, PP_Instance instance);
+
+ virtual ~ImageCaptureResource();
+
+ // Resource overrides:
+ virtual thunk::PPB_ImageCapture_API* AsPPB_ImageCapture_API() override {
+ return this;
+ }
+
+ // PPB_ImageCapture_API overrides:
+ virtual int32_t Open(PP_Var camera_source_id,
+ scoped_refptr<TrackedCallback> callback) override;
+ virtual void Close() override;
+ virtual int32_t SetConfig(PP_Resource config,
+ scoped_refptr<TrackedCallback> callback) override;
+ virtual int32_t GetConfig(PP_Resource* config,
+ scoped_refptr<TrackedCallback> callback) override;
+ virtual int32_t GetCameraCapabilities(
+ PP_Resource* capabilities,
+ scoped_refptr<TrackedCallback> callback) override;
+ virtual int32_t ReuseBuffers() override;
+ virtual int32_t CaptureStillImage(
+ PPB_ImageCapture_Private_ShutterCallback shutter_callback,
+ PPB_ImageCapture_Private_PreviewCallback preview_callback,
+ PPB_ImageCapture_Private_JpegCallback jpeg_callback,
+ PPB_ImageCapture_Private_ErrorCallback error_callback,
+ uint64_t* sequence_id) override;
+
+ private:
+ enum OpenState { BEFORE_OPEN, OPENED, CLOSED };
+
+ // Host -> plugin messages.
+ void OnPluginMsgGetPreviewSizesReply(
+ const ResourceMessageReplyParams& params,
+ const std::vector<PP_Size>& preview_sizes);
+
+ // reply to open
+ void OnPluginMsgOpenReply(const ResourceMessageReplyParams& params);
+
+ // other
+ bool IsOpened() const {return open_state_ == OPENED;}
+
+ // Holds a reference of the callback so that Close() can cancel it.
+ scoped_refptr<TrackedCallback> open_callback_;
+ OpenState open_state_;
+
+ PP_Resource* get_capabilities_output_;
+ scoped_refptr<TrackedCallback> get_capabilities_callback_;
+ scoped_refptr<CameraCapabilitiesResource> camera_capabilities_;
+
+ // scoped_refptr<ImageCaptureConfigResource> config_;
+
+ DISALLOW_COPY_AND_ASSIGN(ImageCaptureResource);
+};
+
+} // namespace proxy
+} // namespace ppapi
+
+#endif // PPAPI_PROXY_IMAGE_CAPTURE_RESOURCE_H_

Powered by Google App Engine
This is Rietveld 408576698