Unverified Commit 57b4a525 authored by amirh's avatar amirh Committed by GitHub

Push physical layers with paths instead of rects in RenderPhysicalModel. (#13942)

parent 0f11de2e
6a724f0d3e22d41246baf3447d7ba2c9ff886765 d8740c70a58ada74aff5b773e2bec9d622c42a97
...@@ -755,20 +755,20 @@ class PhysicalModelLayer extends ContainerLayer { ...@@ -755,20 +755,20 @@ class PhysicalModelLayer extends ContainerLayer {
/// Creates a composited layer that uses a physical model to producing /// Creates a composited layer that uses a physical model to producing
/// lighting effects. /// lighting effects.
/// ///
/// The [clipRRect], [elevation], and [color] arguments must not be null. /// The [clipPath], [elevation], and [color] arguments must not be null.
PhysicalModelLayer({ PhysicalModelLayer({
@required this.clipRRect, @required this.clipPath,
@required this.elevation, @required this.elevation,
@required this.color, @required this.color,
}) : assert(clipRRect != null), }) : assert(clipPath != null),
assert(elevation != null), assert(elevation != null),
assert(color != null); assert(color != null);
/// The rounded-rect to clip in the parent's coordinate system. /// The path to clip in the parent's coordinate system.
/// ///
/// The scene must be explicitly recomposited after this property is changed /// The scene must be explicitly recomposited after this property is changed
/// (as described at [Layer]). /// (as described at [Layer]).
RRect clipRRect; Path clipPath;
/// The z-coordinate at which to place this physical object. /// The z-coordinate at which to place this physical object.
/// ///
...@@ -784,8 +784,8 @@ class PhysicalModelLayer extends ContainerLayer { ...@@ -784,8 +784,8 @@ class PhysicalModelLayer extends ContainerLayer {
@override @override
void addToScene(ui.SceneBuilder builder, Offset layerOffset) { void addToScene(ui.SceneBuilder builder, Offset layerOffset) {
builder.pushPhysicalModel( builder.pushPhysicalShape(
rrect: clipRRect.shift(layerOffset), path: clipPath.shift(layerOffset),
elevation: elevation, elevation: elevation,
color: color, color: color,
); );
...@@ -796,7 +796,6 @@ class PhysicalModelLayer extends ContainerLayer { ...@@ -796,7 +796,6 @@ class PhysicalModelLayer extends ContainerLayer {
@override @override
void debugFillProperties(DiagnosticPropertiesBuilder description) { void debugFillProperties(DiagnosticPropertiesBuilder description) {
super.debugFillProperties(description); super.debugFillProperties(description);
description.add(new DiagnosticsProperty<RRect>('clipRRect', clipRRect));
description.add(new DoubleProperty('elevation', elevation)); description.add(new DoubleProperty('elevation', elevation));
description.add(new DiagnosticsProperty<Color>('color', color)); description.add(new DiagnosticsProperty<Color>('color', color));
} }
......
...@@ -1426,9 +1426,10 @@ class RenderPhysicalModel extends _RenderCustomClip<RRect> { ...@@ -1426,9 +1426,10 @@ class RenderPhysicalModel extends _RenderCustomClip<RRect> {
_updateClip(); _updateClip();
final RRect offsetClipRRect = _clip.shift(offset); final RRect offsetClipRRect = _clip.shift(offset);
final Rect offsetBounds = offsetClipRRect.outerRect; final Rect offsetBounds = offsetClipRRect.outerRect;
final Path offsetClipPath = new Path()..addRRect(offsetClipRRect);
if (needsCompositing) { if (needsCompositing) {
final PhysicalModelLayer physicalModel = new PhysicalModelLayer( final PhysicalModelLayer physicalModel = new PhysicalModelLayer(
clipRRect: offsetClipRRect, clipPath: offsetClipPath,
elevation: elevation, elevation: elevation,
color: color, color: color,
); );
...@@ -1445,7 +1446,7 @@ class RenderPhysicalModel extends _RenderCustomClip<RRect> { ...@@ -1445,7 +1446,7 @@ class RenderPhysicalModel extends _RenderCustomClip<RRect> {
_transparentPaint, _transparentPaint,
); );
canvas.drawShadow( canvas.drawShadow(
new Path()..addRRect(offsetClipRRect), offsetClipPath,
shadowColor, shadowColor,
elevation, elevation,
color.alpha != 0xFF, color.alpha != 0xFF,
......
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