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

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

Issue 1457543003: Add ShaderBuilders to EmitArgs and remove gettings from ProgBuilder. (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: Created 5 years, 1 month 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/SkPerlinNoiseShader.cpp ('k') | src/effects/gradients/SkGradientShader.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 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
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
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
OLDNEW
« no previous file with comments | « src/effects/SkPerlinNoiseShader.cpp ('k') | src/effects/gradients/SkGradientShader.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698