Index: src/gpu/GrStencilAndCoverTextContext.cpp |
diff --git a/src/gpu/GrStencilAndCoverTextContext.cpp b/src/gpu/GrStencilAndCoverTextContext.cpp |
index 1456aa22b5802d0e860dbcf1c17d18258e6499e1..675df69445bf8d01cee178b1c3c86d5119f7155b 100644 |
--- a/src/gpu/GrStencilAndCoverTextContext.cpp |
+++ b/src/gpu/GrStencilAndCoverTextContext.cpp |
@@ -69,6 +69,12 @@ bool GrStencilAndCoverTextContext::canDraw(const GrRenderTarget* rt, |
return false; |
} |
+ if (skPaint.isAntiAlias() && |
+ GrRenderTarget::kStencil_SampleConfig == rt->sampleConfig() && |
+ !paint.getXPFactory()->canTweakAlphaForCoverage()) { |
+ return false; |
+ } |
+ |
// No color bitmap fonts. |
SkScalerContext::Rec rec; |
SkScalerContext::MakeRec(skPaint, &fDeviceProperties, NULL, &rec); |
@@ -374,6 +380,8 @@ void GrStencilAndCoverTextContext::init(GrRenderTarget* rt, |
fStateRestore.set(&fPipelineBuilder); |
fPipelineBuilder.setFromPaint(fPaint, fRenderTarget, fClip); |
+ SkASSERT(fRenderTarget->isMultisampled(GrRenderTarget::BufferBits::kStencil_BufferBit)); |
+ fPipelineBuilder.setState(GrPipelineBuilder::kHWAntialias_StateBit, fPaint.isAntiAlias()); |
GR_STATIC_CONST_SAME_STENCIL(kStencilPass, |
kZero_StencilOp, |