| OLD | NEW |
| 1 | 1 |
| 2 /* | 2 /* |
| 3 * Copyright 2006 The Android Open Source Project | 3 * Copyright 2006 The Android Open Source Project |
| 4 * | 4 * |
| 5 * Use of this source code is governed by a BSD-style license that can be | 5 * Use of this source code is governed by a BSD-style license that can be |
| 6 * found in the LICENSE file. | 6 * found in the LICENSE file. |
| 7 */ | 7 */ |
| 8 | 8 |
| 9 | 9 |
| 10 #include "SkEmbossMaskFilter.h" | 10 #include "SkEmbossMaskFilter.h" |
| (...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 42 | 42 |
| 43 // specular should be 0..15.99 as a scalar | 43 // specular should be 0..15.99 as a scalar |
| 44 int sp = pin2byte(SkScalarToFixed(specular) >> 12); | 44 int sp = pin2byte(SkScalarToFixed(specular) >> 12); |
| 45 | 45 |
| 46 SkEmbossMaskFilter::Light light; | 46 SkEmbossMaskFilter::Light light; |
| 47 | 47 |
| 48 memcpy(light.fDirection, direction, sizeof(light.fDirection)); | 48 memcpy(light.fDirection, direction, sizeof(light.fDirection)); |
| 49 light.fAmbient = SkToU8(am); | 49 light.fAmbient = SkToU8(am); |
| 50 light.fSpecular = SkToU8(sp); | 50 light.fSpecular = SkToU8(sp); |
| 51 | 51 |
| 52 return SkNEW_ARGS(SkEmbossMaskFilter, (blurSigma, light)); | 52 return SkEmbossMaskFilter::Create(blurSigma, light); |
| 53 } | 53 } |
| 54 | 54 |
| 55 /////////////////////////////////////////////////////////////////////////////// | 55 /////////////////////////////////////////////////////////////////////////////// |
| 56 | 56 |
| 57 static void normalize(SkScalar v[3]) { | 57 static void normalize(SkScalar v[3]) { |
| 58 SkScalar mag = SkScalarSquare(v[0]) + SkScalarSquare(v[1]) + SkScalarSquare(
v[2]); | 58 SkScalar mag = SkScalarSquare(v[0]) + SkScalarSquare(v[1]) + SkScalarSquare(
v[2]); |
| 59 mag = SkScalarSqrt(mag); | 59 mag = SkScalarSqrt(mag); |
| 60 | 60 |
| 61 for (int i = 0; i < 3; i++) { | 61 for (int i = 0; i < 3; i++) { |
| 62 v[i] = SkScalarDiv(v[i], mag); | 62 v[i] = SkScalarDiv(v[i], mag); |
| 63 } | 63 } |
| 64 } | 64 } |
| 65 | 65 |
| 66 SkEmbossMaskFilter::SkEmbossMaskFilter(SkScalar blurSigma, const Light& light) | 66 SkEmbossMaskFilter::SkEmbossMaskFilter(SkScalar blurSigma, const Light& light) |
| 67 : fLight(light), fBlurSigma(blurSigma) { | 67 : fLight(light), fBlurSigma(blurSigma) { |
| 68 normalize(fLight.fDirection); | 68 normalize(fLight.fDirection); |
| 69 } | 69 } |
| 70 | 70 |
| 71 SkEmbossMaskFilter::SkEmbossMaskFilter(const Light& light, SkScalar blurRadius) | |
| 72 : fLight(light) { | |
| 73 normalize(fLight.fDirection); | |
| 74 | |
| 75 fBlurSigma = SkBlurMask::ConvertRadiusToSigma(blurRadius); | |
| 76 } | |
| 77 | |
| 78 SkMask::Format SkEmbossMaskFilter::getFormat() const { | 71 SkMask::Format SkEmbossMaskFilter::getFormat() const { |
| 79 return SkMask::k3D_Format; | 72 return SkMask::k3D_Format; |
| 80 } | 73 } |
| 81 | 74 |
| 82 bool SkEmbossMaskFilter::filterMask(SkMask* dst, const SkMask& src, | 75 bool SkEmbossMaskFilter::filterMask(SkMask* dst, const SkMask& src, |
| 83 const SkMatrix& matrix, SkIPoint* margin) co
nst { | 76 const SkMatrix& matrix, SkIPoint* margin) co
nst { |
| 84 SkScalar sigma = matrix.mapRadius(fBlurSigma); | 77 SkScalar sigma = matrix.mapRadius(fBlurSigma); |
| 85 | 78 |
| 86 if (!SkBlurMask::BoxBlur(dst, src, sigma, SkBlurMask::kInner_Style, | 79 if (!SkBlurMask::BoxBlur(dst, src, sigma, SkBlurMask::kInner_Style, |
| 87 SkBlurMask::kLow_Quality)) { | 80 SkBlurMask::kLow_Quality)) { |
| (...skipping 72 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 160 str->append(") "); | 153 str->append(") "); |
| 161 | 154 |
| 162 str->appendf("ambient: %d specular: %d ", | 155 str->appendf("ambient: %d specular: %d ", |
| 163 fLight.fAmbient, fLight.fSpecular); | 156 fLight.fAmbient, fLight.fSpecular); |
| 164 | 157 |
| 165 str->append("blurSigma: "); | 158 str->append("blurSigma: "); |
| 166 str->appendScalar(fBlurSigma); | 159 str->appendScalar(fBlurSigma); |
| 167 str->append(")"); | 160 str->append(")"); |
| 168 } | 161 } |
| 169 #endif | 162 #endif |
| OLD | NEW |