| Index: src/gpu/effects/GrOvalEffect.cpp
|
| diff --git a/src/gpu/effects/GrOvalEffect.cpp b/src/gpu/effects/GrOvalEffect.cpp
|
| index 65f188e9083caf29f575469e2eecff57007878d6..369b78042c770f9a558fd7243c033c250808ed98 100644
|
| --- a/src/gpu/effects/GrOvalEffect.cpp
|
| +++ b/src/gpu/effects/GrOvalEffect.cpp
|
| @@ -71,7 +71,7 @@
|
| }
|
|
|
| bool CircleEffect::onIsEqual(const GrEffect& other) const {
|
| - const CircleEffect& ce = other.cast<CircleEffect>();
|
| + const CircleEffect& ce = CastEffect<CircleEffect>(other);
|
| return fEdgeType == ce.fEdgeType && fCenter == ce.fCenter && fRadius == ce.fRadius;
|
| }
|
|
|
| @@ -98,19 +98,19 @@
|
|
|
| class GLCircleEffect : public GrGLEffect {
|
| public:
|
| - GLCircleEffect(const GrBackendEffectFactory&, const GrEffect&);
|
| + GLCircleEffect(const GrBackendEffectFactory&, const GrDrawEffect&);
|
|
|
| virtual void emitCode(GrGLProgramBuilder* builder,
|
| - const GrEffect& effect,
|
| + const GrDrawEffect& drawEffect,
|
| const GrEffectKey& key,
|
| const char* outputColor,
|
| const char* inputColor,
|
| const TransformedCoordsArray&,
|
| const TextureSamplerArray&) SK_OVERRIDE;
|
|
|
| - static inline void GenKey(const GrEffect&, const GrGLCaps&, GrEffectKeyBuilder*);
|
| -
|
| - virtual void setData(const GrGLProgramDataManager&, const GrEffect&) SK_OVERRIDE;
|
| + static inline void GenKey(const GrDrawEffect&, const GrGLCaps&, GrEffectKeyBuilder*);
|
| +
|
| + virtual void setData(const GrGLProgramDataManager&, const GrDrawEffect&) SK_OVERRIDE;
|
|
|
| private:
|
| GrGLProgramDataManager::UniformHandle fCircleUniform;
|
| @@ -121,19 +121,19 @@
|
| };
|
|
|
| GLCircleEffect::GLCircleEffect(const GrBackendEffectFactory& factory,
|
| - const GrEffect& effect)
|
| + const GrDrawEffect& drawEffect)
|
| : INHERITED (factory) {
|
| fPrevRadius = -1.f;
|
| }
|
|
|
| void GLCircleEffect::emitCode(GrGLProgramBuilder* builder,
|
| - const GrEffect& effect,
|
| + const GrDrawEffect& drawEffect,
|
| const GrEffectKey& key,
|
| const char* outputColor,
|
| const char* inputColor,
|
| const TransformedCoordsArray&,
|
| const TextureSamplerArray& samplers) {
|
| - const CircleEffect& ce = effect.cast<CircleEffect>();
|
| + const CircleEffect& ce = drawEffect.castEffect<CircleEffect>();
|
| const char *circleName;
|
| // The circle uniform is (center.x, center.y, radius + 0.5) for regular fills and
|
| // (... ,radius - 0.5) for inverse fills.
|
| @@ -163,14 +163,14 @@
|
| (GrGLSLExpr4(inputColor) * GrGLSLExpr1("d")).c_str());
|
| }
|
|
|
| -void GLCircleEffect::GenKey(const GrEffect& effect, const GrGLCaps&,
|
| +void GLCircleEffect::GenKey(const GrDrawEffect& drawEffect, const GrGLCaps&,
|
| GrEffectKeyBuilder* b) {
|
| - const CircleEffect& ce = effect.cast<CircleEffect>();
|
| + const CircleEffect& ce = drawEffect.castEffect<CircleEffect>();
|
| b->add32(ce.getEdgeType());
|
| }
|
|
|
| -void GLCircleEffect::setData(const GrGLProgramDataManager& pdman, const GrEffect& effect) {
|
| - const CircleEffect& ce = effect.cast<CircleEffect>();
|
| +void GLCircleEffect::setData(const GrGLProgramDataManager& pdman, const GrDrawEffect& drawEffect) {
|
| + const CircleEffect& ce = drawEffect.castEffect<CircleEffect>();
|
| if (ce.getRadius() != fPrevRadius || ce.getCenter() != fPrevCenter) {
|
| SkScalar radius = ce.getRadius();
|
| if (GrEffectEdgeTypeIsInverseFill(ce.getEdgeType())) {
|
| @@ -244,7 +244,7 @@
|
| }
|
|
|
| bool EllipseEffect::onIsEqual(const GrEffect& other) const {
|
| - const EllipseEffect& ee = other.cast<EllipseEffect>();
|
| + const EllipseEffect& ee = CastEffect<EllipseEffect>(other);
|
| return fEdgeType == ee.fEdgeType && fCenter == ee.fCenter && fRadii == ee.fRadii;
|
| }
|
|
|
| @@ -272,19 +272,19 @@
|
|
|
| class GLEllipseEffect : public GrGLEffect {
|
| public:
|
| - GLEllipseEffect(const GrBackendEffectFactory&, const GrEffect&);
|
| + GLEllipseEffect(const GrBackendEffectFactory&, const GrDrawEffect&);
|
|
|
| virtual void emitCode(GrGLProgramBuilder* builder,
|
| - const GrEffect& effect,
|
| + const GrDrawEffect& drawEffect,
|
| const GrEffectKey& key,
|
| const char* outputColor,
|
| const char* inputColor,
|
| const TransformedCoordsArray&,
|
| const TextureSamplerArray&) SK_OVERRIDE;
|
|
|
| - static inline void GenKey(const GrEffect&, const GrGLCaps&, GrEffectKeyBuilder*);
|
| -
|
| - virtual void setData(const GrGLProgramDataManager&, const GrEffect&) SK_OVERRIDE;
|
| + static inline void GenKey(const GrDrawEffect&, const GrGLCaps&, GrEffectKeyBuilder*);
|
| +
|
| + virtual void setData(const GrGLProgramDataManager&, const GrDrawEffect&) SK_OVERRIDE;
|
|
|
| private:
|
| GrGLProgramDataManager::UniformHandle fEllipseUniform;
|
| @@ -295,19 +295,19 @@
|
| };
|
|
|
| GLEllipseEffect::GLEllipseEffect(const GrBackendEffectFactory& factory,
|
| - const GrEffect& effect)
|
| + const GrDrawEffect& drawEffect)
|
| : INHERITED (factory) {
|
| fPrevRadii.fX = -1.f;
|
| }
|
|
|
| void GLEllipseEffect::emitCode(GrGLProgramBuilder* builder,
|
| - const GrEffect& effect,
|
| + const GrDrawEffect& drawEffect,
|
| const GrEffectKey& key,
|
| const char* outputColor,
|
| const char* inputColor,
|
| const TransformedCoordsArray&,
|
| const TextureSamplerArray& samplers) {
|
| - const EllipseEffect& ee = effect.cast<EllipseEffect>();
|
| + const EllipseEffect& ee = drawEffect.castEffect<EllipseEffect>();
|
| const char *ellipseName;
|
| // The ellipse uniform is (center.x, center.y, 1 / rx^2, 1 / ry^2)
|
| fEllipseUniform = builder->addUniform(GrGLProgramBuilder::kFragment_Visibility,
|
| @@ -350,14 +350,14 @@
|
| (GrGLSLExpr4(inputColor) * GrGLSLExpr1("alpha")).c_str());
|
| }
|
|
|
| -void GLEllipseEffect::GenKey(const GrEffect& effect, const GrGLCaps&,
|
| +void GLEllipseEffect::GenKey(const GrDrawEffect& drawEffect, const GrGLCaps&,
|
| GrEffectKeyBuilder* b) {
|
| - const EllipseEffect& ee = effect.cast<EllipseEffect>();
|
| + const EllipseEffect& ee = drawEffect.castEffect<EllipseEffect>();
|
| b->add32(ee.getEdgeType());
|
| }
|
|
|
| -void GLEllipseEffect::setData(const GrGLProgramDataManager& pdman, const GrEffect& effect) {
|
| - const EllipseEffect& ee = effect.cast<EllipseEffect>();
|
| +void GLEllipseEffect::setData(const GrGLProgramDataManager& pdman, const GrDrawEffect& drawEffect) {
|
| + const EllipseEffect& ee = drawEffect.castEffect<EllipseEffect>();
|
| if (ee.getRadii() != fPrevRadii || ee.getCenter() != fPrevCenter) {
|
| SkScalar invRXSqd = 1.f / (ee.getRadii().fX * ee.getRadii().fX);
|
| SkScalar invRYSqd = 1.f / (ee.getRadii().fY * ee.getRadii().fY);
|
|
|