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 |