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

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: Update histogram.xml with pepper_hash_for_uma Created 5 years, 10 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..62bc8ab3068aa656ec5c0c636817c7346a1cfb2f
--- /dev/null
+++ b/ppapi/proxy/image_capture_resource.h
@@ -0,0 +1,66 @@
+// 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 PPAPI_PROXY_IMAGE_CAPTURE_RESOURCE_H_
+#define PPAPI_PROXY_IMAGE_CAPTURE_RESOURCE_H_
+
+#include "base/basictypes.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);
+ ~ImageCaptureResource() override;
+
+ // Resource overrides:
+ thunk::PPB_ImageCapture_API* AsPPB_ImageCapture_API() override {
+ return this;
+ }
+
+ // PPB_ImageCapture_API implementation.
+ int32_t Open(PP_Var device_id,
+ const scoped_refptr<TrackedCallback>& callback) override;
+ void Close() override;
+ int32_t GetCameraCapabilities(
+ PP_Resource* capabilities,
+ const scoped_refptr<TrackedCallback>& callback) override;
+
+ private:
+ enum OpenState { BEFORE_OPEN, OPENED, CLOSED };
dcheng 2015/02/12 21:47:20 Prefer enum class.
Justin Chuang 2015/02/16 19:15:24 Done. Thanks. Looks better.
+
+ void OnPluginMsgGetPreviewSizesReply(
+ PP_Resource* capabilities_output,
+ const ResourceMessageReplyParams& params,
+ const std::vector<PP_Size>& preview_sizes);
+ void OnPluginMsgOpenReply(const ResourceMessageReplyParams& params);
+
+ bool is_opened() 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_;
+
+ scoped_refptr<TrackedCallback> get_capabilities_callback_;
+ scoped_refptr<CameraCapabilitiesResource> camera_capabilities_;
+
+ 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