using System; using UnityEngine; namespace XCharts { /// /// Text label of chart, to explain some data information about graphic item like value, name and so on. /// 图形上的文本标签,可用于说明图形的一些数据信息,比如值,名称等。 /// [System.Serializable] public class LabelStyle : ChildComponent, ISerieExtraComponent, ISerieDataComponent { /// /// The position of label. /// 标签的位置。 /// public enum Position { /// /// Outside of sectors of pie chart, which relates to corresponding sector through visual guide line. /// 饼图扇区外侧,通过视觉引导线连到相应的扇区。 /// Outside, /// /// Inside the sectors of pie chart. /// 饼图扇区内部。 /// Inside, /// /// In the center of pie chart. /// 在饼图中心位置。 /// Center, /// /// top of symbol. /// 图形标志的顶部。 /// Top, /// /// the bottom of symbol. /// 图形标志的底部。 /// Bottom, /// /// the left of symbol. /// 图形标志的左边。 /// Left, /// /// the right of symbol. /// 图形标志的右边。 /// Right, /// /// the start of line. /// 线的起始点。 /// Start, /// /// the middle of line. /// 线的中点。 /// Middle, /// /// the end of line. /// 线的结束点。 /// End } [SerializeField] private bool m_Show = true; [SerializeField] Position m_Position = Position.Outside; [SerializeField] private Vector3 m_Offset; [SerializeField] private float m_Distance; [SerializeField] private string m_Formatter; [SerializeField] private float m_PaddingLeftRight = 2f; [SerializeField] private float m_PaddingTopBottom = 2f; [SerializeField] private float m_BackgroundWidth = 0; [SerializeField] private float m_BackgroundHeight = 0; [SerializeField] private string m_NumericFormatter = ""; [SerializeField] private bool m_AutoOffset = false; [SerializeField] private bool m_AutoColor = false; [SerializeField] private TextStyle m_TextStyle = new TextStyle(); private DelegateSerieLabelFormatter m_FormatterFunction; public void Reset() { m_Show = false; m_Position = Position.Outside; m_Offset = Vector3.zero; m_Distance = 0; m_PaddingLeftRight = 2f; m_PaddingTopBottom = 2f; m_BackgroundWidth = 0; m_BackgroundHeight = 0; m_NumericFormatter = ""; m_AutoOffset = false; m_AutoColor = false; } /// /// Whether the label is showed. /// 是否显示文本标签。 /// public bool show { get { return m_Show; } set { if (PropertyUtil.SetStruct(ref m_Show, value)) SetAllDirty(); } } /// /// The position of label. /// 标签的位置。 /// public Position position { get { return m_Position; } set { if (PropertyUtil.SetStruct(ref m_Position, value)) SetVerticesDirty(); } } /// /// 标签内容字符串模版格式器。支持用 \n 换行。 /// 模板变量有: /// /// {a}:系列名。 /// {b}:数据名。 /// {c}:数据值。 /// {d}:百分比。 /// /// /// /// 示例:“{b}:{c}” /// public string formatter { get { return m_Formatter; } set { if (PropertyUtil.SetClass(ref m_Formatter, value)) SetVerticesDirty(); } } /// /// offset to the host graphic element. /// 距离图形元素的偏移 /// public Vector3 offset { get { return m_Offset; } set { if (PropertyUtil.SetStruct(ref m_Offset, value)) SetVerticesDirty(); } } /// /// 距离轴线的距离。 /// public float distance { get { return m_Distance; } set { if (PropertyUtil.SetStruct(ref m_Distance, value)) SetVerticesDirty(); } } /// /// the width of background. If set as default value 0, it means than the background width auto set as the text width. /// 标签的背景宽度。一般不用指定,不指定时则自动是文字的宽度。 /// /// public float backgroundWidth { get { return m_BackgroundWidth; } set { if (PropertyUtil.SetStruct(ref m_BackgroundWidth, value)) SetComponentDirty(); } } /// /// the height of background. If set as default value 0, it means than the background height auto set as the text height. /// 标签的背景高度。一般不用指定,不指定时则自动是文字的高度。 /// /// public float backgroundHeight { get { return m_BackgroundHeight; } set { if (PropertyUtil.SetStruct(ref m_BackgroundHeight, value)) SetComponentDirty(); } } /// /// the text padding of left and right. defaut:2. /// 左右边距。 /// public float paddingLeftRight { get { return m_PaddingLeftRight; } set { if (PropertyUtil.SetStruct(ref m_PaddingLeftRight, value)) SetComponentDirty(); } } /// /// the text padding of top and bottom. defaut:2. /// 上下边距。 /// public float paddingTopBottom { get { return m_PaddingTopBottom; } set { if (PropertyUtil.SetStruct(ref m_PaddingTopBottom, value)) SetComponentDirty(); } } /// /// Standard numeric format strings. /// 标准数字格式字符串。用于将数值格式化显示为字符串。 /// 使用Axx的形式:A是格式说明符的单字符,支持C货币、D十进制、E指数、F定点数、G常规、N数字、P百分比、R往返、X十六进制的。xx是精度说明,从0-99。 /// 参考:https://docs.microsoft.com/zh-cn/dotnet/standard/base-types/standard-numeric-format-strings /// /// public string numericFormatter { get { return m_NumericFormatter; } set { if (PropertyUtil.SetClass(ref m_NumericFormatter, value)) SetComponentDirty(); } } /// /// 是否开启自动偏移。当开启时,Y的偏移会自动判断曲线的开口来决定向上还是向下偏移。 /// public bool autoOffset { get { return m_AutoOffset; } set { if (PropertyUtil.SetStruct(ref m_AutoOffset, value)) SetAllDirty(); } } /// /// 是否开启自动颜色。当开启时,会根据已支持的serie自动设置颜色。 /// public bool autoColor { get { return m_AutoColor; } set { if (PropertyUtil.SetStruct(ref m_AutoColor, value)) SetAllDirty(); } } /// /// the sytle of text. /// 文本样式。 /// public TextStyle textStyle { get { return m_TextStyle; } set { if (PropertyUtil.SetClass(ref m_TextStyle, value)) SetAllDirty(); } } public DelegateSerieLabelFormatter formatterFunction { get { return m_FormatterFunction; } set { m_FormatterFunction = value; } } public bool IsInside() { return position == Position.Inside || position == Position.Center; } public Vector3 GetOffset(float radius) { var x = ChartHelper.GetActualValue(m_Offset.x, radius); var y = ChartHelper.GetActualValue(m_Offset.y, radius); var z = ChartHelper.GetActualValue(m_Offset.z, radius); return new Vector3(x, y, z); } public Color GetColor(Color defaultColor) { if (ChartHelper.IsClearColor(textStyle.color)) { return IsInside() ? Color.black : defaultColor; } else { return textStyle.color; } } public TextAnchor GetAutoAlignment() { if (textStyle.autoAlign) return textStyle.alignment; else { switch (position) { case LabelStyle.Position.Inside: case LabelStyle.Position.Center: case LabelStyle.Position.Top: case LabelStyle.Position.Bottom: return TextAnchor.MiddleCenter; case LabelStyle.Position.Outside: case LabelStyle.Position.Right: return TextAnchor.MiddleLeft; case LabelStyle.Position.Left: return TextAnchor.MiddleRight; default: return TextAnchor.MiddleCenter; } } } } }