OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright 2012 Google Inc. | 2 * Copyright 2012 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 "SkImageDecoder.h" | 8 #include "SkImageDecoder.h" |
9 #include "SkImage_Base.h" | 9 #include "SkImage_Base.h" |
10 #include "SkBitmap.h" | 10 #include "SkBitmap.h" |
11 #include "SkCanvas.h" | 11 #include "SkCanvas.h" |
12 #include "SkData.h" | 12 #include "SkData.h" |
13 | 13 |
14 class SkImage_Codec : public SkImage_Base { | 14 class SkImage_Codec : public SkImage_Base { |
15 public: | 15 public: |
16 static SkImage* NewEmpty(); | 16 static SkImage* NewEmpty(); |
17 | 17 |
18 SkImage_Codec(SkData* encodedData, int width, int height); | 18 SkImage_Codec(SkData* encodedData, int width, int height); |
19 virtual ~SkImage_Codec(); | 19 virtual ~SkImage_Codec(); |
20 | 20 |
21 virtual void onDraw(SkCanvas*, SkScalar, SkScalar, const SkPaint*) SK_OVERRI DE; | 21 virtual void onDraw(SkCanvas*, SkScalar, SkScalar, const SkPaint*) SK_OVERRI DE; |
22 virtual void onDrawRectToRect(SkCanvas*, const SkRect*, const SkRect&, const SkPaint*) SK_OVERRIDE; | 22 virtual void onDrawRectToRect(SkCanvas*, const SkRect*, const SkRect&, const SkPaint*) SK_OVERRIDE; |
23 | 23 |
24 virtual SkShader* onNewShader(SkShader::TileMode, SkShader::TileMode) const SK_OVERRIDE; | |
24 private: | 25 private: |
25 SkData* fEncodedData; | 26 SkData* fEncodedData; |
26 SkBitmap fBitmap; | 27 SkBitmap fBitmap; |
27 | 28 |
28 typedef SkImage_Base INHERITED; | 29 typedef SkImage_Base INHERITED; |
29 }; | 30 }; |
30 | 31 |
31 /////////////////////////////////////////////////////////////////////////////// | 32 /////////////////////////////////////////////////////////////////////////////// |
32 | 33 |
33 SkImage_Codec::SkImage_Codec(SkData* data, int width, int height) : INHERITED(wi dth, height) { | 34 SkImage_Codec::SkImage_Codec(SkData* data, int width, int height) : INHERITED(wi dth, height) { |
34 fEncodedData = data; | 35 fEncodedData = data; |
35 fEncodedData->ref(); | 36 fEncodedData->ref(); |
36 } | 37 } |
37 | 38 |
38 SkImage_Codec::~SkImage_Codec() { | 39 SkImage_Codec::~SkImage_Codec() { |
39 fEncodedData->unref(); | 40 fEncodedData->unref(); |
40 } | 41 } |
41 | 42 |
43 SkShader* SkImage_Codec::onNewShader(SkShader::TileMode tileX, SkShader::TileMod e tileY) const { | |
Justin Novosad
2014/07/10 19:24:36
Do you have test coverage for this guy?
Rémi Piotaix
2014/07/10 20:16:04
It seems that SkImage_Codec is never used...
Metho
| |
44 return SkShader::CreateBitmapShader(fBitmap, tileX, tileY, NULL); | |
45 } | |
46 | |
42 void SkImage_Codec::onDraw(SkCanvas* canvas, SkScalar x, SkScalar y, const SkPai nt* paint) { | 47 void SkImage_Codec::onDraw(SkCanvas* canvas, SkScalar x, SkScalar y, const SkPai nt* paint) { |
43 if (!fBitmap.pixelRef()) { | 48 if (!fBitmap.pixelRef()) { |
44 if (!SkImageDecoder::DecodeMemory(fEncodedData->bytes(), fEncodedData->s ize(), &fBitmap)) { | 49 if (!SkImageDecoder::DecodeMemory(fEncodedData->bytes(), fEncodedData->s ize(), &fBitmap)) { |
45 return; | 50 return; |
46 } | 51 } |
47 } | 52 } |
48 canvas->drawBitmap(fBitmap, x, y, paint); | 53 canvas->drawBitmap(fBitmap, x, y, paint); |
49 } | 54 } |
50 | 55 |
51 void SkImage_Codec::onDrawRectToRect(SkCanvas* canvas, const SkRect* src, | 56 void SkImage_Codec::onDrawRectToRect(SkCanvas* canvas, const SkRect* src, |
(...skipping 14 matching lines...) Expand all Loading... | |
66 } | 71 } |
67 | 72 |
68 SkBitmap bitmap; | 73 SkBitmap bitmap; |
69 if (!SkImageDecoder::DecodeMemory(data->bytes(), data->size(), &bitmap, kUnk nown_SkColorType, | 74 if (!SkImageDecoder::DecodeMemory(data->bytes(), data->size(), &bitmap, kUnk nown_SkColorType, |
70 SkImageDecoder::kDecodeBounds_Mode)) { | 75 SkImageDecoder::kDecodeBounds_Mode)) { |
71 return NULL; | 76 return NULL; |
72 } | 77 } |
73 | 78 |
74 return SkNEW_ARGS(SkImage_Codec, (data, bitmap.width(), bitmap.height())); | 79 return SkNEW_ARGS(SkImage_Codec, (data, bitmap.width(), bitmap.height())); |
75 } | 80 } |
OLD | NEW |