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

Side by Side Diff: chrome/browser/ui/window_snapshot/window_snapshot_aura.cc

Issue 10386124: Introduce XGetImage() for GrabWindowSnapshot() in ChromeOS. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase Created 8 years, 7 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « no previous file | ui/aura/root_window.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // 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 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/ui/window_snapshot/window_snapshot.h" 5 #include "chrome/browser/ui/window_snapshot/window_snapshot.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "third_party/skia/include/core/SkBitmap.h" 8 #include "third_party/skia/include/core/SkBitmap.h"
9 #include "ui/aura/root_window.h"
9 #include "ui/aura/window.h" 10 #include "ui/aura/window.h"
10 #include "ui/compositor/compositor.h" 11 #include "ui/compositor/compositor.h"
11 #include "ui/compositor/dip_util.h" 12 #include "ui/compositor/dip_util.h"
12 #include "ui/compositor/layer.h" 13 #include "ui/compositor/layer.h"
13 #include "ui/gfx/codec/png_codec.h" 14 #include "ui/gfx/codec/png_codec.h"
14 #include "ui/gfx/rect.h" 15 #include "ui/gfx/rect.h"
15 16
16 namespace browser { 17 namespace browser {
17 18
18 bool GrabWindowSnapshot(gfx::NativeWindow window, 19 bool GrabWindowSnapshot(gfx::NativeWindow window,
19 std::vector<unsigned char>* png_representation, 20 std::vector<unsigned char>* png_representation,
20 const gfx::Rect& snapshot_bounds) { 21 const gfx::Rect& snapshot_bounds) {
22 #if defined(OS_LINUX)
23 // We use XGetImage() for Linux/ChromeOS for performance reasons.
24 // See crbug.com/122720
25 if (window->GetRootWindow()->GrabSnapshot(
26 snapshot_bounds, png_representation))
27 return true;
28 #endif // OS_LINUX
29
21 ui::Compositor* compositor = window->layer()->GetCompositor(); 30 ui::Compositor* compositor = window->layer()->GetCompositor();
22 31
23 gfx::Rect read_pixels_bounds = snapshot_bounds; 32 gfx::Rect read_pixels_bounds = snapshot_bounds;
24 33
25 // When not in compact mode we must take into account the window's position on 34 // When not in compact mode we must take into account the window's position on
26 // the desktop. 35 // the desktop.
27 read_pixels_bounds.set_origin( 36 read_pixels_bounds.set_origin(
28 snapshot_bounds.origin().Add(window->bounds().origin())); 37 snapshot_bounds.origin().Add(window->bounds().origin()));
29 gfx::Rect read_pixels_bounds_in_pixel = 38 gfx::Rect read_pixels_bounds_in_pixel =
30 ui::ConvertRectToPixel(window->layer(), read_pixels_bounds); 39 ui::ConvertRectToPixel(window->layer(), read_pixels_bounds);
(...skipping 11 matching lines...) Expand all
42 51
43 gfx::PNGCodec::Encode(pixels, gfx::PNGCodec::FORMAT_BGRA, 52 gfx::PNGCodec::Encode(pixels, gfx::PNGCodec::FORMAT_BGRA,
44 read_pixels_bounds_in_pixel.size(), 53 read_pixels_bounds_in_pixel.size(),
45 bitmap.rowBytes(), true, 54 bitmap.rowBytes(), true,
46 std::vector<gfx::PNGCodec::Comment>(), 55 std::vector<gfx::PNGCodec::Comment>(),
47 png_representation); 56 png_representation);
48 return true; 57 return true;
49 } 58 }
50 59
51 } // namespace browser 60 } // namespace browser
OLDNEW
« no previous file with comments | « no previous file | ui/aura/root_window.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698