blob: 37f8dc9d52e9de111634ce18eab0426cc47a6692 (
plain)
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
|
/*
* Copyright 2015 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#include "SkBitmapProvider.h"
#include "SkImage_Base.h"
#include "SkPixelRef.h"
int SkBitmapProvider::width() const {
return fImage ? fImage->width() : fBitmap.width();
}
int SkBitmapProvider::height() const {
return fImage ? fImage->height() : fBitmap.height();
}
uint32_t SkBitmapProvider::getID() const {
return fImage ? fImage->uniqueID() : fBitmap.getGenerationID();
}
bool SkBitmapProvider::validForDrawing() const {
if (!fImage) {
if (0 == fBitmap.width() || 0 == fBitmap.height()) {
return false;
}
if (nullptr == fBitmap.pixelRef()) {
return false; // no pixels to read
}
if (kIndex_8_SkColorType == fBitmap.colorType()) {
SkAutoLockPixels alp(fBitmap); // but we need to call it before getColorTable() is safe.
if (!fBitmap.getColorTable()) {
return false;
}
}
}
return true;
}
SkImageInfo SkBitmapProvider::info() const {
if (fImage) {
return as_IB(fImage)->onImageInfo();
} else {
return fBitmap.info();
}
}
bool SkBitmapProvider::isVolatile() const {
if (fImage) {
// add flag to images?
const SkBitmap* bm = as_IB(fImage)->onPeekBitmap();
return bm ? bm->isVolatile() : false;
} else {
return fBitmap.isVolatile();
}
}
SkBitmapCacheDesc SkBitmapProvider::makeCacheDesc(int w, int h) const {
return fImage ? SkBitmapCacheDesc::Make(fImage, w, h) : SkBitmapCacheDesc::Make(fBitmap, w, h);
}
SkBitmapCacheDesc SkBitmapProvider::makeCacheDesc() const {
return fImage ? SkBitmapCacheDesc::Make(fImage) : SkBitmapCacheDesc::Make(fBitmap);
}
void SkBitmapProvider::notifyAddedToCache() const {
if (fImage) {
as_IB(fImage)->notifyAddedToCache();
} else {
fBitmap.pixelRef()->notifyAddedToCache();
}
}
bool SkBitmapProvider::asBitmap(SkBitmap* bm) const {
if (fImage) {
return as_IB(fImage)->getROPixels(bm, SkImage::kAllow_CachingHint);
} else {
*bm = fBitmap;
return true;
}
}
|