| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2015 Google Inc. | 2 * Copyright 2015 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 "SkTableColorFilter.h" | 8 #include "SkTableColorFilter.h" |
| 9 | 9 |
| 10 #include "SkBitmap.h" | 10 #include "SkBitmap.h" |
| (...skipping 402 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 413 pdm.set4fv(fRGBAYValuesUni, 1, rgbaYValues); | 413 pdm.set4fv(fRGBAYValuesUni, 1, rgbaYValues); |
| 414 } | 414 } |
| 415 | 415 |
| 416 void GLColorTableEffect::emitCode(EmitArgs& args) { | 416 void GLColorTableEffect::emitCode(EmitArgs& args) { |
| 417 const char* yoffsets; | 417 const char* yoffsets; |
| 418 fRGBAYValuesUni = args.fBuilder->addUniform(GrGLSLFPBuilder::kFragment_Visib
ility, | 418 fRGBAYValuesUni = args.fBuilder->addUniform(GrGLSLFPBuilder::kFragment_Visib
ility, |
| 419 kVec4f_GrSLType, kDefault_GrSLPr
ecision, | 419 kVec4f_GrSLType, kDefault_GrSLPr
ecision, |
| 420 "yoffsets", &yoffsets); | 420 "yoffsets", &yoffsets); |
| 421 static const float kColorScaleFactor = 255.0f / 256.0f; | 421 static const float kColorScaleFactor = 255.0f / 256.0f; |
| 422 static const float kColorOffsetFactor = 1.0f / 512.0f; | 422 static const float kColorOffsetFactor = 1.0f / 512.0f; |
| 423 GrGLSLFragmentBuilder* fsBuilder = args.fBuilder->getFragmentShaderBuilder()
; | 423 GrGLSLFragmentBuilder* fragBuilder = args.fFragBuilder; |
| 424 if (nullptr == args.fInputColor) { | 424 if (nullptr == args.fInputColor) { |
| 425 // the input color is solid white (all ones). | 425 // the input color is solid white (all ones). |
| 426 static const float kMaxValue = kColorScaleFactor + kColorOffsetFactor; | 426 static const float kMaxValue = kColorScaleFactor + kColorOffsetFactor; |
| 427 fsBuilder->codeAppendf("\t\tvec4 coord = vec4(%f, %f, %f, %f);\n", | 427 fragBuilder->codeAppendf("\t\tvec4 coord = vec4(%f, %f, %f, %f);\n", |
| 428 kMaxValue, kMaxValue, kMaxValue, kMaxValue); | 428 kMaxValue, kMaxValue, kMaxValue, kMaxValue); |
| 429 | 429 |
| 430 } else { | 430 } else { |
| 431 fsBuilder->codeAppendf("\t\tfloat nonZeroAlpha = max(%s.a, .0001);\n", a
rgs.fInputColor); | 431 fragBuilder->codeAppendf("\t\tfloat nonZeroAlpha = max(%s.a, .0001);\n",
args.fInputColor); |
| 432 fsBuilder->codeAppendf("\t\tvec4 coord = vec4(%s.rgb / nonZeroAlpha, non
ZeroAlpha);\n", | 432 fragBuilder->codeAppendf("\t\tvec4 coord = vec4(%s.rgb / nonZeroAlpha, n
onZeroAlpha);\n", |
| 433 args.fInputColor); | 433 args.fInputColor); |
| 434 fsBuilder->codeAppendf("\t\tcoord = coord * %f + vec4(%f, %f, %f, %f);\n
", | 434 fragBuilder->codeAppendf("\t\tcoord = coord * %f + vec4(%f, %f, %f, %f);
\n", |
| 435 kColorScaleFactor, | 435 kColorScaleFactor, |
| 436 kColorOffsetFactor, kColorOffsetFactor, | 436 kColorOffsetFactor, kColorOffsetFactor, |
| 437 kColorOffsetFactor, kColorOffsetFactor); | 437 kColorOffsetFactor, kColorOffsetFactor); |
| 438 } | 438 } |
| 439 | 439 |
| 440 SkString coord; | 440 SkString coord; |
| 441 | 441 |
| 442 fsBuilder->codeAppendf("\t\t%s.a = ", args.fOutputColor); | 442 fragBuilder->codeAppendf("\t\t%s.a = ", args.fOutputColor); |
| 443 coord.printf("vec2(coord.a, %s.a)", yoffsets); | 443 coord.printf("vec2(coord.a, %s.a)", yoffsets); |
| 444 fsBuilder->appendTextureLookup(args.fSamplers[0], coord.c_str()); | 444 fragBuilder->appendTextureLookup(args.fSamplers[0], coord.c_str()); |
| 445 fsBuilder->codeAppend(";\n"); | 445 fragBuilder->codeAppend(";\n"); |
| 446 | 446 |
| 447 fsBuilder->codeAppendf("\t\t%s.r = ", args.fOutputColor); | 447 fragBuilder->codeAppendf("\t\t%s.r = ", args.fOutputColor); |
| 448 coord.printf("vec2(coord.r, %s.r)", yoffsets); | 448 coord.printf("vec2(coord.r, %s.r)", yoffsets); |
| 449 fsBuilder->appendTextureLookup(args.fSamplers[0], coord.c_str()); | 449 fragBuilder->appendTextureLookup(args.fSamplers[0], coord.c_str()); |
| 450 fsBuilder->codeAppend(";\n"); | 450 fragBuilder->codeAppend(";\n"); |
| 451 | 451 |
| 452 fsBuilder->codeAppendf("\t\t%s.g = ", args.fOutputColor); | 452 fragBuilder->codeAppendf("\t\t%s.g = ", args.fOutputColor); |
| 453 coord.printf("vec2(coord.g, %s.g)", yoffsets); | 453 coord.printf("vec2(coord.g, %s.g)", yoffsets); |
| 454 fsBuilder->appendTextureLookup(args.fSamplers[0], coord.c_str()); | 454 fragBuilder->appendTextureLookup(args.fSamplers[0], coord.c_str()); |
| 455 fsBuilder->codeAppend(";\n"); | 455 fragBuilder->codeAppend(";\n"); |
| 456 | 456 |
| 457 fsBuilder->codeAppendf("\t\t%s.b = ", args.fOutputColor); | 457 fragBuilder->codeAppendf("\t\t%s.b = ", args.fOutputColor); |
| 458 coord.printf("vec2(coord.b, %s.b)", yoffsets); | 458 coord.printf("vec2(coord.b, %s.b)", yoffsets); |
| 459 fsBuilder->appendTextureLookup(args.fSamplers[0], coord.c_str()); | 459 fragBuilder->appendTextureLookup(args.fSamplers[0], coord.c_str()); |
| 460 fsBuilder->codeAppend(";\n"); | 460 fragBuilder->codeAppend(";\n"); |
| 461 | 461 |
| 462 fsBuilder->codeAppendf("\t\t%s.rgb *= %s.a;\n", args.fOutputColor, args.fOut
putColor); | 462 fragBuilder->codeAppendf("\t\t%s.rgb *= %s.a;\n", args.fOutputColor, args.fO
utputColor); |
| 463 } | 463 } |
| 464 | 464 |
| 465 /////////////////////////////////////////////////////////////////////////////// | 465 /////////////////////////////////////////////////////////////////////////////// |
| 466 const GrFragmentProcessor* ColorTableEffect::Create(GrContext* context, SkBitmap
bitmap, | 466 const GrFragmentProcessor* ColorTableEffect::Create(GrContext* context, SkBitmap
bitmap, |
| 467 unsigned flags) { | 467 unsigned flags) { |
| 468 | 468 |
| 469 GrTextureStripAtlas::Desc desc; | 469 GrTextureStripAtlas::Desc desc; |
| 470 desc.fWidth = bitmap.width(); | 470 desc.fWidth = bitmap.width(); |
| 471 desc.fHeight = 128; | 471 desc.fHeight = 128; |
| 472 desc.fRowHeight = bitmap.height(); | 472 desc.fRowHeight = bitmap.height(); |
| (...skipping 125 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 598 SkColorFilter* SkTableColorFilter::CreateARGB(const uint8_t tableA[256], | 598 SkColorFilter* SkTableColorFilter::CreateARGB(const uint8_t tableA[256], |
| 599 const uint8_t tableR[256], | 599 const uint8_t tableR[256], |
| 600 const uint8_t tableG[256], | 600 const uint8_t tableG[256], |
| 601 const uint8_t tableB[256]) { | 601 const uint8_t tableB[256]) { |
| 602 return new SkTable_ColorFilter(tableA, tableR, tableG, tableB); | 602 return new SkTable_ColorFilter(tableA, tableR, tableG, tableB); |
| 603 } | 603 } |
| 604 | 604 |
| 605 SK_DEFINE_FLATTENABLE_REGISTRAR_GROUP_START(SkTableColorFilter) | 605 SK_DEFINE_FLATTENABLE_REGISTRAR_GROUP_START(SkTableColorFilter) |
| 606 SK_DEFINE_FLATTENABLE_REGISTRAR_ENTRY(SkTable_ColorFilter) | 606 SK_DEFINE_FLATTENABLE_REGISTRAR_ENTRY(SkTable_ColorFilter) |
| 607 SK_DEFINE_FLATTENABLE_REGISTRAR_GROUP_END | 607 SK_DEFINE_FLATTENABLE_REGISTRAR_GROUP_END |
| OLD | NEW |