blob: 4b2733c1536b846fa85d51cd25dc3a6b2ce703a7 [file] [log] [blame]
[email protected]c9bc8f12012-12-15 22:20:091// Copyright (c) 2012 The Chromium Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef UI_SNAPSHOT_SNAPSHOT_H_
6#define UI_SNAPSHOT_SNAPSHOT_H_
7
8#include <vector>
9
[email protected]75a3f1b2013-12-27 00:13:4310#include "base/callback_forward.h"
11#include "base/memory/ref_counted.h"
[email protected]24e4cac2014-01-15 09:54:5912#include "base/memory/ref_counted_memory.h"
[email protected]c9bc8f12012-12-15 22:20:0913#include "ui/gfx/native_widget_types.h"
14#include "ui/snapshot/snapshot_export.h"
15
[email protected]75a3f1b2013-12-27 00:13:4316namespace base {
17class TaskRunner;
18}
19
[email protected]c9bc8f12012-12-15 22:20:0920namespace gfx {
21class Rect;
[email protected]75a3f1b2013-12-27 00:13:4322class Image;
23class Size;
[email protected]c9bc8f12012-12-15 22:20:0924}
25
26namespace ui {
27
[email protected]75a3f1b2013-12-27 00:13:4328// Grabs a snapshot of the window/view. No security checks are done. This is
29// intended to be used for debugging purposes where no BrowserProcess instance
30// is available (ie. tests). This function is synchronous, so it should NOT be
[email protected]43ea25e32014-01-16 22:36:1531// used in a result of user action. Support for async vs synchronous
32// GrabWindowSnapshot differs by platform. To be most general, use the
33// synchronous function first and if it returns false call the async one.
[email protected]c9bc8f12012-12-15 22:20:0934SNAPSHOT_EXPORT bool GrabWindowSnapshot(
35 gfx::NativeWindow window,
36 std::vector<unsigned char>* png_representation,
37 const gfx::Rect& snapshot_bounds);
38
39SNAPSHOT_EXPORT bool GrabViewSnapshot(
40 gfx::NativeView view,
41 std::vector<unsigned char>* png_representation,
42 const gfx::Rect& snapshot_bounds);
43
[email protected]667568d2014-08-14 10:03:0844
45// These functions take a snapshot of |source_rect|, specified in layer space
46// coordinates (DIP for desktop, physical pixels for Android), and scale the
47// snapshot to |target_size| (in physical pixels), asynchronously.
[email protected]75a3f1b2013-12-27 00:13:4348typedef base::Callback<void(const gfx::Image& snapshot)>
[email protected]bff45072014-01-06 20:11:5949 GrabWindowSnapshotAsyncCallback;
[email protected]c051d5a52014-01-08 23:54:5150SNAPSHOT_EXPORT void GrabWindowSnapshotAndScaleAsync(
[email protected]75a3f1b2013-12-27 00:13:4351 gfx::NativeWindow window,
52 const gfx::Rect& source_rect,
53 const gfx::Size& target_size,
54 scoped_refptr<base::TaskRunner> background_task_runner,
[email protected]bff45072014-01-06 20:11:5955 const GrabWindowSnapshotAsyncCallback& callback);
[email protected]24e4cac2014-01-15 09:54:5956
57typedef base::Callback<void(scoped_refptr<base::RefCountedBytes> png_data)>
58 GrabWindowSnapshotAsyncPNGCallback;
[email protected]c051d5a52014-01-08 23:54:5159SNAPSHOT_EXPORT void GrabWindowSnapshotAsync(
60 gfx::NativeWindow window,
61 const gfx::Rect& source_rect,
62 scoped_refptr<base::TaskRunner> background_task_runner,
[email protected]24e4cac2014-01-15 09:54:5963 const GrabWindowSnapshotAsyncPNGCallback& callback);
[email protected]43ea25e32014-01-16 22:36:1564SNAPSHOT_EXPORT void GrabViewSnapshotAsync(
65 gfx::NativeView view,
66 const gfx::Rect& source_rect,
67 scoped_refptr<base::TaskRunner> background_task_runner,
68 const GrabWindowSnapshotAsyncPNGCallback& callback);
[email protected]75a3f1b2013-12-27 00:13:4369
[email protected]c9bc8f12012-12-15 22:20:0970} // namespace ui
71
72#endif // UI_SNAPSHOT_SNAPSHOT_H_