1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
|
// Copyright 2011 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.
#include "cc/resources/bitmap_skpicture_content_layer_updater.h"
#include "base/time.h"
#include "cc/debug/rendering_stats.h"
#include "cc/resources/layer_painter.h"
#include "cc/resources/prioritized_resource.h"
#include "cc/resources/resource_update_queue.h"
#include "third_party/skia/include/core/SkCanvas.h"
#include "third_party/skia/include/core/SkDevice.h"
namespace cc {
BitmapSkPictureContentLayerUpdater::Resource::Resource(
BitmapSkPictureContentLayerUpdater* updater,
scoped_ptr<PrioritizedResource> texture)
: ContentLayerUpdater::Resource(texture.Pass()), updater_(updater) {}
void BitmapSkPictureContentLayerUpdater::Resource::Update(
ResourceUpdateQueue* queue,
gfx::Rect source_rect,
gfx::Vector2d dest_offset,
bool partial_update,
RenderingStats* stats) {
bitmap_.setConfig(
SkBitmap::kARGB_8888_Config, source_rect.width(), source_rect.height());
bitmap_.allocPixels();
bitmap_.setIsOpaque(updater_->layer_is_opaque());
SkDevice device(bitmap_);
SkCanvas canvas(&device);
base::TimeTicks paint_begin_time;
if (stats)
paint_begin_time = base::TimeTicks::Now();
updater_->PaintContentsRect(&canvas, source_rect, stats);
if (stats)
stats->total_paint_time += base::TimeTicks::Now() - paint_begin_time;
ResourceUpdate upload = ResourceUpdate::Create(
texture(), &bitmap_, source_rect, source_rect, dest_offset);
if (partial_update)
queue->AppendPartialUpload(upload);
else
queue->AppendFullUpload(upload);
}
scoped_refptr<BitmapSkPictureContentLayerUpdater>
BitmapSkPictureContentLayerUpdater::Create(scoped_ptr<LayerPainter> painter) {
return make_scoped_refptr(
new BitmapSkPictureContentLayerUpdater(painter.Pass()));
}
BitmapSkPictureContentLayerUpdater::BitmapSkPictureContentLayerUpdater(
scoped_ptr<LayerPainter> painter)
: SkPictureContentLayerUpdater(painter.Pass()) {}
BitmapSkPictureContentLayerUpdater::~BitmapSkPictureContentLayerUpdater() {}
scoped_ptr<LayerUpdater::Resource>
BitmapSkPictureContentLayerUpdater::CreateResource(
PrioritizedResourceManager* manager) {
return scoped_ptr<LayerUpdater::Resource>(
new Resource(this, PrioritizedResource::Create(manager)));
}
void BitmapSkPictureContentLayerUpdater::PaintContentsRect(
SkCanvas* canvas,
gfx::Rect source_rect,
RenderingStats* stats) {
// Translate the origin of content_rect to that of source_rect.
canvas->translate(content_rect().x() - source_rect.x(),
content_rect().y() - source_rect.y());
base::TimeTicks rasterize_begin_time;
if (stats)
rasterize_begin_time = base::TimeTicks::Now();
DrawPicture(canvas);
if (stats) {
stats->total_rasterize_time +=
base::TimeTicks::Now() - rasterize_begin_time;
stats->total_pixels_rasterized +=
source_rect.width() * source_rect.height();
}
}
} // namespace cc
|