Unverified Commit 3890af64 authored by xster's avatar xster Committed by GitHub

Add debug disable flags for various performance affecting layers (#15548)

parent 27ac523e
...@@ -111,6 +111,26 @@ bool debugCheckIntrinsicSizes = false; ...@@ -111,6 +111,26 @@ bool debugCheckIntrinsicSizes = false;
/// * The discussion at [RendererBinding.drawFrame]. /// * The discussion at [RendererBinding.drawFrame].
bool debugProfilePaintsEnabled = false; bool debugProfilePaintsEnabled = false;
/// Setting to true will cause all clipping effects from the layer tree to be ignored.
///
/// Can be used to debug whether objects being clipped are painting excessively
/// in clipped areas. Can also be used to check whether excessive use of clipping
/// is affecting performance.
bool debugDisableClipLayers = false;
/// Setting to true will cause all physical modeling effects, such as shadows
/// from elevations, from the layer tree to be ignored.
///
/// Can be used to check whether excessive use of physical models is affecting
/// performance.
bool debugDisablePhysicalShapeLayers = false;
/// Setting to true will cause all opacity effects to be ignored.
///
/// An optimization to not paint the child at all when opacity is 0 will still
/// remain. Can be used to check whether excessive use of opacity effects is
/// affecting performance.
bool debugDisableOpacityLayers = false;
void _debugDrawDoubleRect(Canvas canvas, Rect outerRect, Rect innerRect, Color color) { void _debugDrawDoubleRect(Canvas canvas, Rect outerRect, Rect innerRect, Color color) {
final Path path = new Path() final Path path = new Path()
......
...@@ -10,6 +10,8 @@ import 'package:flutter/foundation.dart'; ...@@ -10,6 +10,8 @@ import 'package:flutter/foundation.dart';
import 'package:flutter/painting.dart'; import 'package:flutter/painting.dart';
import 'package:vector_math/vector_math_64.dart'; import 'package:vector_math/vector_math_64.dart';
import 'debug.dart';
/// A composited layer. /// A composited layer.
/// ///
/// During painting, the render tree generates a tree of composited layers that /// During painting, the render tree generates a tree of composited layers that
...@@ -531,8 +533,10 @@ class ClipRectLayer extends ContainerLayer { ...@@ -531,8 +533,10 @@ class ClipRectLayer extends ContainerLayer {
@override @override
void addToScene(ui.SceneBuilder builder, Offset layerOffset) { void addToScene(ui.SceneBuilder builder, Offset layerOffset) {
if (!debugDisableClipLayers)
builder.pushClipRect(clipRect.shift(layerOffset)); builder.pushClipRect(clipRect.shift(layerOffset));
addChildrenToScene(builder, layerOffset); addChildrenToScene(builder, layerOffset);
if (!debugDisableClipLayers)
builder.pop(); builder.pop();
} }
...@@ -559,8 +563,10 @@ class ClipRRectLayer extends ContainerLayer { ...@@ -559,8 +563,10 @@ class ClipRRectLayer extends ContainerLayer {
@override @override
void addToScene(ui.SceneBuilder builder, Offset layerOffset) { void addToScene(ui.SceneBuilder builder, Offset layerOffset) {
if (!debugDisableClipLayers)
builder.pushClipRRect(clipRRect.shift(layerOffset)); builder.pushClipRRect(clipRRect.shift(layerOffset));
addChildrenToScene(builder, layerOffset); addChildrenToScene(builder, layerOffset);
if (!debugDisableClipLayers)
builder.pop(); builder.pop();
} }
...@@ -587,8 +593,10 @@ class ClipPathLayer extends ContainerLayer { ...@@ -587,8 +593,10 @@ class ClipPathLayer extends ContainerLayer {
@override @override
void addToScene(ui.SceneBuilder builder, Offset layerOffset) { void addToScene(ui.SceneBuilder builder, Offset layerOffset) {
if (!debugDisableClipLayers)
builder.pushClipPath(clipPath.shift(layerOffset)); builder.pushClipPath(clipPath.shift(layerOffset));
addChildrenToScene(builder, layerOffset); addChildrenToScene(builder, layerOffset);
if (!debugDisableClipLayers)
builder.pop(); builder.pop();
} }
} }
...@@ -664,8 +672,10 @@ class OpacityLayer extends ContainerLayer { ...@@ -664,8 +672,10 @@ class OpacityLayer extends ContainerLayer {
@override @override
void addToScene(ui.SceneBuilder builder, Offset layerOffset) { void addToScene(ui.SceneBuilder builder, Offset layerOffset) {
if (!debugDisableOpacityLayers)
builder.pushOpacity(alpha); builder.pushOpacity(alpha);
addChildrenToScene(builder, layerOffset); addChildrenToScene(builder, layerOffset);
if (!debugDisableOpacityLayers)
builder.pop(); builder.pop();
} }
...@@ -778,12 +788,14 @@ class PhysicalModelLayer extends ContainerLayer { ...@@ -778,12 +788,14 @@ class PhysicalModelLayer extends ContainerLayer {
@override @override
void addToScene(ui.SceneBuilder builder, Offset layerOffset) { void addToScene(ui.SceneBuilder builder, Offset layerOffset) {
if (!debugDisablePhysicalShapeLayers)
builder.pushPhysicalShape( builder.pushPhysicalShape(
path: clipPath.shift(layerOffset), path: clipPath.shift(layerOffset),
elevation: elevation, elevation: elevation,
color: color, color: color,
); );
addChildrenToScene(builder, layerOffset); addChildrenToScene(builder, layerOffset);
if (!debugDisablePhysicalShapeLayers)
builder.pop(); builder.pop();
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment