| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2013 Google Inc. | 2 * Copyright 2013 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 "SkAlphaThresholdFilter.h" | 8 #include "SkAlphaThresholdFilter.h" |
| 9 #include "SkBitmap.h" | 9 #include "SkBitmap.h" |
| 10 #include "SkReadBuffer.h" | 10 #include "SkReadBuffer.h" |
| (...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 74 outerThreshold)); | 74 outerThreshold)); |
| 75 } | 75 } |
| 76 | 76 |
| 77 virtual ~AlphaThresholdEffect() {}; | 77 virtual ~AlphaThresholdEffect() {}; |
| 78 | 78 |
| 79 const char* name() const override { return "Alpha Threshold"; } | 79 const char* name() const override { return "Alpha Threshold"; } |
| 80 | 80 |
| 81 float innerThreshold() const { return fInnerThreshold; } | 81 float innerThreshold() const { return fInnerThreshold; } |
| 82 float outerThreshold() const { return fOuterThreshold; } | 82 float outerThreshold() const { return fOuterThreshold; } |
| 83 | 83 |
| 84 GrGLFragmentProcessor* createGLInstance() const override; | |
| 85 | |
| 86 private: | 84 private: |
| 87 AlphaThresholdEffect(GrProcessorDataManager*, | 85 AlphaThresholdEffect(GrProcessorDataManager*, |
| 88 GrTexture* texture, | 86 GrTexture* texture, |
| 89 GrTexture* maskTexture, | 87 GrTexture* maskTexture, |
| 90 float innerThreshold, | 88 float innerThreshold, |
| 91 float outerThreshold) | 89 float outerThreshold) |
| 92 : fInnerThreshold(innerThreshold) | 90 : fInnerThreshold(innerThreshold) |
| 93 , fOuterThreshold(outerThreshold) | 91 , fOuterThreshold(outerThreshold) |
| 94 , fImageCoordTransform(kLocal_GrCoordSet, | 92 , fImageCoordTransform(kLocal_GrCoordSet, |
| 95 GrCoordTransform::MakeDivByTextureWHMatrix(textur
e), texture, | 93 GrCoordTransform::MakeDivByTextureWHMatrix(textur
e), texture, |
| 96 GrTextureParams::kNone_FilterMode) | 94 GrTextureParams::kNone_FilterMode) |
| 97 , fImageTextureAccess(texture) | 95 , fImageTextureAccess(texture) |
| 98 , fMaskCoordTransform(kLocal_GrCoordSet, | 96 , fMaskCoordTransform(kLocal_GrCoordSet, |
| 99 GrCoordTransform::MakeDivByTextureWHMatrix(maskTex
ture), maskTexture, | 97 GrCoordTransform::MakeDivByTextureWHMatrix(maskTex
ture), maskTexture, |
| 100 GrTextureParams::kNone_FilterMode) | 98 GrTextureParams::kNone_FilterMode) |
| 101 , fMaskTextureAccess(maskTexture) { | 99 , fMaskTextureAccess(maskTexture) { |
| 102 this->initClassID<AlphaThresholdEffect>(); | 100 this->initClassID<AlphaThresholdEffect>(); |
| 103 this->addCoordTransform(&fImageCoordTransform); | 101 this->addCoordTransform(&fImageCoordTransform); |
| 104 this->addTextureAccess(&fImageTextureAccess); | 102 this->addTextureAccess(&fImageTextureAccess); |
| 105 this->addCoordTransform(&fMaskCoordTransform); | 103 this->addCoordTransform(&fMaskCoordTransform); |
| 106 this->addTextureAccess(&fMaskTextureAccess); | 104 this->addTextureAccess(&fMaskTextureAccess); |
| 107 } | 105 } |
| 108 | 106 |
| 107 GrGLFragmentProcessor* onCreateGLInstance() const override; |
| 108 |
| 109 void onGetGLProcessorKey(const GrGLSLCaps&, GrProcessorKeyBuilder*) const ov
erride; | 109 void onGetGLProcessorKey(const GrGLSLCaps&, GrProcessorKeyBuilder*) const ov
erride; |
| 110 | 110 |
| 111 bool onIsEqual(const GrFragmentProcessor&) const override; | 111 bool onIsEqual(const GrFragmentProcessor&) const override; |
| 112 | 112 |
| 113 void onComputeInvariantOutput(GrInvariantOutput* inout) const override; | 113 void onComputeInvariantOutput(GrInvariantOutput* inout) const override; |
| 114 | 114 |
| 115 GR_DECLARE_FRAGMENT_PROCESSOR_TEST; | 115 GR_DECLARE_FRAGMENT_PROCESSOR_TEST; |
| 116 | 116 |
| 117 float fInnerThreshold; | 117 float fInnerThreshold; |
| 118 float fOuterThreshold; | 118 float fOuterThreshold; |
| 119 GrCoordTransform fImageCoordTransform; | 119 GrCoordTransform fImageCoordTransform; |
| 120 GrTextureAccess fImageTextureAccess; | 120 GrTextureAccess fImageTextureAccess; |
| 121 GrCoordTransform fMaskCoordTransform; | 121 GrCoordTransform fMaskCoordTransform; |
| 122 GrTextureAccess fMaskTextureAccess; | 122 GrTextureAccess fMaskTextureAccess; |
| 123 | 123 |
| 124 typedef GrFragmentProcessor INHERITED; | 124 typedef GrFragmentProcessor INHERITED; |
| 125 }; | 125 }; |
| 126 | 126 |
| 127 class GrGLAlphaThresholdEffect : public GrGLFragmentProcessor { | 127 class GrGLAlphaThresholdEffect : public GrGLFragmentProcessor { |
| 128 public: | 128 public: |
| 129 GrGLAlphaThresholdEffect(const GrFragmentProcessor&) {} | 129 GrGLAlphaThresholdEffect(const GrFragmentProcessor&) {} |
| 130 | 130 |
| 131 virtual void emitCode(EmitArgs&) override; | 131 virtual void emitCode(EmitArgs&) override; |
| 132 | 132 |
| 133 void setData(const GrGLProgramDataManager&, const GrProcessor&) override; | 133 protected: |
| 134 void onSetData(const GrGLProgramDataManager&, const GrProcessor&) override; |
| 134 | 135 |
| 135 private: | 136 private: |
| 136 | 137 |
| 137 GrGLProgramDataManager::UniformHandle fInnerThresholdVar; | 138 GrGLProgramDataManager::UniformHandle fInnerThresholdVar; |
| 138 GrGLProgramDataManager::UniformHandle fOuterThresholdVar; | 139 GrGLProgramDataManager::UniformHandle fOuterThresholdVar; |
| 139 | 140 |
| 140 typedef GrGLFragmentProcessor INHERITED; | 141 typedef GrGLFragmentProcessor INHERITED; |
| 141 }; | 142 }; |
| 142 | 143 |
| 143 void GrGLAlphaThresholdEffect::emitCode(EmitArgs& args) { | 144 void GrGLAlphaThresholdEffect::emitCode(EmitArgs& args) { |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 179 "\t\t} else if (color.a < inner_thresh) {\n" | 180 "\t\t} else if (color.a < inner_thresh) {\n" |
| 180 "\t\t\tfloat scale = inner_thresh / max(0.001, color.a
);\n" | 181 "\t\t\tfloat scale = inner_thresh / max(0.001, color.a
);\n" |
| 181 "\t\t\tcolor.rgb *= scale;\n" | 182 "\t\t\tcolor.rgb *= scale;\n" |
| 182 "\t\t\tcolor.a = inner_thresh;\n" | 183 "\t\t\tcolor.a = inner_thresh;\n" |
| 183 "\t\t}\n"); | 184 "\t\t}\n"); |
| 184 | 185 |
| 185 fsBuilder->codeAppendf("%s = %s;\n", args.fOutputColor, | 186 fsBuilder->codeAppendf("%s = %s;\n", args.fOutputColor, |
| 186 (GrGLSLExpr4(args.fInputColor) * GrGLSLExpr4("color")
).c_str()); | 187 (GrGLSLExpr4(args.fInputColor) * GrGLSLExpr4("color")
).c_str()); |
| 187 } | 188 } |
| 188 | 189 |
| 189 void GrGLAlphaThresholdEffect::setData(const GrGLProgramDataManager& pdman, | 190 void GrGLAlphaThresholdEffect::onSetData(const GrGLProgramDataManager& pdman, |
| 190 const GrProcessor& proc) { | 191 const GrProcessor& proc) { |
| 191 const AlphaThresholdEffect& alpha_threshold = proc.cast<AlphaThresholdEffect
>(); | 192 const AlphaThresholdEffect& alpha_threshold = proc.cast<AlphaThresholdEffect
>(); |
| 192 pdman.set1f(fInnerThresholdVar, alpha_threshold.innerThreshold()); | 193 pdman.set1f(fInnerThresholdVar, alpha_threshold.innerThreshold()); |
| 193 pdman.set1f(fOuterThresholdVar, alpha_threshold.outerThreshold()); | 194 pdman.set1f(fOuterThresholdVar, alpha_threshold.outerThreshold()); |
| 194 } | 195 } |
| 195 | 196 |
| 196 ///////////////////////////////////////////////////////////////////// | 197 ///////////////////////////////////////////////////////////////////// |
| 197 | 198 |
| 198 GR_DEFINE_FRAGMENT_PROCESSOR_TEST(AlphaThresholdEffect); | 199 GR_DEFINE_FRAGMENT_PROCESSOR_TEST(AlphaThresholdEffect); |
| 199 | 200 |
| 200 GrFragmentProcessor* AlphaThresholdEffect::TestCreate(GrProcessorTestData* d) { | 201 GrFragmentProcessor* AlphaThresholdEffect::TestCreate(GrProcessorTestData* d) { |
| 201 GrTexture* bmpTex = d->fTextures[GrProcessorUnitTest::kSkiaPMTextureIdx]; | 202 GrTexture* bmpTex = d->fTextures[GrProcessorUnitTest::kSkiaPMTextureIdx]; |
| 202 GrTexture* maskTex = d->fTextures[GrProcessorUnitTest::kAlphaTextureIdx]; | 203 GrTexture* maskTex = d->fTextures[GrProcessorUnitTest::kAlphaTextureIdx]; |
| 203 float innerThresh = d->fRandom->nextUScalar1(); | 204 float innerThresh = d->fRandom->nextUScalar1(); |
| 204 float outerThresh = d->fRandom->nextUScalar1(); | 205 float outerThresh = d->fRandom->nextUScalar1(); |
| 205 return AlphaThresholdEffect::Create(d->fProcDataManager, bmpTex, maskTex, in
nerThresh, | 206 return AlphaThresholdEffect::Create(d->fProcDataManager, bmpTex, maskTex, in
nerThresh, |
| 206 outerThresh); | 207 outerThresh); |
| 207 } | 208 } |
| 208 | 209 |
| 209 /////////////////////////////////////////////////////////////////////////////// | 210 /////////////////////////////////////////////////////////////////////////////// |
| 210 | 211 |
| 211 void AlphaThresholdEffect::onGetGLProcessorKey(const GrGLSLCaps& caps, | 212 void AlphaThresholdEffect::onGetGLProcessorKey(const GrGLSLCaps& caps, |
| 212 GrProcessorKeyBuilder* b) const { | 213 GrProcessorKeyBuilder* b) const { |
| 213 GrGLAlphaThresholdEffect::GenKey(*this, caps, b); | 214 GrGLAlphaThresholdEffect::GenKey(*this, caps, b); |
| 214 } | 215 } |
| 215 | 216 |
| 216 GrGLFragmentProcessor* AlphaThresholdEffect::createGLInstance() const { | 217 GrGLFragmentProcessor* AlphaThresholdEffect::onCreateGLInstance() const { |
| 217 return SkNEW_ARGS(GrGLAlphaThresholdEffect, (*this)); | 218 return SkNEW_ARGS(GrGLAlphaThresholdEffect, (*this)); |
| 218 } | 219 } |
| 219 | 220 |
| 220 bool AlphaThresholdEffect::onIsEqual(const GrFragmentProcessor& sBase) const { | 221 bool AlphaThresholdEffect::onIsEqual(const GrFragmentProcessor& sBase) const { |
| 221 const AlphaThresholdEffect& s = sBase.cast<AlphaThresholdEffect>(); | 222 const AlphaThresholdEffect& s = sBase.cast<AlphaThresholdEffect>(); |
| 222 return (this->fInnerThreshold == s.fInnerThreshold && | 223 return (this->fInnerThreshold == s.fInnerThreshold && |
| 223 this->fOuterThreshold == s.fOuterThreshold); | 224 this->fOuterThreshold == s.fOuterThreshold); |
| 224 } | 225 } |
| 225 | 226 |
| 226 void AlphaThresholdEffect::onComputeInvariantOutput(GrInvariantOutput* inout) co
nst { | 227 void AlphaThresholdEffect::onComputeInvariantOutput(GrInvariantOutput* inout) co
nst { |
| (...skipping 147 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 374 } | 375 } |
| 375 | 376 |
| 376 #ifndef SK_IGNORE_TO_STRING | 377 #ifndef SK_IGNORE_TO_STRING |
| 377 void SkAlphaThresholdFilterImpl::toString(SkString* str) const { | 378 void SkAlphaThresholdFilterImpl::toString(SkString* str) const { |
| 378 str->appendf("SkAlphaThresholdImageFilter: ("); | 379 str->appendf("SkAlphaThresholdImageFilter: ("); |
| 379 str->appendf("inner: %f outer: %f", fInnerThreshold, fOuterThreshold); | 380 str->appendf("inner: %f outer: %f", fInnerThreshold, fOuterThreshold); |
| 380 str->append(")"); | 381 str->append(")"); |
| 381 } | 382 } |
| 382 #endif | 383 #endif |
| 383 | 384 |
| OLD | NEW |