您最多选择25个主题 主题必须以中文或者字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符
 
 
 
 
 
 

862 行
27 KiB

using System;
using Unity.UIWidgets.foundation;
using Unity.UIWidgets.ui;
using Rect = Unity.UIWidgets.ui.Rect;
namespace Unity.UIWidgets.painting {
public abstract class EdgeInsetsGeometry {
internal virtual float _bottom { get; }
internal virtual float _end { get; }
internal virtual float _left { get; }
internal virtual float _right { get; }
internal virtual float _start { get; }
internal virtual float _top { get; }
public static EdgeInsetsGeometry infinityEdgeInsetsGeometry = _MixedEdgeInsets.fromLRSETB(
float.PositiveInfinity,
float.PositiveInfinity,
float.PositiveInfinity,
float.PositiveInfinity,
float.PositiveInfinity,
float.PositiveInfinity
);
/// Whether every dimension is non-negative.
public virtual bool isNonNegative {
get {
return _left >= 0.0
&& _right >= 0.0
&& _start >= 0.0
&& _end >= 0.0
&& _top >= 0.0
&& _bottom >= 0.0;
}
}
public virtual float horizontal {
get { return _left + _right + _start + _end; }
}
public virtual float vertical {
get { return _top + _bottom; }
}
float? along(Axis axis) {
switch (axis) {
case Axis.horizontal:
return horizontal;
case Axis.vertical:
return vertical;
}
return null;
}
Size collapsedSize {
get { return new Size(horizontal, vertical); }
}
EdgeInsetsGeometry flipped {
get { return _MixedEdgeInsets.fromLRSETB(_right, _left, _end, _start, _bottom, _top); }
}
Size inflateSize(Size size) {
return new Size(size.width + horizontal, size.height + vertical);
}
Size deflateSize(Size size) {
return new Size(size.width - horizontal, size.height - vertical);
}
public virtual EdgeInsetsGeometry clamp(EdgeInsetsGeometry min, EdgeInsetsGeometry max) {
return _MixedEdgeInsets.fromLRSETB(
_left.clamp(min._left, max._left),
_right.clamp(min._right, max._right),
_start.clamp(min._start, max._start),
_end.clamp(min._end, max._end),
_top.clamp(min._top, max._top),
_bottom.clamp(min._bottom, max._bottom)
);
}
public virtual EdgeInsetsGeometry add(EdgeInsetsGeometry other) {
return _MixedEdgeInsets.fromLRSETB(
_left + other._left,
_right + other._right,
_start + other._start,
_end + other._end,
_top + other._top,
_bottom + other._bottom
);
}
public virtual EdgeInsetsGeometry subtract(EdgeInsetsGeometry other) {
return _MixedEdgeInsets.fromLRSETB(
_left - other._left,
_right - other._right,
_start - other._start,
_end - other._end,
_top - other._top,
_bottom - other._bottom
);
}
public virtual EdgeInsetsGeometry multiply(float b) {
return _MixedEdgeInsets.fromLRSETB(
_left * b,
_right * b,
_start * b,
_end * b,
_top * b,
_bottom * b
);
}
public virtual EdgeInsetsGeometry divide(float b) {
return _MixedEdgeInsets.fromLRSETB(
_left / b,
_right / b,
_start / b,
_end / b,
_top / b,
_bottom / b
);
}
public virtual EdgeInsetsGeometry remainder(float b) {
return _MixedEdgeInsets.fromLRSETB(
_left % b,
_right % b,
_start % b,
_end % b,
_top % b,
_bottom % b
);
}
public static EdgeInsetsGeometry operator -(EdgeInsetsGeometry a) {
return a.multiply(-1.0f);
}
public static EdgeInsetsGeometry operator +(EdgeInsetsGeometry a, EdgeInsetsGeometry b) {
return a.add(b);
}
public static EdgeInsetsGeometry operator -(EdgeInsetsGeometry a, EdgeInsetsGeometry b) {
return a.subtract(b);
}
public static EdgeInsetsGeometry operator *(EdgeInsetsGeometry a, float other) {
return a.multiply(other);
}
public static EdgeInsetsGeometry operator /(EdgeInsetsGeometry a, float other) {
return a.divide(other);
}
public static EdgeInsetsGeometry operator %(EdgeInsetsGeometry a, float other) {
return a.remainder(other);
}
public static EdgeInsetsGeometry lerp(EdgeInsetsGeometry a, EdgeInsetsGeometry b, float t) {
if (a == null && b == null)
return null;
if (a == null)
return b * t;
if (b == null)
return a * (1.0f - t);
if (a is EdgeInsets && b is EdgeInsets)
return EdgeInsets.lerp((EdgeInsets) a, (EdgeInsets) b, t);
if (a is EdgeInsetsDirectional && b is EdgeInsetsDirectional)
return EdgeInsetsDirectional.lerp((EdgeInsetsDirectional)a, (EdgeInsetsDirectional)b, t);
return _MixedEdgeInsets.fromLRSETB(
MathUtils.lerpNullableFloat(a._left, b._left, t),
MathUtils.lerpNullableFloat(a._right, b._right, t),
MathUtils.lerpNullableFloat(a._start, b._start, t),
MathUtils.lerpNullableFloat(a._end, b._end, t),
MathUtils.lerpNullableFloat(a._top, b._top, t),
MathUtils.lerpNullableFloat(a._bottom, b._bottom, t)
);
}
public abstract EdgeInsets resolve(TextDirection? direction);
public bool Equals(EdgeInsetsGeometry other) {
if (ReferenceEquals(null, other)) {
return false;
}
if (ReferenceEquals(this, other)) {
return true;
}
return _left.Equals(other._left)
&& _right.Equals(other._right)
&& _top.Equals(other._top)
&& _bottom.Equals(other._bottom)
&& _start.Equals(other._top)
&& _end.Equals(other._bottom);
}
public override bool Equals(object obj) {
if (ReferenceEquals(null, obj)) {
return false;
}
if (ReferenceEquals(this, obj)) {
return true;
}
if (obj.GetType() != GetType()) {
return false;
}
return Equals((EdgeInsetsGeometry) obj);
}
public override int GetHashCode() {
unchecked {
var hashCode = _left.GetHashCode();
hashCode = (hashCode * 397) ^ _right.GetHashCode();
hashCode = (hashCode * 397) ^ _top.GetHashCode();
hashCode = (hashCode * 397) ^ _bottom.GetHashCode();
hashCode = (hashCode * 397) ^ _start.GetHashCode();
hashCode = (hashCode * 397) ^ _end.GetHashCode();
return hashCode;
}
}
public override string ToString() {
if (_start == 0.0 && _end == 0.0) {
if (_left == 0.0 && _right == 0.0 && _top == 0.0 && _bottom == 0.0)
return "EdgeInsets.zero";
if (_left == _right && _right == _top && _top == _bottom)
return $"EdgeInsets.all({_left: F1})";
return $"EdgeInsets({_left: F1}, " +
$"{_top: F1}, " +
$"{_right: F1}, " +
$"{_bottom: F1})";
}
if (_left == 0.0 && _right == 0.0) {
return $"EdgeInsetsDirectional({_start: F1}, " +
$"{_top: F1}, " +
$"{_end: F1}, " +
$"{_bottom: F1})";
}
return $"EdgeInsets({_left: F1}, " +
$"{_top: F1}, " +
$"{_right: F1}, " +
$"{_bottom: F1})" +
" + " + $"EdgeInsetsDirectional({_start: F1}, " +
"0.0, " + $"{_end: F1}, " + "0.0)";
}
public static bool operator ==(EdgeInsetsGeometry a, EdgeInsetsGeometry b) {
return Equals(a, b);
}
public static bool operator !=(EdgeInsetsGeometry a, EdgeInsetsGeometry b) {
return !(a == b);
}
}
public class EdgeInsetsDirectional : EdgeInsetsGeometry {
public EdgeInsetsDirectional(float start, float top, float end, float bottom) {
this.start = start;
this.end = end;
this.top = top;
this.bottom = bottom;
}
public readonly float start;
internal override float _start {
get { return start; }
}
public readonly float end;
internal override float _end {
get { return end; }
}
public readonly float top;
internal override float _top {
get { return top; }
}
public readonly float bottom;
internal override float _bottom {
get { return bottom; }
}
internal override float _left {
get { return 0f; }
}
internal override float _right {
get { return 0f; }
}
public static EdgeInsetsDirectional fromSTEB(float start, float top, float end, float bottom) {
return new EdgeInsetsDirectional(start, top, end, bottom);
}
public static EdgeInsetsDirectional only( float start = 0.0f, float top = 0.0f,float end = 0.0f,float bottom = 0.0f) {
return new EdgeInsetsDirectional(start,top,end,bottom);
}
static EdgeInsetsDirectional zero = only();
public override bool isNonNegative {
get { return start >= 0.0 && top >= 0.0 && end >= 0.0 && bottom >= 0.0; }
}
public EdgeInsetsDirectional flipped {
get { return fromSTEB(end, bottom, start, top); }
}
public override EdgeInsetsGeometry add(EdgeInsetsGeometry other) {
return fromSTEB(
start + other._start,
end + other._end,
top + other._top,
bottom + other._bottom
);
}
public override EdgeInsetsGeometry subtract(EdgeInsetsGeometry other) {
return fromSTEB(
start - other._start,
end - other._end,
top - other._top,
bottom - other._bottom
);
}
public override EdgeInsetsGeometry multiply(float b){
return fromSTEB(
start * b,
end * b,
top * b,
bottom * b
);
}
public override EdgeInsetsGeometry divide(float b){
return fromSTEB(
start / b,
end / b,
top / b,
bottom / b
);
}
public override EdgeInsetsGeometry remainder(float b){
return fromSTEB(
start % b,
end % b,
top % b,
bottom % b
);
}
public static EdgeInsetsDirectional operator -(EdgeInsetsDirectional a) {
return a.multiply(-1.0f) as EdgeInsetsDirectional;
}
public static EdgeInsetsDirectional operator +(EdgeInsetsDirectional a, EdgeInsetsDirectional b) {
return a.add(b) as EdgeInsetsDirectional;
}
public static EdgeInsetsDirectional operator -(EdgeInsetsDirectional a, EdgeInsetsDirectional b) {
return a.subtract(b) as EdgeInsetsDirectional;
}
public static EdgeInsetsDirectional operator *(EdgeInsetsDirectional a, float b) {
return a.multiply(b) as EdgeInsetsDirectional;
}
public static EdgeInsetsDirectional operator /(EdgeInsetsDirectional a, float b) {
return a.divide(b) as EdgeInsetsDirectional;
}
public static EdgeInsetsDirectional operator %(EdgeInsetsDirectional a, float b) {
return a.remainder(b) as EdgeInsetsDirectional;
}
public static EdgeInsetsDirectional lerp(EdgeInsetsDirectional a, EdgeInsetsDirectional b, float t) {
if (a == null && b == null)
return null;
if (a == null)
return b * t;
if (b == null)
return a * (1.0f - t);
return fromSTEB(
MathUtils.lerpNullableFloat(a.start, b.start, t),
MathUtils.lerpNullableFloat(a.top, b.top, t),
MathUtils.lerpNullableFloat(a.end, b.end, t),
MathUtils.lerpNullableFloat(a.bottom, b.bottom, t)
);
}
public override EdgeInsets resolve(TextDirection? direction) {
D.assert(direction != null);
switch (direction) {
case TextDirection.rtl:
return EdgeInsets.fromLTRB(end, top, start, bottom);
case TextDirection.ltr:
return EdgeInsets.fromLTRB(start, top, end, bottom);
}
return null;
}
}
public class _MixedEdgeInsets : EdgeInsetsGeometry {
public _MixedEdgeInsets(float _left, float _right, float _start, float _end, float _top, float _bottom) {
this._left = _left;
this._right = _right;
this._start = _start;
this._end = _end;
this._top = _top;
this._bottom = _bottom;
}
public static _MixedEdgeInsets fromLRSETB(float _left, float _right, float _start, float _end, float _top,
float _bottom) {
return new _MixedEdgeInsets(_left, _right, _start, _end, _top, _bottom);
}
internal override float _left { get; }
internal override float _right { get; }
internal override float _start { get; }
internal override float _end { get; }
internal override float _top { get; }
internal override float _bottom { get; }
public override bool isNonNegative {
get {
return _left >= 0.0
&& _right >= 0.0
&& _start >= 0.0
&& _end >= 0.0
&& _top >= 0.0
&& _bottom >= 0.0;
}
}
public override EdgeInsetsGeometry add(EdgeInsetsGeometry other) {
return fromLRSETB(
_left + other._left,
_right + other._right,
_start + other._start,
_end + other._end,
_top + other._top,
_bottom + other._bottom
);
}
public override EdgeInsetsGeometry subtract(EdgeInsetsGeometry other) {
return fromLRSETB(
_left - other._left,
_right - other._right,
_start - other._start,
_end - other._end,
_top - other._top,
_bottom - other._bottom
);
}
public override EdgeInsetsGeometry multiply(float b){
return fromLRSETB(
_left * b,
_right * b,
_start * b,
_end * b,
_top * b,
_bottom * b
);
}
public override EdgeInsetsGeometry divide(float b){
return fromLRSETB(
_left / b,
_right / b,
_start / b,
_end / b,
_top / b,
_bottom / b
);
}
public override EdgeInsetsGeometry remainder(float b){
return fromLRSETB(
_left % b,
_right % b,
_start % b,
_end % b,
_top % b,
_bottom % b
);
}
public static _MixedEdgeInsets operator -(_MixedEdgeInsets a) {
return a.multiply(-1.0f) as _MixedEdgeInsets;
}
public static _MixedEdgeInsets operator +(_MixedEdgeInsets a, _MixedEdgeInsets b) {
return a.add(b) as _MixedEdgeInsets;
}
public static _MixedEdgeInsets operator -(_MixedEdgeInsets a, _MixedEdgeInsets b) {
return a.subtract(b) as _MixedEdgeInsets;
}
public static _MixedEdgeInsets operator *(_MixedEdgeInsets a, float b) {
return a.multiply(b) as _MixedEdgeInsets;
}
public static _MixedEdgeInsets operator /(_MixedEdgeInsets a, float b) {
return a.divide(b) as _MixedEdgeInsets;
}
public static _MixedEdgeInsets operator %(_MixedEdgeInsets a, float b) {
return a.remainder(b) as _MixedEdgeInsets;
}
public override EdgeInsets resolve(TextDirection? direction) {
D.assert(direction != null);
switch (direction) {
case TextDirection.rtl:
return EdgeInsets.fromLTRB(_end + _left, _top, _start + _right, _bottom);
case TextDirection.ltr:
return EdgeInsets.fromLTRB(_start + _left, _top, _end + _right, _bottom);
}
return null;
}
}
public class EdgeInsets : EdgeInsetsGeometry {
EdgeInsets(float left, float top, float right, float bottom) {
this.left = left;
this.right = right;
this.top = top;
this.bottom = bottom;
}
public readonly float left;
public readonly float right;
public readonly float top;
public readonly float bottom;
public static EdgeInsets infinityEdgeInsets = fromLTRB(
float.PositiveInfinity,
float.PositiveInfinity,
float.PositiveInfinity,
float.PositiveInfinity
);
public override bool isNonNegative {
get {
return left >= 0.0
&& right >= 0.0
&& top >= 0.0
&& bottom >= 0.0;
}
}
public override float horizontal {
get { return left + right; }
}
public override float vertical {
get { return top + bottom; }
}
public float along(Axis? axis) {
D.assert(axis != null);
switch (axis) {
case Axis.horizontal:
return horizontal;
case Axis.vertical:
return vertical;
}
throw new Exception("unknown axis");
}
public Size collapsedSize {
get { return new Size(horizontal, vertical); }
}
public EdgeInsets flipped {
get { return fromLTRB(right, bottom, left, top); }
}
public Size inflateSize(Size size) {
return new Size(size.width + horizontal, size.height + vertical);
}
public Size deflateSize(Size size) {
return new Size(size.width - horizontal, size.height - vertical);
}
public static EdgeInsets fromLTRB(float left, float top, float right, float bottom) {
return new EdgeInsets(left, top, right, bottom);
}
public static EdgeInsets all(float value) {
return new EdgeInsets(value, value, value, value);
}
public static EdgeInsets only(float left = 0.0f, float top = 0.0f, float right = 0.0f, float bottom = 0.0f) {
return new EdgeInsets(left, top, right, bottom);
}
public static EdgeInsets symmetric(float vertical = 0.0f, float horizontal = 0.0f) {
return new EdgeInsets(horizontal, vertical, horizontal, vertical);
}
public static EdgeInsets fromWindowPadding(WindowPadding padding, float devicePixelRatio) {
return new EdgeInsets(
left: padding.left / devicePixelRatio,
top: padding.top / devicePixelRatio,
right: padding.right / devicePixelRatio,
bottom: padding.bottom / devicePixelRatio
);
}
public static readonly EdgeInsets zero = only();
public Offset topLeft {
get { return new Offset(left, top); }
}
public Offset topRight {
get { return new Offset(-right, top); }
}
public Offset bottomLeft {
get { return new Offset(left, -bottom); }
}
public Offset bottomRight {
get { return new Offset(-right, -bottom); }
}
public Rect inflateRect(Rect rect) {
return Rect.fromLTRB(
rect.left - left, rect.top - top,
rect.right + right, rect.bottom + bottom);
}
public Rect deflateRect(Rect rect) {
return Rect.fromLTRB(
rect.left + left, rect.top + top,
rect.right - right, rect.bottom - bottom);
}
public override EdgeInsetsGeometry clamp(EdgeInsetsGeometry min, EdgeInsetsGeometry max) {
return fromLTRB(
left.clamp(min._left, max._left),
top.clamp(min._top, max._top),
right.clamp(min._right, max._right),
bottom.clamp(min._bottom, max._bottom)
);
}
public override EdgeInsetsGeometry add(EdgeInsetsGeometry other) {
return fromLTRB(
left + other._left,
top + other._top,
right + other._right,
bottom + other._bottom
);
}
public override EdgeInsetsGeometry subtract(EdgeInsetsGeometry other) {
return fromLTRB(
left - other._left,
top - other._top,
right - other._right,
bottom - other._bottom
);
}
public override EdgeInsetsGeometry multiply(float b){
return fromLTRB(
left * b,
top * b,
right * b,
bottom * b
);
}
public override EdgeInsetsGeometry divide(float b){
return fromLTRB(
left / b,
top / b,
right / b,
bottom / b
);
}
public override EdgeInsetsGeometry remainder(float b){
return fromLTRB(
left % b,
top % b,
right % b,
bottom % b
);
}
public static EdgeInsets operator -(EdgeInsets a) {
return a.multiply(-1.0f) as EdgeInsets;
}
public static EdgeInsets operator +(EdgeInsets a, EdgeInsets b) {
return a.add(b) as EdgeInsets;
}
public static EdgeInsets operator -(EdgeInsets a, EdgeInsets b) {
return a.subtract(b) as EdgeInsets;
}
public static EdgeInsets operator *(EdgeInsets a, float b) {
return a.multiply(b) as EdgeInsets;
}
public static EdgeInsets operator /(EdgeInsets a, float b) {
return a.divide(b) as EdgeInsets;
}
public static EdgeInsets operator %(EdgeInsets a, float b) {
return a.remainder(b) as EdgeInsets;
}
public static EdgeInsets lerp(EdgeInsets a, EdgeInsets b, float t) {
if (a == null && b == null) {
return null;
}
if (a == null) {
return b * t;
}
if (b == null) {
return a * (1.0f - t);
}
return fromLTRB(
MathUtils.lerpNullableFloat(a.left, b.left, t),
MathUtils.lerpNullableFloat(a.top, b.top, t),
MathUtils.lerpNullableFloat(a.right, b.right, t),
MathUtils.lerpNullableFloat(a.bottom, b.bottom, t)
);
}
public EdgeInsets copyWith(
float? left = null,
float? top = null,
float? right = null,
float? bottom = null
) {
return only(
left: left ?? this.left,
top: top ?? this.top,
right: right ?? this.right,
bottom: bottom ?? this.bottom
);
}
public bool Equals(EdgeInsets other) {
if (ReferenceEquals(null, other)) {
return false;
}
if (ReferenceEquals(this, other)) {
return true;
}
return left.Equals(other.left)
&& right.Equals(other.right)
&& top.Equals(other.top)
&& bottom.Equals(other.bottom);
}
public override EdgeInsets resolve(TextDirection? direction) {
return this;
}
public override bool Equals(object obj) {
if (ReferenceEquals(null, obj)) {
return false;
}
if (ReferenceEquals(this, obj)) {
return true;
}
if (obj.GetType() != GetType()) {
return false;
}
return Equals((EdgeInsets) obj);
}
public override int GetHashCode() {
unchecked {
var hashCode = left.GetHashCode();
hashCode = (hashCode * 397) ^ right.GetHashCode();
hashCode = (hashCode * 397) ^ top.GetHashCode();
hashCode = (hashCode * 397) ^ bottom.GetHashCode();
return hashCode;
}
}
public static bool operator ==(EdgeInsets a, EdgeInsets b) {
return Equals(a, b);
}
public static bool operator !=(EdgeInsets a, EdgeInsets b) {
return !(a == b);
}
public override string ToString() {
if (left == 0.0 && right == 0.0 && top == 0.0 && bottom == 0.0) {
return "EdgeInsets.zero";
}
if (left == right && right == top && top == bottom) {
return $"EdgeInsets.all({left:F1})";
}
return $"EdgeInsets({left:F1}, " +
$"{top:F1}, " +
$"{right:F1}, " +
$"{bottom:F1})";
}
}
}