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

Side by Side Diff: blimp/test/support/compositor/picture_cache_test_support.cc

Issue 2343993002: use SkData oriented picture serialize api (Closed)
Patch Set: remove another unused SkStream.h include Created 4 years, 3 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
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 "blimp/test/support/compositor/picture_cache_test_support.h" 5 #include "blimp/test/support/compositor/picture_cache_test_support.h"
6 6
7 #include "base/memory/ptr_util.h" 7 #include "base/memory/ptr_util.h"
8 #include "blimp/common/blob_cache/blob_cache.h" 8 #include "blimp/common/blob_cache/blob_cache.h"
9 #include "blimp/common/blob_cache/id_util.h" 9 #include "blimp/common/blob_cache/id_util.h"
10 #include "third_party/skia/include/core/SkCanvas.h" 10 #include "third_party/skia/include/core/SkCanvas.h"
11 #include "third_party/skia/include/core/SkColor.h" 11 #include "third_party/skia/include/core/SkColor.h"
12 #include "third_party/skia/include/core/SkData.h" 12 #include "third_party/skia/include/core/SkData.h"
13 #include "third_party/skia/include/core/SkPicture.h" 13 #include "third_party/skia/include/core/SkPicture.h"
14 #include "third_party/skia/include/core/SkPictureRecorder.h" 14 #include "third_party/skia/include/core/SkPictureRecorder.h"
15 #include "third_party/skia/include/core/SkRefCnt.h" 15 #include "third_party/skia/include/core/SkRefCnt.h"
16 #include "third_party/skia/include/core/SkStream.h"
17 #include "ui/gfx/geometry/point_f.h" 16 #include "ui/gfx/geometry/point_f.h"
18 #include "ui/gfx/geometry/rect.h" 17 #include "ui/gfx/geometry/rect.h"
19 #include "ui/gfx/geometry/rect_f.h" 18 #include "ui/gfx/geometry/rect_f.h"
20 #include "ui/gfx/skia_util.h" 19 #include "ui/gfx/skia_util.h"
21 20
22 namespace blimp { 21 namespace blimp {
23 22
24 sk_sp<const SkPicture> CreateSkPicture(SkColor color) { 23 sk_sp<const SkPicture> CreateSkPicture(SkColor color) {
25 SkPictureRecorder recorder; 24 SkPictureRecorder recorder;
26 sk_sp<SkCanvas> canvas = 25 sk_sp<SkCanvas> canvas =
27 sk_ref_sp(recorder.beginRecording(SkRect::MakeWH(1, 1))); 26 sk_ref_sp(recorder.beginRecording(SkRect::MakeWH(1, 1)));
28 canvas->drawColor(color); 27 canvas->drawColor(color);
29 return recorder.finishRecordingAsPicture(); 28 return recorder.finishRecordingAsPicture();
30 } 29 }
31 30
32 sk_sp<SkData> SerializePicture(sk_sp<const SkPicture> picture) { 31 sk_sp<SkData> SerializePicture(sk_sp<const SkPicture> picture) {
33 SkDynamicMemoryWStream stream; 32 sk_sp<SkData> data = picture->serialize();
34 picture->serialize(&stream, nullptr); 33 DCHECK(data->size());
Wez 2016/09/16 16:34:02 nit: I realise this was already in this state, but
reed1 2016/09/16 20:06:29 That seems related to the other question about zer
Wez 2016/09/17 01:50:03 No, my point here was simply to be consistent in u
35 DCHECK(stream.bytesWritten()); 34 return data;
36 return sk_sp<SkData>(stream.copyToData());
37 } 35 }
38 36
39 BlobId GetBlobId(sk_sp<const SkPicture> picture) { 37 BlobId GetBlobId(sk_sp<const SkPicture> picture) {
40 sk_sp<SkData> data = SerializePicture(picture); 38 sk_sp<SkData> data = SerializePicture(picture);
41 return CalculateBlobId(data->data(), data->size()); 39 return CalculateBlobId(data->data(), data->size());
42 } 40 }
43 41
44 sk_sp<const SkPicture> DeserializePicture(sk_sp<SkData> data) { 42 sk_sp<const SkPicture> DeserializePicture(sk_sp<SkData> data) {
45 SkMemoryStream stream(data); 43 return SkPicture::MakeFromData(data.get());
46 return SkPicture::MakeFromStream(&stream, nullptr);
47 } 44 }
48 45
49 bool PicturesEqual(sk_sp<const SkPicture> picture, 46 bool PicturesEqual(sk_sp<const SkPicture> picture,
50 const cc::PictureData& picture_data) { 47 const cc::PictureData& picture_data) {
51 if (picture->uniqueID() != picture_data.unique_id) { 48 if (picture->uniqueID() != picture_data.unique_id) {
52 return false; 49 return false;
53 } 50 }
54 sk_sp<const SkPicture> deserialized_picture = 51 sk_sp<const SkPicture> deserialized_picture =
55 DeserializePicture(picture_data.data); 52 DeserializePicture(picture_data.data);
56 return GetBlobId(picture) == GetBlobId(deserialized_picture); 53 return GetBlobId(picture) == GetBlobId(deserialized_picture);
57 } 54 }
58 55
59 cc::PictureData CreatePictureData(sk_sp<const SkPicture> picture) { 56 cc::PictureData CreatePictureData(sk_sp<const SkPicture> picture) {
60 return cc::PictureData(picture->uniqueID(), SerializePicture(picture)); 57 return cc::PictureData(picture->uniqueID(), SerializePicture(picture));
61 } 58 }
62 59
63 } // namespace blimp 60 } // namespace blimp
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698