| 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 "SkArithmeticMode_gpu.h" | 8 #include "SkArithmeticMode_gpu.h" |
| 9 | 9 |
| 10 #if SK_SUPPORT_GPU | 10 #if SK_SUPPORT_GPU |
| (...skipping 140 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 151 | 151 |
| 152 return SkNEW_ARGS(GrArithmeticFP, (k1, k2, k3, k4, enforcePMColor, textures[
0])); | 152 return SkNEW_ARGS(GrArithmeticFP, (k1, k2, k3, k4, enforcePMColor, textures[
0])); |
| 153 } | 153 } |
| 154 | 154 |
| 155 GR_DEFINE_FRAGMENT_PROCESSOR_TEST(GrArithmeticFP); | 155 GR_DEFINE_FRAGMENT_PROCESSOR_TEST(GrArithmeticFP); |
| 156 | 156 |
| 157 /////////////////////////////////////////////////////////////////////////////// | 157 /////////////////////////////////////////////////////////////////////////////// |
| 158 // Xfer Processor | 158 // Xfer Processor |
| 159 /////////////////////////////////////////////////////////////////////////////// | 159 /////////////////////////////////////////////////////////////////////////////// |
| 160 | 160 |
| 161 class ArithmeticXP : public GrXferProcessor { |
| 162 public: |
| 163 static GrXferProcessor* Create(float k1, float k2, float k3, float k4, bool
enforcePMColor, |
| 164 const GrDeviceCoordTexture* dstCopy, |
| 165 bool willReadDstColor) { |
| 166 return SkNEW_ARGS(ArithmeticXP, (k1, k2, k3, k4, enforcePMColor, dstCopy
, |
| 167 willReadDstColor)); |
| 168 } |
| 169 |
| 170 ~ArithmeticXP() SK_OVERRIDE {}; |
| 171 |
| 172 const char* name() const SK_OVERRIDE { return "Arithmetic"; } |
| 173 |
| 174 GrGLXferProcessor* createGLInstance() const SK_OVERRIDE; |
| 175 |
| 176 bool hasSecondaryOutput() const SK_OVERRIDE { return false; } |
| 177 |
| 178 GrXferProcessor::OptFlags getOptimizations(const GrProcOptInfo& colorPOI, |
| 179 const GrProcOptInfo& coveragePOI, |
| 180 bool doesStencilWrite, |
| 181 GrColor* overrideColor, |
| 182 const GrDrawTargetCaps& caps) SK_
OVERRIDE; |
| 183 |
| 184 void getBlendInfo(GrXferProcessor::BlendInfo* blendInfo) const SK_OVERRIDE { |
| 185 blendInfo->fSrcBlend = kOne_GrBlendCoeff; |
| 186 blendInfo->fDstBlend = kZero_GrBlendCoeff; |
| 187 blendInfo->fBlendConstant = 0; |
| 188 } |
| 189 |
| 190 float k1() const { return fK1; } |
| 191 float k2() const { return fK2; } |
| 192 float k3() const { return fK3; } |
| 193 float k4() const { return fK4; } |
| 194 bool enforcePMColor() const { return fEnforcePMColor; } |
| 195 |
| 196 private: |
| 197 ArithmeticXP(float k1, float k2, float k3, float k4, bool enforcePMColor, |
| 198 const GrDeviceCoordTexture* dstCopy, bool willReadDstColor); |
| 199 |
| 200 void onGetGLProcessorKey(const GrGLCaps& caps, GrProcessorKeyBuilder* b) con
st SK_OVERRIDE; |
| 201 |
| 202 bool onIsEqual(const GrXferProcessor& xpBase) const SK_OVERRIDE { |
| 203 const ArithmeticXP& xp = xpBase.cast<ArithmeticXP>(); |
| 204 if (fK1 != xp.fK1 || |
| 205 fK2 != xp.fK2 || |
| 206 fK3 != xp.fK3 || |
| 207 fK4 != xp.fK4 || |
| 208 fEnforcePMColor != xp.fEnforcePMColor) { |
| 209 return false; |
| 210 } |
| 211 return true; |
| 212 } |
| 213 |
| 214 float fK1, fK2, fK3, fK4; |
| 215 bool fEnforcePMColor; |
| 216 |
| 217 typedef GrXferProcessor INHERITED; |
| 218 }; |
| 219 |
| 220 /////////////////////////////////////////////////////////////////////////////// |
| 221 |
| 161 class GLArithmeticXP : public GrGLXferProcessor { | 222 class GLArithmeticXP : public GrGLXferProcessor { |
| 162 public: | 223 public: |
| 163 GLArithmeticXP(const GrProcessor&) | 224 GLArithmeticXP(const GrProcessor&) |
| 164 : fEnforcePMColor(true) { | 225 : fEnforcePMColor(true) { |
| 165 } | 226 } |
| 166 | 227 |
| 167 ~GLArithmeticXP() SK_OVERRIDE {} | 228 ~GLArithmeticXP() SK_OVERRIDE {} |
| 168 | 229 |
| 169 static void GenKey(const GrProcessor& processor, const GrGLCaps& caps, | 230 static void GenKey(const GrProcessor& processor, const GrGLCaps& caps, |
| 170 GrProcessorKeyBuilder* b) { | 231 GrProcessorKeyBuilder* b) { |
| 171 const GrArithmeticXP& arith = processor.cast<GrArithmeticXP>(); | 232 const ArithmeticXP& arith = processor.cast<ArithmeticXP>(); |
| 172 uint32_t key = arith.enforcePMColor() ? 1 : 0; | 233 uint32_t key = arith.enforcePMColor() ? 1 : 0; |
| 173 b->add32(key); | 234 b->add32(key); |
| 174 } | 235 } |
| 175 | 236 |
| 176 private: | 237 private: |
| 177 void onEmitCode(const EmitArgs& args) SK_OVERRIDE { | 238 void onEmitCode(const EmitArgs& args) SK_OVERRIDE { |
| 178 GrGLFPFragmentBuilder* fsBuilder = args.fPB->getFragmentShaderBuilder(); | 239 GrGLFPFragmentBuilder* fsBuilder = args.fPB->getFragmentShaderBuilder(); |
| 179 | 240 |
| 180 const char* dstColor = fsBuilder->dstColor(); | 241 const char* dstColor = fsBuilder->dstColor(); |
| 181 | 242 |
| 182 fKUni = args.fPB->addUniform(GrGLProgramBuilder::kFragment_Visibility, | 243 fKUni = args.fPB->addUniform(GrGLProgramBuilder::kFragment_Visibility, |
| 183 kVec4f_GrSLType, kDefault_GrSLPrecision, | 244 kVec4f_GrSLType, kDefault_GrSLPrecision, |
| 184 "k"); | 245 "k"); |
| 185 const char* kUni = args.fPB->getUniformCStr(fKUni); | 246 const char* kUni = args.fPB->getUniformCStr(fKUni); |
| 186 | 247 |
| 187 add_arithmetic_code(fsBuilder, args.fInputColor, dstColor, args.fOutputP
rimary, kUni, | 248 add_arithmetic_code(fsBuilder, args.fInputColor, dstColor, args.fOutputP
rimary, kUni, |
| 188 fEnforcePMColor); | 249 fEnforcePMColor); |
| 189 | 250 |
| 190 fsBuilder->codeAppendf("%s = %s * %s + (vec4(1.0) - %s) * %s;", | 251 fsBuilder->codeAppendf("%s = %s * %s + (vec4(1.0) - %s) * %s;", |
| 191 args.fOutputPrimary, args.fOutputPrimary, args.fI
nputCoverage, | 252 args.fOutputPrimary, args.fOutputPrimary, args.fI
nputCoverage, |
| 192 args.fInputCoverage, dstColor); | 253 args.fInputCoverage, dstColor); |
| 193 } | 254 } |
| 194 | 255 |
| 195 void onSetData(const GrGLProgramDataManager& pdman, | 256 void onSetData(const GrGLProgramDataManager& pdman, |
| 196 const GrXferProcessor& processor) SK_OVERRIDE { | 257 const GrXferProcessor& processor) SK_OVERRIDE { |
| 197 const GrArithmeticXP& arith = processor.cast<GrArithmeticXP>(); | 258 const ArithmeticXP& arith = processor.cast<ArithmeticXP>(); |
| 198 pdman.set4f(fKUni, arith.k1(), arith.k2(), arith.k3(), arith.k4()); | 259 pdman.set4f(fKUni, arith.k1(), arith.k2(), arith.k3(), arith.k4()); |
| 199 fEnforcePMColor = arith.enforcePMColor(); | 260 fEnforcePMColor = arith.enforcePMColor(); |
| 200 }; | 261 }; |
| 201 | 262 |
| 202 GrGLProgramDataManager::UniformHandle fKUni; | 263 GrGLProgramDataManager::UniformHandle fKUni; |
| 203 bool fEnforcePMColor; | 264 bool fEnforcePMColor; |
| 204 | 265 |
| 205 typedef GrGLXferProcessor INHERITED; | 266 typedef GrGLXferProcessor INHERITED; |
| 206 }; | 267 }; |
| 207 | 268 |
| 208 /////////////////////////////////////////////////////////////////////////////// | 269 /////////////////////////////////////////////////////////////////////////////// |
| 209 | 270 |
| 210 GrArithmeticXP::GrArithmeticXP(float k1, float k2, float k3, float k4, bool enfo
rcePMColor, | 271 ArithmeticXP::ArithmeticXP(float k1, float k2, float k3, float k4, bool enforceP
MColor, |
| 211 const GrDeviceCoordTexture* dstCopy, bool willRea
dDstColor) | 272 const GrDeviceCoordTexture* dstCopy, bool willReadDst
Color) |
| 212 : INHERITED(dstCopy, willReadDstColor) | 273 : INHERITED(dstCopy, willReadDstColor) |
| 213 , fK1(k1) | 274 , fK1(k1) |
| 214 , fK2(k2) | 275 , fK2(k2) |
| 215 , fK3(k3) | 276 , fK3(k3) |
| 216 , fK4(k4) | 277 , fK4(k4) |
| 217 , fEnforcePMColor(enforcePMColor) { | 278 , fEnforcePMColor(enforcePMColor) { |
| 218 this->initClassID<GrArithmeticXP>(); | 279 this->initClassID<ArithmeticXP>(); |
| 219 } | 280 } |
| 220 | 281 |
| 221 void GrArithmeticXP::onGetGLProcessorKey(const GrGLCaps& caps, GrProcessorKeyBui
lder* b) const { | 282 void ArithmeticXP::onGetGLProcessorKey(const GrGLCaps& caps, GrProcessorKeyBuild
er* b) const { |
| 222 GLArithmeticXP::GenKey(*this, caps, b); | 283 GLArithmeticXP::GenKey(*this, caps, b); |
| 223 } | 284 } |
| 224 | 285 |
| 225 GrGLXferProcessor* GrArithmeticXP::createGLInstance() const { | 286 GrGLXferProcessor* ArithmeticXP::createGLInstance() const { |
| 226 return SkNEW_ARGS(GLArithmeticXP, (*this)); | 287 return SkNEW_ARGS(GLArithmeticXP, (*this)); |
| 227 } | 288 } |
| 228 | 289 |
| 229 GrXferProcessor::OptFlags GrArithmeticXP::getOptimizations(const GrProcOptInfo&
colorPOI, | 290 GrXferProcessor::OptFlags ArithmeticXP::getOptimizations(const GrProcOptInfo& co
lorPOI, |
| 230 const GrProcOptInfo&
coveragePOI, | 291 const GrProcOptInfo& co
veragePOI, |
| 231 bool doesStencilWrite
, | 292 bool doesStencilWrite, |
| 232 GrColor* overrideColo
r, | 293 GrColor* overrideColor, |
| 233 const GrDrawTargetCap
s& caps) { | 294 const GrDrawTargetCaps&
caps) { |
| 234 return GrXferProcessor::kNone_Opt; | 295 return GrXferProcessor::kNone_Opt; |
| 235 } | 296 } |
| 236 | 297 |
| 237 /////////////////////////////////////////////////////////////////////////////// | 298 /////////////////////////////////////////////////////////////////////////////// |
| 238 | 299 |
| 239 GrArithmeticXPFactory::GrArithmeticXPFactory(float k1, float k2, float k3, float
k4, | 300 GrArithmeticXPFactory::GrArithmeticXPFactory(float k1, float k2, float k3, float
k4, |
| 240 bool enforcePMColor) | 301 bool enforcePMColor) |
| 241 : fK1(k1), fK2(k2), fK3(k3), fK4(k4), fEnforcePMColor(enforcePMColor) { | 302 : fK1(k1), fK2(k2), fK3(k3), fK4(k4), fEnforcePMColor(enforcePMColor) { |
| 242 this->initClassID<GrArithmeticXPFactory>(); | 303 this->initClassID<GrArithmeticXPFactory>(); |
| 243 } | 304 } |
| 244 | 305 |
| 306 GrXferProcessor* |
| 307 GrArithmeticXPFactory::onCreateXferProcessor(const GrProcOptInfo& colorPOI, |
| 308 const GrProcOptInfo& coveragePOI, |
| 309 const GrDeviceCoordTexture* dstCopy
) const { |
| 310 return ArithmeticXP::Create(fK1, fK2, fK3, fK4, fEnforcePMColor, dstCopy, |
| 311 this->willReadDstColor()); |
| 312 } |
| 313 |
| 314 |
| 245 void GrArithmeticXPFactory::getInvariantOutput(const GrProcOptInfo& colorPOI, | 315 void GrArithmeticXPFactory::getInvariantOutput(const GrProcOptInfo& colorPOI, |
| 246 const GrProcOptInfo& coveragePOI, | 316 const GrProcOptInfo& coveragePOI, |
| 247 GrXPFactory::InvariantOutput* out
put) const { | 317 GrXPFactory::InvariantOutput* out
put) const { |
| 248 output->fWillBlendWithDst = true; | 318 output->fWillBlendWithDst = true; |
| 249 | 319 |
| 250 // TODO: We could try to optimize this more. For example if we have solid co
verage and fK1 and | 320 // TODO: We could try to optimize this more. For example if we have solid co
verage and fK1 and |
| 251 // fK3 are zero, then we won't be blending the color with dst at all so we c
an know what the | 321 // fK3 are zero, then we won't be blending the color with dst at all so we c
an know what the |
| 252 // output color is (up to the valid color components passed in). | 322 // output color is (up to the valid color components passed in). |
| 253 output->fBlendedColorFlags = 0; | 323 output->fBlendedColorFlags = 0; |
| 254 } | 324 } |
| 255 | 325 |
| 256 GR_DEFINE_XP_FACTORY_TEST(GrArithmeticXPFactory); | 326 GR_DEFINE_XP_FACTORY_TEST(GrArithmeticXPFactory); |
| 257 | 327 |
| 258 GrXPFactory* GrArithmeticXPFactory::TestCreate(SkRandom* random, | 328 GrXPFactory* GrArithmeticXPFactory::TestCreate(SkRandom* random, |
| 259 GrContext*, | 329 GrContext*, |
| 260 const GrDrawTargetCaps&, | 330 const GrDrawTargetCaps&, |
| 261 GrTexture*[]) { | 331 GrTexture*[]) { |
| 262 float k1 = random->nextF(); | 332 float k1 = random->nextF(); |
| 263 float k2 = random->nextF(); | 333 float k2 = random->nextF(); |
| 264 float k3 = random->nextF(); | 334 float k3 = random->nextF(); |
| 265 float k4 = random->nextF(); | 335 float k4 = random->nextF(); |
| 266 bool enforcePMColor = random->nextBool(); | 336 bool enforcePMColor = random->nextBool(); |
| 267 | 337 |
| 268 return GrArithmeticXPFactory::Create(k1, k2, k3, k4, enforcePMColor); | 338 return GrArithmeticXPFactory::Create(k1, k2, k3, k4, enforcePMColor); |
| 269 } | 339 } |
| 270 | 340 |
| 271 #endif | 341 #endif |
| OLD | NEW |