您最多选择25个主题
主题必须以中文或者字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符
867 行
26 KiB
867 行
26 KiB
using System;
|
|
using JetBrains.Annotations;
|
|
using Unity.UIWidgets.foundation;
|
|
using Unity.UIWidgets.ui;
|
|
using UnityEngine;
|
|
using Rect = Unity.UIWidgets.ui.Rect;
|
|
|
|
namespace Unity.UIWidgets.painting {
|
|
public abstract class EdgeInsetsGeometry {
|
|
internal float _bottom { get; }
|
|
internal float _end { get; }
|
|
internal float _left { get; }
|
|
internal float _right { get; }
|
|
internal float _start { get; }
|
|
internal float _top { get; }
|
|
|
|
|
|
public static EdgeInsetsGeometry infinity = _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;
|
|
}
|
|
}
|
|
|
|
|
|
float horizontal {
|
|
get { return _left + _right + _start + _end; }
|
|
}
|
|
|
|
float vertical {
|
|
get { return _top + _bottom; }
|
|
}
|
|
|
|
|
|
float? along(Axis axis) {
|
|
D.assert(axis != null);
|
|
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);
|
|
}
|
|
|
|
protected 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
|
|
);
|
|
}
|
|
|
|
protected 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 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 static EdgeInsetsGeometry operator -(EdgeInsetsGeometry a, EdgeInsetsGeometry b) {
|
|
return _MixedEdgeInsets.fromLRSETB(
|
|
a._left - b._left,
|
|
a._right - b._right,
|
|
a._start - b._start,
|
|
a._end - b._end,
|
|
a._top - b._top,
|
|
a._bottom - b._bottom
|
|
);
|
|
}
|
|
|
|
public static EdgeInsetsGeometry operator +(EdgeInsetsGeometry a, EdgeInsetsGeometry b) {
|
|
return _MixedEdgeInsets.fromLRSETB(
|
|
a._left + b._left,
|
|
a._right + b._right,
|
|
a._start + b._start,
|
|
a._end + b._end,
|
|
a._top + b._top,
|
|
a._bottom + b._bottom
|
|
);
|
|
}
|
|
|
|
public static EdgeInsetsGeometry operator -(EdgeInsetsGeometry a) {
|
|
return _MixedEdgeInsets.fromLRSETB(
|
|
-a._left,
|
|
-a._right,
|
|
-a._start,
|
|
-a._end,
|
|
-a._top,
|
|
-a._bottom
|
|
);
|
|
}
|
|
|
|
public static EdgeInsetsGeometry operator *(EdgeInsetsGeometry a, float other) {
|
|
return _MixedEdgeInsets.fromLRSETB(
|
|
a._left * other,
|
|
a._right * other,
|
|
a._start * other,
|
|
a._end * other,
|
|
a._top * other,
|
|
a._bottom * other
|
|
);
|
|
}
|
|
|
|
public static EdgeInsetsGeometry operator /(EdgeInsetsGeometry a, float other) {
|
|
return _MixedEdgeInsets.fromLRSETB(
|
|
a._left / other,
|
|
a._right / other,
|
|
a._start / other,
|
|
a._end / other,
|
|
a._top / other,
|
|
a._bottom / other
|
|
);
|
|
}
|
|
|
|
public static EdgeInsetsGeometry operator %(EdgeInsetsGeometry a, float other) {
|
|
return _MixedEdgeInsets.fromLRSETB(
|
|
a._left % other,
|
|
a._right % other,
|
|
a._start % other,
|
|
a._end % other,
|
|
a._top % other,
|
|
a._bottom % other
|
|
);
|
|
}
|
|
|
|
|
|
public static EdgeInsetsGeometry lerp(EdgeInsetsGeometry a, EdgeInsetsGeometry b, float t) {
|
|
D.assert(t != null);
|
|
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(a, b, t);
|
|
|
|
return _MixedEdgeInsets.fromLRSETB(
|
|
Mathf.Lerp(a._left, b._left, t),
|
|
Mathf.Lerp(a._right, b._right, t),
|
|
Mathf.Lerp(a._start, b._start, t),
|
|
Mathf.Lerp(a._end, b._end, t),
|
|
Mathf.Lerp(a._top, b._top, t),
|
|
Mathf.Lerp(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((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();
|
|
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);
|
|
}
|
|
}
|
|
|
|
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;
|
|
|
|
float _start {
|
|
get { return start; }
|
|
}
|
|
|
|
public readonly float end;
|
|
|
|
float _end {
|
|
get { return end; }
|
|
}
|
|
|
|
public readonly float top;
|
|
|
|
float _top {
|
|
get { return top; }
|
|
}
|
|
|
|
public readonly float bottom;
|
|
|
|
float _bottom {
|
|
get { return bottom; }
|
|
}
|
|
|
|
float _left {
|
|
get { return 0f; }
|
|
}
|
|
|
|
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, float top = 0, float end = 0, float bottom = 0) {
|
|
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 EdgeInsetsGeometry subtract(EdgeInsetsDirectional other) {
|
|
if (other is EdgeInsetsDirectional)
|
|
return this - other;
|
|
return base.subtract(other);
|
|
}
|
|
|
|
public EdgeInsetsGeometry add(EdgeInsetsDirectional other) {
|
|
if (other is EdgeInsetsDirectional)
|
|
return this + other;
|
|
return base.add(other);
|
|
}
|
|
|
|
public static EdgeInsetsDirectional operator -(EdgeInsetsDirectional a, EdgeInsetsDirectional b) {
|
|
return fromSTEB(
|
|
a.start - b.start,
|
|
a.top - b.top,
|
|
a.end - b.end,
|
|
a.bottom - b.bottom
|
|
);
|
|
}
|
|
|
|
public static EdgeInsetsDirectional operator +(EdgeInsetsDirectional a, EdgeInsetsDirectional b) {
|
|
return fromSTEB(
|
|
a.start + b.start,
|
|
a.top + b.top,
|
|
a.end + b.end,
|
|
a.bottom + b.bottom
|
|
);
|
|
}
|
|
|
|
public static EdgeInsetsDirectional operator -(EdgeInsetsDirectional a) {
|
|
return fromSTEB(
|
|
-a.start,
|
|
-a.top,
|
|
-a.end,
|
|
-a.bottom
|
|
);
|
|
}
|
|
|
|
public static EdgeInsetsDirectional operator *(EdgeInsetsDirectional a, float b) {
|
|
return fromSTEB(
|
|
a.start * b,
|
|
a.top * b,
|
|
a.end * b,
|
|
a.bottom * b
|
|
);
|
|
}
|
|
|
|
public static EdgeInsetsDirectional operator /(EdgeInsetsDirectional a, float b) {
|
|
return fromSTEB(
|
|
a.start / b,
|
|
a.top / b,
|
|
a.end / b,
|
|
a.bottom / b
|
|
);
|
|
}
|
|
|
|
public static EdgeInsetsDirectional operator %(EdgeInsetsDirectional a, float b) {
|
|
return fromSTEB(
|
|
a.start % b,
|
|
a.top % b,
|
|
a.end % b,
|
|
a.bottom % b
|
|
);
|
|
}
|
|
|
|
|
|
public static EdgeInsetsDirectional lerp(EdgeInsetsDirectional a, EdgeInsetsDirectional b, float t) {
|
|
D.assert(t != null);
|
|
if (a == null && b == null)
|
|
return null;
|
|
if (a == null)
|
|
return b * t;
|
|
if (b == null)
|
|
return a * (1.0f - t);
|
|
return fromSTEB(
|
|
Mathf.Lerp(a.start, b.start, t),
|
|
Mathf.Lerp(a.top, b.top, t),
|
|
Mathf.Lerp(a.end, b.end, t),
|
|
Mathf.Lerp(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);
|
|
}
|
|
|
|
public readonly float _left;
|
|
|
|
public readonly float _right;
|
|
|
|
public readonly float _start;
|
|
|
|
public readonly float _end;
|
|
|
|
public readonly float _top;
|
|
|
|
public readonly float _bottom;
|
|
|
|
|
|
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 static _MixedEdgeInsets operator -(_MixedEdgeInsets a, _MixedEdgeInsets b) {
|
|
return _MixedEdgeInsets.fromLRSETB(
|
|
a._left - b._left,
|
|
a._right - b._right,
|
|
a._start - b._start,
|
|
a._end - b._end,
|
|
a._top - b._top,
|
|
a._bottom - b._bottom
|
|
);
|
|
}
|
|
|
|
public static _MixedEdgeInsets operator +(_MixedEdgeInsets a, _MixedEdgeInsets b) {
|
|
return _MixedEdgeInsets.fromLRSETB(
|
|
a._left + b._left,
|
|
a._right + b._right,
|
|
a._start + b._start,
|
|
a._end + b._end,
|
|
a._top + b._top,
|
|
a._bottom + b._bottom
|
|
);
|
|
}
|
|
|
|
public static _MixedEdgeInsets operator -(_MixedEdgeInsets a) {
|
|
return _MixedEdgeInsets.fromLRSETB(
|
|
-a._left,
|
|
-a._right,
|
|
-a._start,
|
|
-a._end,
|
|
-a._top,
|
|
-a._bottom
|
|
);
|
|
}
|
|
|
|
public static _MixedEdgeInsets operator *(_MixedEdgeInsets a, float other) {
|
|
return _MixedEdgeInsets.fromLRSETB(
|
|
a._left * other,
|
|
a._right * other,
|
|
a._start * other,
|
|
a._end * other,
|
|
a._top * other,
|
|
a._bottom * other
|
|
);
|
|
}
|
|
|
|
public static _MixedEdgeInsets operator /(_MixedEdgeInsets a, float other) {
|
|
return _MixedEdgeInsets.fromLRSETB(
|
|
a._left / other,
|
|
a._right / other,
|
|
a._start / other,
|
|
a._end / other,
|
|
a._top / other,
|
|
a._bottom / other
|
|
);
|
|
}
|
|
|
|
public static _MixedEdgeInsets operator %(_MixedEdgeInsets a, float other) {
|
|
return _MixedEdgeInsets.fromLRSETB(
|
|
a._left % other,
|
|
a._right % other,
|
|
a._start % other,
|
|
a._end % other,
|
|
a._top % other,
|
|
a._bottom % other
|
|
);
|
|
}
|
|
|
|
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 infinity = fromLTRB(
|
|
float.PositiveInfinity,
|
|
float.PositiveInfinity,
|
|
float.PositiveInfinity,
|
|
float.PositiveInfinity
|
|
);
|
|
|
|
public bool isNonNegative {
|
|
get {
|
|
return left >= 0.0
|
|
&& right >= 0.0
|
|
&& top >= 0.0
|
|
&& bottom >= 0.0;
|
|
}
|
|
}
|
|
|
|
public float horizontal {
|
|
get { return left + right; }
|
|
}
|
|
|
|
public float vertical {
|
|
get { return top + bottom; }
|
|
}
|
|
|
|
public float along(Axis axis) {
|
|
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 EdgeInsets subtract(EdgeInsets other) {
|
|
return fromLTRB(
|
|
left - other.left,
|
|
top - other.top,
|
|
right - other.right,
|
|
bottom - other.bottom
|
|
);
|
|
}
|
|
|
|
public EdgeInsets add(EdgeInsetsGeometry other) {
|
|
return fromLTRB(
|
|
left + other._left,
|
|
top + other._top,
|
|
right + other._right,
|
|
bottom + other._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 static EdgeInsets operator -(EdgeInsets a, EdgeInsets b) {
|
|
return fromLTRB(
|
|
a.left - b.left,
|
|
a.top - b.top,
|
|
a.right - b.right,
|
|
a.bottom - b.bottom
|
|
);
|
|
}
|
|
|
|
public static EdgeInsets operator +(EdgeInsets a, EdgeInsets b) {
|
|
return fromLTRB(
|
|
a.left + b.left,
|
|
a.top + b.top,
|
|
a.right + b.right,
|
|
a.bottom + b.bottom
|
|
);
|
|
}
|
|
|
|
public static EdgeInsets operator -(EdgeInsets a) {
|
|
return fromLTRB(
|
|
-a.left,
|
|
-a.top,
|
|
-a.right,
|
|
-a.bottom
|
|
);
|
|
}
|
|
|
|
public static EdgeInsets operator *(EdgeInsets a, float b) {
|
|
return fromLTRB(
|
|
a.left * b,
|
|
a.top * b,
|
|
a.right * b,
|
|
a.bottom * b
|
|
);
|
|
}
|
|
|
|
public static EdgeInsets operator /(EdgeInsets a, float b) {
|
|
return fromLTRB(
|
|
a.left / b,
|
|
a.top / b,
|
|
a.right / b,
|
|
a.bottom / b
|
|
);
|
|
}
|
|
|
|
public static EdgeInsets operator %(EdgeInsets a, float b) {
|
|
return fromLTRB(
|
|
a.left % b,
|
|
a.top % b,
|
|
a.right % b,
|
|
a.bottom % b
|
|
);
|
|
}
|
|
|
|
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(
|
|
Mathf.Lerp(a.left, b.left, t),
|
|
Mathf.Lerp(a.top, b.top, t),
|
|
Mathf.Lerp(a.right, b.right, t),
|
|
Mathf.Lerp(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})";
|
|
}
|
|
}
|
|
}
|