OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2006 The Android Open Source Project | 2 * Copyright 2006 The Android Open Source Project |
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 "SkEmbossMaskFilter.h" | 8 #include "SkEmbossMaskFilter.h" |
9 #include "SkBlurMaskFilter.h" | 9 #include "SkBlurMaskFilter.h" |
10 #include "SkBlurMask.h" | 10 #include "SkBlurMask.h" |
(...skipping 17 matching lines...) Expand all Loading... |
28 | 28 |
29 SkMaskFilter* SkBlurMaskFilter::CreateEmboss(const SkScalar direction[3], | 29 SkMaskFilter* SkBlurMaskFilter::CreateEmboss(const SkScalar direction[3], |
30 SkScalar ambient, SkScalar specular
, | 30 SkScalar ambient, SkScalar specular
, |
31 SkScalar blurRadius) { | 31 SkScalar blurRadius) { |
32 return SkBlurMaskFilter::CreateEmboss(SkBlurMask::ConvertRadiusToSigma(blurR
adius), | 32 return SkBlurMaskFilter::CreateEmboss(SkBlurMask::ConvertRadiusToSigma(blurR
adius), |
33 direction, ambient, specular); | 33 direction, ambient, specular); |
34 } | 34 } |
35 | 35 |
36 SkMaskFilter* SkBlurMaskFilter::CreateEmboss(SkScalar blurSigma, const SkScalar
direction[3], | 36 SkMaskFilter* SkBlurMaskFilter::CreateEmboss(SkScalar blurSigma, const SkScalar
direction[3], |
37 SkScalar ambient, SkScalar specular
) { | 37 SkScalar ambient, SkScalar specular
) { |
38 if (direction == NULL) { | 38 if (direction == nullptr) { |
39 return NULL; | 39 return nullptr; |
40 } | 40 } |
41 | 41 |
42 // ambient should be 0...1 as a scalar | 42 // ambient should be 0...1 as a scalar |
43 int am = pin2byte(SkScalarToFixed(ambient) >> 8); | 43 int am = pin2byte(SkScalarToFixed(ambient) >> 8); |
44 | 44 |
45 // specular should be 0..15.99 as a scalar | 45 // specular should be 0..15.99 as a scalar |
46 int sp = pin2byte(SkScalarToFixed(specular) >> 12); | 46 int sp = pin2byte(SkScalarToFixed(specular) >> 12); |
47 | 47 |
48 SkEmbossMaskFilter::Light light; | 48 SkEmbossMaskFilter::Light light; |
49 | 49 |
(...skipping 30 matching lines...) Expand all Loading... |
80 | 80 |
81 if (!SkBlurMask::BoxBlur(dst, src, sigma, kInner_SkBlurStyle, kLow_SkBlurQua
lity)) { | 81 if (!SkBlurMask::BoxBlur(dst, src, sigma, kInner_SkBlurStyle, kLow_SkBlurQua
lity)) { |
82 return false; | 82 return false; |
83 } | 83 } |
84 | 84 |
85 dst->fFormat = SkMask::k3D_Format; | 85 dst->fFormat = SkMask::k3D_Format; |
86 if (margin) { | 86 if (margin) { |
87 margin->set(SkScalarCeilToInt(3*sigma), SkScalarCeilToInt(3*sigma)); | 87 margin->set(SkScalarCeilToInt(3*sigma), SkScalarCeilToInt(3*sigma)); |
88 } | 88 } |
89 | 89 |
90 if (src.fImage == NULL) { | 90 if (src.fImage == nullptr) { |
91 return true; | 91 return true; |
92 } | 92 } |
93 | 93 |
94 // create a larger buffer for the other two channels (should force fBlur to
do this for us) | 94 // create a larger buffer for the other two channels (should force fBlur to
do this for us) |
95 | 95 |
96 { | 96 { |
97 uint8_t* alphaPlane = dst->fImage; | 97 uint8_t* alphaPlane = dst->fImage; |
98 size_t planeSize = dst->computeImageSize(); | 98 size_t planeSize = dst->computeImageSize(); |
99 if (0 == planeSize) { | 99 if (0 == planeSize) { |
100 return false; // too big to allocate, abort | 100 return false; // too big to allocate, abort |
(...skipping 23 matching lines...) Expand all Loading... |
124 return true; | 124 return true; |
125 } | 125 } |
126 | 126 |
127 SkFlattenable* SkEmbossMaskFilter::CreateProc(SkReadBuffer& buffer) { | 127 SkFlattenable* SkEmbossMaskFilter::CreateProc(SkReadBuffer& buffer) { |
128 Light light; | 128 Light light; |
129 if (buffer.readByteArray(&light, sizeof(Light))) { | 129 if (buffer.readByteArray(&light, sizeof(Light))) { |
130 light.fPad = 0; // for the font-cache lookup to be clean | 130 light.fPad = 0; // for the font-cache lookup to be clean |
131 const SkScalar sigma = buffer.readScalar(); | 131 const SkScalar sigma = buffer.readScalar(); |
132 return Create(sigma, light); | 132 return Create(sigma, light); |
133 } | 133 } |
134 return NULL; | 134 return nullptr; |
135 } | 135 } |
136 | 136 |
137 void SkEmbossMaskFilter::flatten(SkWriteBuffer& buffer) const { | 137 void SkEmbossMaskFilter::flatten(SkWriteBuffer& buffer) const { |
138 Light tmpLight = fLight; | 138 Light tmpLight = fLight; |
139 tmpLight.fPad = 0; // for the font-cache lookup to be clean | 139 tmpLight.fPad = 0; // for the font-cache lookup to be clean |
140 buffer.writeByteArray(&tmpLight, sizeof(tmpLight)); | 140 buffer.writeByteArray(&tmpLight, sizeof(tmpLight)); |
141 buffer.writeScalar(fBlurSigma); | 141 buffer.writeScalar(fBlurSigma); |
142 } | 142 } |
143 | 143 |
144 #ifndef SK_IGNORE_TO_STRING | 144 #ifndef SK_IGNORE_TO_STRING |
145 void SkEmbossMaskFilter::toString(SkString* str) const { | 145 void SkEmbossMaskFilter::toString(SkString* str) const { |
146 str->append("SkEmbossMaskFilter: ("); | 146 str->append("SkEmbossMaskFilter: ("); |
147 | 147 |
148 str->append("direction: ("); | 148 str->append("direction: ("); |
149 str->appendScalar(fLight.fDirection[0]); | 149 str->appendScalar(fLight.fDirection[0]); |
150 str->append(", "); | 150 str->append(", "); |
151 str->appendScalar(fLight.fDirection[1]); | 151 str->appendScalar(fLight.fDirection[1]); |
152 str->append(", "); | 152 str->append(", "); |
153 str->appendScalar(fLight.fDirection[2]); | 153 str->appendScalar(fLight.fDirection[2]); |
154 str->append(") "); | 154 str->append(") "); |
155 | 155 |
156 str->appendf("ambient: %d specular: %d ", | 156 str->appendf("ambient: %d specular: %d ", |
157 fLight.fAmbient, fLight.fSpecular); | 157 fLight.fAmbient, fLight.fSpecular); |
158 | 158 |
159 str->append("blurSigma: "); | 159 str->append("blurSigma: "); |
160 str->appendScalar(fBlurSigma); | 160 str->appendScalar(fBlurSigma); |
161 str->append(")"); | 161 str->append(")"); |
162 } | 162 } |
163 #endif | 163 #endif |
OLD | NEW |