// Copyright 2013 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 EXTENSIONS_BROWSER_API_CAPTURE_WEB_CONTENTS_FUNCTION_H_ #define EXTENSIONS_BROWSER_API_CAPTURE_WEB_CONTENTS_FUNCTION_H_ #include "content/public/browser/readback_types.h" #include "extensions/browser/extension_function.h" #include "extensions/common/api/extension_types.h" class SkBitmap; namespace content { class WebContents; } namespace extensions { // Base class for capturing visibile area of a WebContents. // This is used by both webview.captureVisibleRegion and tabs.captureVisibleTab. class CaptureWebContentsFunction : public AsyncExtensionFunction { public: CaptureWebContentsFunction() {} protected: ~CaptureWebContentsFunction() override {} // ExtensionFunction implementation. bool HasPermission() override; bool RunAsync() override; virtual bool IsScreenshotEnabled() = 0; virtual content::WebContents* GetWebContentsForID(int context_id) = 0; enum FailureReason { FAILURE_REASON_UNKNOWN, FAILURE_REASON_ENCODING_FAILED, FAILURE_REASON_VIEW_INVISIBLE }; virtual void OnCaptureFailure(FailureReason reason) = 0; private: typedef core_api::extension_types::ImageDetails ImageDetails; void CopyFromBackingStoreComplete(const SkBitmap& bitmap, content::ReadbackResponse response); void OnCaptureSuccess(const SkBitmap& bitmap); // |context_id_| is the ID used to find the relevant WebContents. In the // |tabs.captureVisibleTab()| api, this represents the window-id, and in the // |webview.captureVisibleRegion()| api, this represents the instance-id of // the guest. int context_id_; // The format (JPEG vs PNG) of the resulting image. Set in RunAsync(). ImageDetails::Format image_format_; // Quality setting to use when encoding jpegs. Set in RunAsync(). int image_quality_; DISALLOW_COPY_AND_ASSIGN(CaptureWebContentsFunction); }; } // namespace extensions #endif // EXTENSIONS_BROWSER_API_CAPTURE_WEB_CONTENTS_FUNCTION_H_