Chromium Code Reviews| Index: src/gpu/GrContext.cpp |
| diff --git a/src/gpu/GrContext.cpp b/src/gpu/GrContext.cpp |
| index a186bd87bc101f1cf9107ccc1903172adf354622..28b59d08044a4db6a8bd8b3b34f0c0ae199253f1 100644 |
| --- a/src/gpu/GrContext.cpp |
| +++ b/src/gpu/GrContext.cpp |
| @@ -20,6 +20,7 @@ |
| #include "batches/GrCopySurfaceBatch.h" |
| #include "effects/GrConfigConversionEffect.h" |
| +#include "effects/GrGammaEffect.h" |
| #include "text/GrTextBlobCache.h" |
| #define ASSERT_OWNED_RESOURCE(R) SkASSERT(!(R) || (R)->getContext() == this) |
| @@ -529,6 +530,40 @@ bool GrContext::readSurfacePixels(GrSurface* src, |
| return true; |
| } |
| +bool GrContext::applyGamma(GrRenderTarget* dst, GrTexture* src, SkScalar gamma){ |
| + ASSERT_SINGLE_OWNER |
| + RETURN_FALSE_IF_ABANDONED |
| + ASSERT_OWNED_RESOURCE(dst); |
| + ASSERT_OWNED_RESOURCE(src); |
| + GR_AUDIT_TRAIL_AUTO_FRAME(&fAuditTrail, "GrContext::applyGamma"); |
| + |
| + SkSurfaceProps props(SkSurfaceProps::kGammaCorrect_Flag, |
| + SkSurfaceProps::kLegacyFontHost_InitType); |
| + sk_sp<GrDrawContext> drawContext(this->drawContext(sk_ref_sp(dst), &props)); |
| + if (!drawContext) { |
| + return false; |
| + } |
| + |
| + GrPaint paint; |
| + if (SkScalarNearlyEqual(gamma, 1.0f)) { |
|
bsalomon
2016/04/29 18:27:20
Maybe just call copySurface here? Should we also d
Brian Osman
2016/05/02 21:02:45
I tried falling back to copySurface, but that code
bsalomon
2016/05/02 21:17:40
Is that what we want copySurface to do? Maybe we s
|
| + paint.addColorTextureProcessor(src, GrCoordTransform::MakeDivByTextureWHMatrix(src)); |
| + } else { |
| + SkAutoTUnref<const GrFragmentProcessor> fp; |
| + fp.reset(GrGammaEffect::Create(src, gamma)); |
| + paint.addColorFragmentProcessor(fp); |
| + } |
| + paint.setPorterDuffXPFactory(SkXfermode::kSrc_Mode); |
| + paint.setGammaCorrect(true); |
| + |
| + SkRect rect; |
| + src->getBoundsRect(&rect); |
| + drawContext->drawRect(GrClip::WideOpen(), paint, SkMatrix::I(), rect, nullptr); |
| + |
| + this->flushSurfaceWrites(dst); |
| + |
| + return true; |
| +} |
| + |
| void GrContext::prepareSurfaceForExternalIO(GrSurface* surface) { |
| ASSERT_SINGLE_OWNER |
| RETURN_IF_ABANDONED |