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

Unified Diff: src/gpu/SkGr.cpp

Issue 1454933002: Initial implementation of GPU no filter NinePatch (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: tweaks 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 side-by-side diff with in-line comments
Download patch
Index: src/gpu/SkGr.cpp
diff --git a/src/gpu/SkGr.cpp b/src/gpu/SkGr.cpp
index 540edb6a38e728c6a5e1f018a2dc3840fda965a8..0669b96fccc719669c026a8807016e901877615a 100644
--- a/src/gpu/SkGr.cpp
+++ b/src/gpu/SkGr.cpp
@@ -597,6 +597,35 @@ bool SkPaintToGrPaintWithXfermode(GrContext* context,
}
+bool SkPaintToGrPaintWithTexture(GrContext* context,
+ const SkPaint& paint,
+ const SkMatrix& viewM,
+ const GrFragmentProcessor* fp,
+ bool textureIsAlphaOnly,
+ GrPaint* grPaint) {
+ SkAutoTUnref<const GrFragmentProcessor> shaderFP;
+ if (textureIsAlphaOnly) {
+ if (const SkShader* shader = paint.getShader()) {
+ shaderFP.reset(shader->asFragmentProcessor(context,
+ viewM,
+ nullptr,
+ paint.getFilterQuality()));
+ if (!shaderFP) {
+ return false;
+ }
+ const GrFragmentProcessor* fpSeries[] = { shaderFP.get(), fp };
+ shaderFP.reset(GrFragmentProcessor::RunInSeries(fpSeries, 2));
+ } else {
+ shaderFP.reset(GrFragmentProcessor::MulOutputByInputUnpremulColor(fp));
+ }
+ } else {
+ shaderFP.reset(GrFragmentProcessor::MulOutputByInputAlpha(fp));
+ }
+
+ return SkPaintToGrPaintReplaceShader(context, paint, shaderFP.get(), grPaint);
+}
+
+
////////////////////////////////////////////////////////////////////////////////////////////////
SkImageInfo GrMakeInfoFromTexture(GrTexture* tex, int w, int h, bool isOpaque) {

Powered by Google App Engine
This is Rietveld 408576698