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

Side by Side Diff: src/image/SkImageShader.cpp

Issue 2187613002: Deserialize pictures with custom image-deserializer (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: move nullptr_t alias behind guard Created 4 years, 4 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 /* 1 /*
2 * Copyright 2015 Google Inc. 2 * Copyright 2015 Google Inc.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license that can be 4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file. 5 * found in the LICENSE file.
6 */ 6 */
7 7
8 #include "SkBitmapProcShader.h" 8 #include "SkBitmapProcShader.h"
9 #include "SkBitmapProvider.h" 9 #include "SkBitmapProvider.h"
10 #include "SkColorShader.h" 10 #include "SkColorShader.h"
11 #include "SkColorTable.h" 11 #include "SkColorTable.h"
12 #include "SkEmptyShader.h" 12 #include "SkEmptyShader.h"
13 #include "SkImage_Base.h" 13 #include "SkImage_Base.h"
14 #include "SkImageShader.h" 14 #include "SkImageShader.h"
15 #include "SkReadBuffer.h" 15 #include "SkReadBuffer.h"
16 #include "SkWriteBuffer.h" 16 #include "SkWriteBuffer.h"
17 17
18 SkImageShader::SkImageShader(const SkImage* img, TileMode tmx, TileMode tmy, con st SkMatrix* matrix) 18 SkImageShader::SkImageShader(const SkImage* img, TileMode tmx, TileMode tmy, con st SkMatrix* matrix)
19 : INHERITED(matrix) 19 : INHERITED(matrix)
20 , fImage(SkRef(img)) 20 , fImage(SkRef(img))
21 , fTileModeX(tmx) 21 , fTileModeX(tmx)
22 , fTileModeY(tmy) 22 , fTileModeY(tmy)
23 {} 23 {}
24 24
25 sk_sp<SkFlattenable> SkImageShader::CreateProc(SkReadBuffer& buffer) { 25 sk_sp<SkFlattenable> SkImageShader::CreateProc(SkReadBuffer& buffer) {
26 const TileMode tx = (TileMode)buffer.readUInt(); 26 const TileMode tx = (TileMode)buffer.readUInt();
27 const TileMode ty = (TileMode)buffer.readUInt(); 27 const TileMode ty = (TileMode)buffer.readUInt();
28 SkMatrix matrix; 28 SkMatrix matrix;
29 buffer.readMatrix(&matrix); 29 buffer.readMatrix(&matrix);
30 SkAutoTUnref<SkImage> img(buffer.readImage()); 30 sk_sp<SkImage> img = buffer.readImage();
31 if (!img) { 31 if (!img) {
32 return nullptr; 32 return nullptr;
33 } 33 }
34 return SkImageShader::Make(img, tx, ty, &matrix); 34 return SkImageShader::Make(img.release(), tx, ty, &matrix);
35 } 35 }
36 36
37 void SkImageShader::flatten(SkWriteBuffer& buffer) const { 37 void SkImageShader::flatten(SkWriteBuffer& buffer) const {
38 buffer.writeUInt(fTileModeX); 38 buffer.writeUInt(fTileModeX);
39 buffer.writeUInt(fTileModeY); 39 buffer.writeUInt(fTileModeY);
40 buffer.writeMatrix(this->getLocalMatrix()); 40 buffer.writeMatrix(this->getLocalMatrix());
41 buffer.writeImage(fImage); 41 buffer.writeImage(fImage);
42 } 42 }
43 43
44 bool SkImageShader::isOpaque() const { 44 bool SkImageShader::isOpaque() const {
(...skipping 196 matching lines...) Expand 10 before | Expand all | Expand 10 after
241 // or modify this assert. 241 // or modify this assert.
242 SkASSERT(!allocator || (kNever_SkCopyPixelsMode == cpm)); 242 SkASSERT(!allocator || (kNever_SkCopyPixelsMode == cpm));
243 243
244 return SkImageShader::Make(SkMakeImageFromRasterBitmap(src, cpm, allocator). get(), 244 return SkImageShader::Make(SkMakeImageFromRasterBitmap(src, cpm, allocator). get(),
245 tmx, tmy, localMatrix, allocator); 245 tmx, tmy, localMatrix, allocator);
246 } 246 }
247 247
248 static sk_sp<SkFlattenable> SkBitmapProcShader_CreateProc(SkReadBuffer& buffer) { 248 static sk_sp<SkFlattenable> SkBitmapProcShader_CreateProc(SkReadBuffer& buffer) {
249 SkMatrix lm; 249 SkMatrix lm;
250 buffer.readMatrix(&lm); 250 buffer.readMatrix(&lm);
251 SkBitmap bm; 251 sk_sp<SkImage> image = buffer.readBitmapAsImage();
252 if (!buffer.readBitmap(&bm)) {
253 return nullptr;
254 }
255 bm.setImmutable();
256 SkShader::TileMode mx = (SkShader::TileMode)buffer.readUInt(); 252 SkShader::TileMode mx = (SkShader::TileMode)buffer.readUInt();
257 SkShader::TileMode my = (SkShader::TileMode)buffer.readUInt(); 253 SkShader::TileMode my = (SkShader::TileMode)buffer.readUInt();
258 return SkShader::MakeBitmapShader(bm, mx, my, &lm); 254 return image ? image->makeShader(mx, my, &lm) : nullptr;
259 } 255 }
260 256
261 SK_DEFINE_FLATTENABLE_REGISTRAR_GROUP_START(SkShader) 257 SK_DEFINE_FLATTENABLE_REGISTRAR_GROUP_START(SkShader)
262 SK_DEFINE_FLATTENABLE_REGISTRAR_ENTRY(SkImageShader) 258 SK_DEFINE_FLATTENABLE_REGISTRAR_ENTRY(SkImageShader)
263 SkFlattenable::Register("SkBitmapProcShader", SkBitmapProcShader_CreateProc, kSk Shader_Type); 259 SkFlattenable::Register("SkBitmapProcShader", SkBitmapProcShader_CreateProc, kSk Shader_Type);
264 SK_DEFINE_FLATTENABLE_REGISTRAR_GROUP_END 260 SK_DEFINE_FLATTENABLE_REGISTRAR_GROUP_END
265 261
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698