| OLD | NEW |
| 1 | 1 |
| 2 /* | 2 /* |
| 3 * Copyright 2012 Google Inc. | 3 * Copyright 2012 Google Inc. |
| 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 #include "SkSweepGradient.h" | 9 #include "SkSweepGradient.h" |
| 10 | 10 |
| (...skipping 168 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 179 | 179 |
| 180 class GrGLSweepGradient : public GrGLGradientEffect { | 180 class GrGLSweepGradient : public GrGLGradientEffect { |
| 181 public: | 181 public: |
| 182 | 182 |
| 183 GrGLSweepGradient(const GrBackendEffectFactory& factory, | 183 GrGLSweepGradient(const GrBackendEffectFactory& factory, |
| 184 const GrDrawEffect&) : INHERITED (factory) { } | 184 const GrDrawEffect&) : INHERITED (factory) { } |
| 185 virtual ~GrGLSweepGradient() { } | 185 virtual ~GrGLSweepGradient() { } |
| 186 | 186 |
| 187 virtual void emitCode(GrGLShaderBuilder*, | 187 virtual void emitCode(GrGLShaderBuilder*, |
| 188 const GrDrawEffect&, | 188 const GrDrawEffect&, |
| 189 EffectKey, | 189 const GrEffectKey&, |
| 190 const char* outputColor, | 190 const char* outputColor, |
| 191 const char* inputColor, | 191 const char* inputColor, |
| 192 const TransformedCoordsArray&, | 192 const TransformedCoordsArray&, |
| 193 const TextureSamplerArray&) SK_OVERRIDE; | 193 const TextureSamplerArray&) SK_OVERRIDE; |
| 194 | 194 |
| 195 static EffectKey GenKey(const GrDrawEffect& drawEffect, const GrGLCaps&) { | 195 static void GenKey(const GrDrawEffect& drawEffect, const GrGLCaps&, GrEffect
KeyBuilder* b) { |
| 196 return GenBaseGradientKey(drawEffect); | 196 b->add32(GenBaseGradientKey(drawEffect)); |
| 197 } | 197 } |
| 198 | 198 |
| 199 private: | 199 private: |
| 200 | 200 |
| 201 typedef GrGLGradientEffect INHERITED; | 201 typedef GrGLGradientEffect INHERITED; |
| 202 | 202 |
| 203 }; | 203 }; |
| 204 | 204 |
| 205 ///////////////////////////////////////////////////////////////////// | 205 ///////////////////////////////////////////////////////////////////// |
| 206 | 206 |
| (...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 249 GrEffect* effect; | 249 GrEffect* effect; |
| 250 GrColor paintColor; | 250 GrColor paintColor; |
| 251 SkAssertResult(shader->asNewEffect(context, paint, NULL, &paintColor, &effec
t)); | 251 SkAssertResult(shader->asNewEffect(context, paint, NULL, &paintColor, &effec
t)); |
| 252 return effect; | 252 return effect; |
| 253 } | 253 } |
| 254 | 254 |
| 255 ///////////////////////////////////////////////////////////////////// | 255 ///////////////////////////////////////////////////////////////////// |
| 256 | 256 |
| 257 void GrGLSweepGradient::emitCode(GrGLShaderBuilder* builder, | 257 void GrGLSweepGradient::emitCode(GrGLShaderBuilder* builder, |
| 258 const GrDrawEffect&, | 258 const GrDrawEffect&, |
| 259 EffectKey key, | 259 const GrEffectKey& key, |
| 260 const char* outputColor, | 260 const char* outputColor, |
| 261 const char* inputColor, | 261 const char* inputColor, |
| 262 const TransformedCoordsArray& coords, | 262 const TransformedCoordsArray& coords, |
| 263 const TextureSamplerArray& samplers) { | 263 const TextureSamplerArray& samplers) { |
| 264 this->emitUniforms(builder, key); | 264 uint32_t baseKey = key.get32(0); |
| 265 this->emitUniforms(builder, baseKey); |
| 265 SkString coords2D = builder->ensureFSCoords2D(coords, 0); | 266 SkString coords2D = builder->ensureFSCoords2D(coords, 0); |
| 266 const GrGLContextInfo ctxInfo = builder->ctxInfo(); | 267 const GrGLContextInfo ctxInfo = builder->ctxInfo(); |
| 267 SkString t; | 268 SkString t; |
| 268 // 0.1591549430918 is 1/(2*pi), used since atan returns values [-pi, pi] | 269 // 0.1591549430918 is 1/(2*pi), used since atan returns values [-pi, pi] |
| 269 // On Intel GPU there is an issue where it reads the second arguement to ata
n "- %s.x" as an int | 270 // On Intel GPU there is an issue where it reads the second arguement to ata
n "- %s.x" as an int |
| 270 // thus must us -1.0 * %s.x to work correctly | 271 // thus must us -1.0 * %s.x to work correctly |
| 271 if (kIntel_GrGLVendor != ctxInfo.vendor()){ | 272 if (kIntel_GrGLVendor != ctxInfo.vendor()){ |
| 272 t.printf("atan(- %s.y, - %s.x) * 0.1591549430918 + 0.5", | 273 t.printf("atan(- %s.y, - %s.x) * 0.1591549430918 + 0.5", |
| 273 coords2D.c_str(), coords2D.c_str()); | 274 coords2D.c_str(), coords2D.c_str()); |
| 274 } else { | 275 } else { |
| 275 t.printf("atan(- %s.y, -1.0 * %s.x) * 0.1591549430918 + 0.5", | 276 t.printf("atan(- %s.y, -1.0 * %s.x) * 0.1591549430918 + 0.5", |
| 276 coords2D.c_str(), coords2D.c_str()); | 277 coords2D.c_str(), coords2D.c_str()); |
| 277 } | 278 } |
| 278 this->emitColor(builder, t.c_str(), key, | 279 this->emitColor(builder, t.c_str(), baseKey, outputColor, inputColor, sample
rs); |
| 279 outputColor, inputColor, samplers); | |
| 280 } | 280 } |
| 281 | 281 |
| 282 ///////////////////////////////////////////////////////////////////// | 282 ///////////////////////////////////////////////////////////////////// |
| 283 | 283 |
| 284 bool SkSweepGradient::asNewEffect(GrContext* context, const SkPaint& paint, | 284 bool SkSweepGradient::asNewEffect(GrContext* context, const SkPaint& paint, |
| 285 const SkMatrix* localMatrix, GrColor* paintCol
or, | 285 const SkMatrix* localMatrix, GrColor* paintCol
or, |
| 286 GrEffect** effect) const { | 286 GrEffect** effect) const { |
| 287 | 287 |
| 288 SkMatrix matrix; | 288 SkMatrix matrix; |
| 289 if (!this->getLocalMatrix().invert(&matrix)) { | 289 if (!this->getLocalMatrix().invert(&matrix)) { |
| (...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 323 str->appendScalar(fCenter.fX); | 323 str->appendScalar(fCenter.fX); |
| 324 str->append(", "); | 324 str->append(", "); |
| 325 str->appendScalar(fCenter.fY); | 325 str->appendScalar(fCenter.fY); |
| 326 str->append(") "); | 326 str->append(") "); |
| 327 | 327 |
| 328 this->INHERITED::toString(str); | 328 this->INHERITED::toString(str); |
| 329 | 329 |
| 330 str->append(")"); | 330 str->append(")"); |
| 331 } | 331 } |
| 332 #endif | 332 #endif |
| OLD | NEW |