| Index: src/pdf/SkPDFDevice.cpp
|
| diff --git a/src/pdf/SkPDFDevice.cpp b/src/pdf/SkPDFDevice.cpp
|
| index 59a8028a76209151e249c35827506346ea68ef87..e00602cc053d184c6b37d68c2059507d22c486a5 100644
|
| --- a/src/pdf/SkPDFDevice.cpp
|
| +++ b/src/pdf/SkPDFDevice.cpp
|
| @@ -1415,7 +1415,8 @@ void SkPDFDevice::drawFormXObjectWithClip(SkPDFFormXObject* xobject,
|
| this->drawPaint(draw, stockPaint);
|
| SkAutoTUnref<SkPDFFormXObject> maskFormXObject(createFormXObjectFromDevice());
|
| SkAutoTUnref<SkPDFGraphicState> sMaskGS(
|
| - SkPDFGraphicState::GetSMaskGraphicState(maskFormXObject, invertClip));
|
| + SkPDFGraphicState::GetSMaskGraphicState(maskFormXObject, invertClip,
|
| + SkPDFGraphicState::kAlpha_SMaskMode));
|
|
|
| // Draw the xobject with the clip as a mask.
|
| ScopedContentEntry content(this, &fExistingClipStack, fExistingClipRegion,
|
| @@ -1571,12 +1572,16 @@ void SkPDFDevice::finishContentEntry(const SkXfermode::Mode xfermode,
|
| if (xfermode == SkXfermode::kSrcIn_Mode ||
|
| xfermode == SkXfermode::kSrcOut_Mode) {
|
| sMaskGS.reset(SkPDFGraphicState::GetSMaskGraphicState(
|
| - dst, xfermode == SkXfermode::kSrcOut_Mode));
|
| + dst,
|
| + xfermode == SkXfermode::kSrcOut_Mode,
|
| + SkPDFGraphicState::kAlpha_SMaskMode));
|
| fXObjectResources.push(srcFormXObject.get());
|
| srcFormXObject.get()->ref();
|
| } else {
|
| sMaskGS.reset(SkPDFGraphicState::GetSMaskGraphicState(
|
| - srcFormXObject.get(), xfermode == SkXfermode::kDstOut_Mode));
|
| + srcFormXObject.get(),
|
| + xfermode == SkXfermode::kDstOut_Mode,
|
| + SkPDFGraphicState::kAlpha_SMaskMode));
|
| // dst already added to fXObjectResources in drawFormXObjectWithClip.
|
| }
|
| SkPDFUtils::ApplyGraphicState(addGraphicStateResource(sMaskGS.get()),
|
|
|