// Copyright (c) 2006-2008 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 CHROME_BROWSER_UI_VIEWS_TABS_NATIVE_VIEW_PHOTOBOOTH_H_ #define CHROME_BROWSER_UI_VIEWS_TABS_NATIVE_VIEW_PHOTOBOOTH_H_ #pragma once #include "base/compiler_specific.h" #include "ui/gfx/native_widget_types.h" namespace gfx { class Canvas; class Rect; } /////////////////////////////////////////////////////////////////////////////// // NativeViewPhotobooth // // An object that a NativeView "steps into" to have its picture taken. This is // used to generate a full size screen shot of the contents of a NativeView // including any child windows. // // Implementation note: This causes the NativeView to be re-parented to a // mostly off-screen layered window. // class NativeViewPhotobooth { public: // Creates the photo booth. Constructs a nearly off-screen window, parents // the view, then shows it. The caller is responsible for destroying this // photo-booth, since the photo-booth will detach it before it is destroyed. static NativeViewPhotobooth* Create(gfx::NativeView initial_view); // Destroys the photo booth window. virtual ~NativeViewPhotobooth() {} // Replaces the view in the photo booth with the specified one. virtual void Replace(gfx::NativeView new_view) = 0; // Paints the current display image of the window into |canvas|, clipped to // |target_bounds|. virtual void PaintScreenshotIntoCanvas(gfx::Canvas* canvas, const gfx::Rect& target_bounds) = 0; }; #endif // CHROME_BROWSER_UI_VIEWS_TABS_NATIVE_VIEW_PHOTOBOOTH_H_