OLD | NEW |
1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 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 "cc/test/skia_common.h" | 5 #include "cc/test/skia_common.h" |
6 | 6 |
7 #include "cc/resources/picture.h" | 7 #include "cc/resources/picture.h" |
8 #include "skia/ext/refptr.h" | 8 #include "skia/ext/refptr.h" |
9 #include "third_party/skia/include/core/SkCanvas.h" | 9 #include "third_party/skia/include/core/SkCanvas.h" |
10 #include "ui/gfx/rect.h" | 10 #include "ui/gfx/rect.h" |
11 #include "ui/gfx/skia_util.h" | 11 #include "ui/gfx/skia_util.h" |
12 | 12 |
13 namespace cc { | 13 namespace cc { |
14 | 14 |
15 void DrawPicture(unsigned char* buffer, | 15 void DrawPicture(unsigned char* buffer, |
16 const gfx::Rect& layer_rect, | 16 const gfx::Rect& layer_rect, |
17 scoped_refptr<Picture> picture) { | 17 scoped_refptr<Picture> picture) { |
| 18 SkImageInfo info = |
| 19 SkImageInfo::MakeN32Premul(layer_rect.width(), layer_rect.height()); |
18 SkBitmap bitmap; | 20 SkBitmap bitmap; |
19 bitmap.setConfig(SkBitmap::kARGB_8888_Config, | 21 bitmap.installPixels(info, buffer, info.minRowBytes()); |
20 layer_rect.width(), | |
21 layer_rect.height()); | |
22 bitmap.setPixels(buffer); | |
23 SkCanvas canvas(bitmap); | 22 SkCanvas canvas(bitmap); |
24 canvas.clipRect(gfx::RectToSkRect(layer_rect)); | 23 canvas.clipRect(gfx::RectToSkRect(layer_rect)); |
25 picture->Raster(&canvas, NULL, layer_rect, 1.0f); | 24 picture->Raster(&canvas, NULL, layer_rect, 1.0f); |
26 } | 25 } |
27 | 26 |
28 void CreateBitmap(const gfx::Size& size, const char* uri, SkBitmap* bitmap) { | 27 void CreateBitmap(const gfx::Size& size, const char* uri, SkBitmap* bitmap) { |
29 SkImageInfo info = { | 28 SkImageInfo info = SkImageInfo::MakeN32Premul(size.width(), size.height()); |
30 size.width(), | |
31 size.height(), | |
32 kPMColor_SkColorType, | |
33 kPremul_SkAlphaType | |
34 }; | |
35 | 29 |
36 bitmap->setConfig(info); | 30 bitmap->allocPixels(info); |
37 bitmap->allocPixels(); | |
38 bitmap->pixelRef()->setImmutable(); | 31 bitmap->pixelRef()->setImmutable(); |
39 bitmap->pixelRef()->setURI(uri); | 32 bitmap->pixelRef()->setURI(uri); |
40 } | 33 } |
41 | 34 |
42 } // namespace cc | 35 } // namespace cc |
OLD | NEW |