summaryrefslogtreecommitdiff
path: root/libs/hwui/pipeline
diff options
context:
space:
mode:
authorNathaniel Nifong <nifong@google.com>2020-01-21 16:43:56 +0000
committerAndroid (Google) Code Review <android-gerrit@google.com>2020-01-21 16:43:56 +0000
commit1beddee406ae388d5a95779438cf49c68feff13a (patch)
tree891ea6975fc6c73157eb5a7e076a868183b336b1 /libs/hwui/pipeline
parentbd0ae94555a8fc0bfc92375743fc308771eaad9b (diff)
parent89a5dc514e69bc5db205910f0106418a0a558c85 (diff)
Merge "Do not clip draw commands during recording of SKP files"
Diffstat (limited to 'libs/hwui/pipeline')
-rw-r--r--libs/hwui/pipeline/skia/SkiaPipeline.cpp12
1 files changed, 9 insertions, 3 deletions
diff --git a/libs/hwui/pipeline/skia/SkiaPipeline.cpp b/libs/hwui/pipeline/skia/SkiaPipeline.cpp
index 35a885f46919..b940cff04713 100644
--- a/libs/hwui/pipeline/skia/SkiaPipeline.cpp
+++ b/libs/hwui/pipeline/skia/SkiaPipeline.cpp
@@ -458,9 +458,15 @@ void SkiaPipeline::renderFrameImpl(const SkRect& clip,
const SkMatrix& preTransform) {
SkAutoCanvasRestore saver(canvas, true);
auto clipRestriction = preTransform.mapRect(clip).roundOut();
- canvas->androidFramework_setDeviceClipRestriction(clipRestriction);
- canvas->drawAnnotation(SkRect::Make(clipRestriction), "AndroidDeviceClipRestriction",
- nullptr);
+ if (CC_UNLIKELY(mCaptureMode == CaptureMode::SingleFrameSKP
+ || mCaptureMode == CaptureMode::MultiFrameSKP)) {
+ canvas->drawAnnotation(SkRect::Make(clipRestriction), "AndroidDeviceClipRestriction",
+ nullptr);
+ } else {
+ // clip drawing to dirty region only when not recording SKP files (which should contain all
+ // draw ops on every frame)
+ canvas->androidFramework_setDeviceClipRestriction(clipRestriction);
+ }
canvas->concat(preTransform);
// STOPSHIP: Revert, temporary workaround to clear always F16 frame buffer for b/74976293