浏览代码

Merge pull request #154 from UnityTech/kgdev

fix clipPath.
/main
GitHub 6 年前
当前提交
1d47f4ac
共有 6 个文件被更改,包括 44 次插入17 次删除
  1. 3
      Runtime/material/animated_icons/animated_icons.cs
  2. 4
      Runtime/painting/notched_shapes.cs
  3. 1
      Runtime/rendering/proxy_box.cs
  4. 10
      Runtime/ui/painting/canvas.cs
  5. 41
      Runtime/ui/painting/path.cs
  6. 2
      Runtime/widgets/binding.cs

3
Runtime/material/animated_icons/animated_icons.cs


Offset controlPoint1 = AnimatedIconUtils._interpolate<Offset>(this.controlPoints1, progress, Offset.lerp);
Offset controlPoint2 = AnimatedIconUtils._interpolate<Offset>(this.controlPoints2, progress, Offset.lerp);
Offset targetPoint = AnimatedIconUtils._interpolate<Offset>(this.targetPoints, progress, Offset.lerp);
// TODO: replace with cubicTo
path.bezierTo(
path.cubicTo(
controlPoint1.dx, controlPoint1.dy,
controlPoint2.dx, controlPoint2.dy,
targetPoint.dx, targetPoint.dy

4
Runtime/painting/notched_shapes.cs


Path ret = new Path();
ret.moveTo(host.left, host.top);
ret.lineTo(p[0].dx, p[0].dy);
ret.quadTo(p[1].dx, p[1].dy, p[2].dx, p[2].dy);
ret.quadraticBezierTo(p[1].dx, p[1].dy, p[2].dx, p[2].dy);
ret.quadTo(p[4].dx, p[4].dy, p[5].dx, p[5].dy);
ret.quadraticBezierTo(p[4].dx, p[4].dy, p[5].dx, p[5].dy);
ret.lineTo(host.right, host.top);
ret.lineTo(host.right, host.bottom);
ret.lineTo(host.left, host.bottom);

1
Runtime/rendering/proxy_box.cs


this._updateClip();
context.pushClipPath(this.needsCompositing, offset, Offset.zero & this.size,
this._clip, base.paint, clipBehavior: this.clipBehavior);
base.paint(context, offset);
}
}

10
Runtime/ui/painting/canvas.cs


bool forceMoveTo = !useCenter;
while (sweepAngle <= -Mathf.PI * 2) {
path.addArc(rect, startAngle, -Mathf.PI, forceMoveTo);
path.arcTo(rect, startAngle, -Mathf.PI, forceMoveTo);
path.addArc(rect, startAngle, -Mathf.PI, false);
path.arcTo(rect, startAngle, -Mathf.PI, false);
startAngle -= Mathf.PI;
forceMoveTo = false;
sweepAngle += Mathf.PI * 2;

path.addArc(rect, startAngle, Mathf.PI, forceMoveTo);
path.arcTo(rect, startAngle, Mathf.PI, forceMoveTo);
path.addArc(rect, startAngle, Mathf.PI, false);
path.arcTo(rect, startAngle, Mathf.PI, false);
path.addArc(rect, startAngle, sweepAngle, forceMoveTo);
path.arcTo(rect, startAngle, sweepAngle, forceMoveTo);
if (useCenter) {
path.close();
}

41
Runtime/ui/painting/path.cs


x + x0, y + y0,
});
}
}
}
public void relativeLineTo(float x, float y) {
var x0 = this._commandx;
var y0 = this._commandy;
this._appendCommands(new[] {
(float) PathCommand.lineTo,
x + x0, y + y0,
});
}
public void lineTo(float x, float y) {
this._appendCommands(new[] {
(float) PathCommand.lineTo,

public void bezierTo(float c1x, float c1y, float c2x, float c2y, float x, float y) {
public void cubicTo(float c1x, float c1y, float c2x, float c2y, float x, float y) {
public void relativeCubicTo(float c1x, float c1y, float c2x, float c2y, float x, float y) {
var x0 = this._commandx;
var y0 = this._commandy;
this.cubicTo(x0 + c1x, y0 + c1y, x0 + c2x, y0 + c2y, x0 + x, y0 + y);
}
public void quadTo(float cx, float cy, float x, float y) {
public void quadraticBezierTo(float cx, float cy, float x, float y) {
var x0 = this._commandx;
var y0 = this._commandy;

(x + 2.0f / 3.0f * (cx - x)), (y + 2.0f / 3.0f * (cy - y)),
x, y,
});
}
public void relativeQuadraticBezierTo(float cx, float cy, float x, float y) {
var x0 = this._commandx;
var y0 = this._commandy;
this.quadraticBezierTo(x0 + cx, y0 + cy, x0 + x, y0 + y);
}
public void close() {

this.addArc(cx, cy, radius, a0, a1, dir);
}
public void addArc(Rect rect, float startAngle, float sweepAngle, bool forceMoveTo = true) {
public void arcTo(Rect rect, float startAngle, float sweepAngle, bool forceMoveTo = true) {
var mat = Matrix3.makeScale(rect.width / 2, rect.height / 2);
var center = rect.center;
mat.postTranslate(center.dx, center.dy);

this._transformCommands(vals, mat);
this._appendCommands(vals.ToArray());
}
public void addArc(Rect rect, float startAngle, float sweepAngle) {
this.arcTo(rect, startAngle, sweepAngle, true);
}
public Path transform(Matrix3 mat) {

var res1 = mat.mapXY(this._commands[i + 1], this._commands[i + 2]);
var res2 = mat.mapXY(this._commands[i + 3], this._commands[i + 4]);
var res3 = mat.mapXY(this._commands[i + 5], this._commands[i + 6]);
ret.bezierTo(res1.dx, res1.dy, res2.dx, res2.dy, res3.dx, res3.dy);
ret.cubicTo(res1.dx, res1.dy, res2.dx, res2.dy, res3.dx, res3.dy);
i += 7;
break;
case PathCommand.close:

2
Runtime/widgets/binding.cs


Application.Quit();
return;
}
this._observers[idx].didPopRoute().Then(_handlePopRouteSub);
this._observers[idx].didPopRoute().Then((Action<bool>) _handlePopRouteSub);
}
}

正在加载...
取消
保存