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 |