Index: src/gpu/GrSoftwarePathRenderer.cpp |
diff --git a/src/gpu/GrSoftwarePathRenderer.cpp b/src/gpu/GrSoftwarePathRenderer.cpp |
index 157e81d1081e677c884da0965d7c8a732a2aaa75..8eb66d81bf14e02eff581912f4a1978e0c523fef 100644 |
--- a/src/gpu/GrSoftwarePathRenderer.cpp |
+++ b/src/gpu/GrSoftwarePathRenderer.cpp |
@@ -81,30 +81,34 @@ void draw_around_inv_path(GrDrawTarget* target, |
GrColor color, |
const SkIRect& devClipBounds, |
const SkIRect& devPathBounds) { |
- GrDrawState::AutoViewMatrixRestore avmr; |
- if (!avmr.setIdentity(drawState)) { |
+ const SkMatrix& matrix = drawState->getViewMatrix(); |
+ SkMatrix invert; |
+ if (!matrix.invert(&invert)) { |
return; |
} |
+ |
+ GrDrawState::AutoViewMatrixRestore avmr(drawState); |
+ |
SkRect rect; |
if (devClipBounds.fTop < devPathBounds.fTop) { |
rect.iset(devClipBounds.fLeft, devClipBounds.fTop, |
devClipBounds.fRight, devPathBounds.fTop); |
- target->drawSimpleRect(drawState, color, rect); |
+ target->drawRect(drawState, color, rect, NULL, &invert); |
} |
if (devClipBounds.fLeft < devPathBounds.fLeft) { |
rect.iset(devClipBounds.fLeft, devPathBounds.fTop, |
devPathBounds.fLeft, devPathBounds.fBottom); |
- target->drawSimpleRect(drawState, color, rect); |
+ target->drawRect(drawState, color, rect, NULL, &invert); |
} |
if (devClipBounds.fRight > devPathBounds.fRight) { |
rect.iset(devPathBounds.fRight, devPathBounds.fTop, |
devClipBounds.fRight, devPathBounds.fBottom); |
- target->drawSimpleRect(drawState, color, rect); |
+ target->drawRect(drawState, color, rect, NULL, &invert); |
} |
if (devClipBounds.fBottom > devPathBounds.fBottom) { |
rect.iset(devClipBounds.fLeft, devPathBounds.fBottom, |
devClipBounds.fRight, devClipBounds.fBottom); |
- target->drawSimpleRect(drawState, color, rect); |
+ target->drawRect(drawState, color, rect, NULL, &invert); |
} |
} |