Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(68)

Side by Side Diff: src/effects/SkMorphologyImageFilter.cpp

Issue 608253002: Add isSingleComponent bool to getConstantColorComponent (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: Fix isSolidWhite Created 6 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « src/effects/SkMagnifierImageFilter.cpp ('k') | src/effects/SkPerlinNoiseShader.cpp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright 2012 The Android Open Source Project 2 * Copyright 2012 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 "SkMorphologyImageFilter.h" 8 #include "SkMorphologyImageFilter.h"
9 #include "SkBitmap.h" 9 #include "SkBitmap.h"
10 #include "SkColorPriv.h" 10 #include "SkColorPriv.h"
(...skipping 291 matching lines...) Expand 10 before | Expand all | Expand 10 after
302 302
303 virtual ~GrMorphologyEffect(); 303 virtual ~GrMorphologyEffect();
304 304
305 MorphologyType type() const { return fType; } 305 MorphologyType type() const { return fType; }
306 306
307 static const char* Name() { return "Morphology"; } 307 static const char* Name() { return "Morphology"; }
308 308
309 typedef GrGLMorphologyEffect GLProcessor; 309 typedef GrGLMorphologyEffect GLProcessor;
310 310
311 virtual const GrBackendFragmentProcessorFactory& getFactory() const SK_OVERR IDE; 311 virtual const GrBackendFragmentProcessorFactory& getFactory() const SK_OVERR IDE;
312 virtual void getConstantColorComponents(GrColor* color, uint32_t* validFlags ) const SK_OVERRIDE;
313 312
314 protected: 313 protected:
315 314
316 MorphologyType fType; 315 MorphologyType fType;
317 316
318 private: 317 private:
319 virtual bool onIsEqual(const GrProcessor&) const SK_OVERRIDE; 318 virtual bool onIsEqual(const GrProcessor&) const SK_OVERRIDE;
320 319
320 virtual void onComputeInvariantOutput(InvariantOutput* inout) const SK_OVERR IDE;
321
321 GrMorphologyEffect(GrTexture*, Direction, int radius, MorphologyType); 322 GrMorphologyEffect(GrTexture*, Direction, int radius, MorphologyType);
322 323
323 GR_DECLARE_FRAGMENT_PROCESSOR_TEST; 324 GR_DECLARE_FRAGMENT_PROCESSOR_TEST;
324 325
325 typedef Gr1DKernelEffect INHERITED; 326 typedef Gr1DKernelEffect INHERITED;
326 }; 327 };
327 328
328 /////////////////////////////////////////////////////////////////////////////// 329 ///////////////////////////////////////////////////////////////////////////////
329 330
330 class GrGLMorphologyEffect : public GrGLFragmentProcessor { 331 class GrGLMorphologyEffect : public GrGLFragmentProcessor {
(...skipping 117 matching lines...) Expand 10 before | Expand all | Expand 10 after
448 } 449 }
449 450
450 bool GrMorphologyEffect::onIsEqual(const GrProcessor& sBase) const { 451 bool GrMorphologyEffect::onIsEqual(const GrProcessor& sBase) const {
451 const GrMorphologyEffect& s = sBase.cast<GrMorphologyEffect>(); 452 const GrMorphologyEffect& s = sBase.cast<GrMorphologyEffect>();
452 return (this->texture(0) == s.texture(0) && 453 return (this->texture(0) == s.texture(0) &&
453 this->radius() == s.radius() && 454 this->radius() == s.radius() &&
454 this->direction() == s.direction() && 455 this->direction() == s.direction() &&
455 this->type() == s.type()); 456 this->type() == s.type());
456 } 457 }
457 458
458 void GrMorphologyEffect::getConstantColorComponents(GrColor* color, uint32_t* va lidFlags) const { 459 void GrMorphologyEffect::onComputeInvariantOutput(InvariantOutput* inout) const {
459 // This is valid because the color components of the result of the kernel al l come 460 // This is valid because the color components of the result of the kernel al l come
460 // exactly from existing values in the source texture. 461 // exactly from existing values in the source texture.
461 this->updateConstantColorComponentsForModulation(color, validFlags); 462 this->updateInvariantOutputForModulation(inout);
463 inout->fIsSingleComponent = false;
462 } 464 }
463 465
464 /////////////////////////////////////////////////////////////////////////////// 466 ///////////////////////////////////////////////////////////////////////////////
465 467
466 GR_DEFINE_FRAGMENT_PROCESSOR_TEST(GrMorphologyEffect); 468 GR_DEFINE_FRAGMENT_PROCESSOR_TEST(GrMorphologyEffect);
467 469
468 GrFragmentProcessor* GrMorphologyEffect::TestCreate(SkRandom* random, 470 GrFragmentProcessor* GrMorphologyEffect::TestCreate(SkRandom* random,
469 GrContext*, 471 GrContext*,
470 const GrDrawTargetCaps&, 472 const GrDrawTargetCaps&,
471 GrTexture* textures[]) { 473 GrTexture* textures[]) {
(...skipping 130 matching lines...) Expand 10 before | Expand all | Expand 10 after
602 SkBitmap* result, SkIPoint* offset) con st { 604 SkBitmap* result, SkIPoint* offset) con st {
603 return this->filterImageGPUGeneric(true, proxy, src, ctx, result, offset); 605 return this->filterImageGPUGeneric(true, proxy, src, ctx, result, offset);
604 } 606 }
605 607
606 bool SkErodeImageFilter::filterImageGPU(Proxy* proxy, const SkBitmap& src, const Context& ctx, 608 bool SkErodeImageFilter::filterImageGPU(Proxy* proxy, const SkBitmap& src, const Context& ctx,
607 SkBitmap* result, SkIPoint* offset) cons t { 609 SkBitmap* result, SkIPoint* offset) cons t {
608 return this->filterImageGPUGeneric(false, proxy, src, ctx, result, offset); 610 return this->filterImageGPUGeneric(false, proxy, src, ctx, result, offset);
609 } 611 }
610 612
611 #endif 613 #endif
OLDNEW
« no previous file with comments | « src/effects/SkMagnifierImageFilter.cpp ('k') | src/effects/SkPerlinNoiseShader.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698