123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159 |
- using UnityEngine;
- using UnityEngine.UI;
-
- namespace XCharts.Runtime
- {
- [UnityEngine.Scripting.Preserve]
- internal sealed class XAxisHander : AxisHandler<XAxis>
- {
- protected override Orient orient { get { return Orient.Horizonal; } }
-
- public override void InitComponent()
- {
- InitXAxis(component);
- }
-
- public override void Update()
- {
- UpdateAxisMinMaxValue(component.index, component);
- UpdatePointerValue(component);
- }
-
- public override void DrawBase(VertexHelper vh)
- {
- UpdatePosition(component);
- DrawXAxisSplit(vh, component);
- DrawXAxisLine(vh, component);
- DrawXAxisTick(vh, component);
- }
-
- private void UpdatePosition(XAxis axis)
- {
- var grid = chart.GetChartComponent<GridCoord>(axis.gridIndex);
- if (grid != null)
- {
- var relativedAxis = chart.GetChartComponent<YAxis>(axis.gridIndex);
- axis.context.x = grid.context.x;
- axis.context.y = AxisHelper.GetXAxisXOrY(grid, axis, relativedAxis);
- axis.context.zeroY = grid.context.y;
- axis.context.zeroX = grid.context.x + axis.context.offset;
- }
- }
-
- private void InitXAxis(XAxis xAxis)
- {
- var theme = chart.theme;
- var xAxisIndex = xAxis.index;
- xAxis.painter = chart.painter;
- xAxis.refreshComponent = delegate()
- {
- var grid = chart.GetChartComponent<GridCoord>(xAxis.gridIndex);
- if (grid != null)
- {
- var yAxis = chart.GetChartComponent<YAxis>(xAxis.index);
- InitAxis(yAxis,
- orient,
- grid.context.x,
- grid.context.y,
- grid.context.width,
- grid.context.height);
- }
- };
- xAxis.refreshComponent();
- }
-
- internal override void UpdateAxisLabelText(Axis axis)
- {
- base.UpdateAxisLabelText(axis);
- if (axis.IsTime() || axis.IsValue())
- {
- for (int i = 0; i < axis.context.labelObjectList.Count; i++)
- {
- var label = axis.context.labelObjectList[i];
- if (label != null)
- {
- var pos = GetLabelPosition(0, i);
- label.SetPosition(pos);
- CheckValueLabelActive(component, i, label, pos);
- }
- }
- }
- }
-
- protected override Vector3 GetLabelPosition(float scaleWid, int i)
- {
- var grid = chart.GetChartComponent<GridCoord>(component.gridIndex);
- if (grid == null)
- return Vector3.zero;
-
- var yAxis = chart.GetChartComponent<YAxis>(component.index);
- return GetLabelPosition(i, Orient.Horizonal, component, yAxis,
- chart.theme.axis,
- scaleWid,
- grid.context.x,
- grid.context.y,
- grid.context.width,
- grid.context.height);
- }
-
- private void DrawXAxisSplit(VertexHelper vh, XAxis xAxis)
- {
- if (AxisHelper.NeedShowSplit(xAxis))
- {
- var grid = chart.GetChartComponent<GridCoord>(xAxis.gridIndex);
- if (grid == null)
- return;
-
- var relativedAxis = chart.GetChartComponent<YAxis>(xAxis.gridIndex);
- var dataZoom = chart.GetDataZoomOfAxis(xAxis);
-
- DrawAxisSplit(vh, chart.theme.axis, dataZoom,
- Orient.Horizonal,
- grid.context.x,
- grid.context.y,
- grid.context.width,
- grid.context.height,
- relativedAxis);
- }
- }
-
- private void DrawXAxisTick(VertexHelper vh, XAxis xAxis)
- {
- if (AxisHelper.NeedShowSplit(xAxis))
- {
- var grid = chart.GetChartComponent<GridCoord>(xAxis.gridIndex);
- if (grid == null)
- return;
-
- var dataZoom = chart.GetDataZoomOfAxis(xAxis);
-
- DrawAxisTick(vh, xAxis, chart.theme.axis, dataZoom,
- Orient.Horizonal,
- grid.context.x,
- GetAxisLineXOrY(),
- grid.context.width);
- }
- }
-
- private void DrawXAxisLine(VertexHelper vh, XAxis xAxis)
- {
- if (xAxis.show && xAxis.axisLine.show)
- {
- var grid = chart.GetChartComponent<GridCoord>(xAxis.gridIndex);
- if (grid == null)
- return;
-
- DrawAxisLine(vh, xAxis, chart.theme.axis,
- Orient.Horizonal,
- grid.context.x,
- GetAxisLineXOrY(),
- grid.context.width);
- }
- }
-
- internal override float GetAxisLineXOrY()
- {
- return component.context.y;
- }
- }
- }
|