mirror of
https://github.com/XCharts-Team/XCharts.git
synced 2026-05-26 19:00:24 +00:00
增加垂直簇状柱形图
This commit is contained in:
@@ -30,28 +30,58 @@ namespace xcharts
|
|||||||
{
|
{
|
||||||
base.OnPopulateMesh(vh);
|
base.OnPopulateMesh(vh);
|
||||||
|
|
||||||
float seriesCount = seriesList.Count;
|
if(yAxis.type == AxisType.category)
|
||||||
float scaleWid = coordinateWid / (xAxis.scaleNum - 1);
|
|
||||||
float barWid = barData.barWid > 1 ? barData.barWid : scaleWid * barData.barWid;
|
|
||||||
float offset = (scaleWid - barWid * seriesCount - barData.space *(seriesCount-1)) / 2;
|
|
||||||
float max = GetMaxValue();
|
|
||||||
for (int j = 0; j < seriesCount; j++)
|
|
||||||
{
|
{
|
||||||
if (!legend.IsShowSeries(j)) continue;
|
float seriesCount = seriesList.Count;
|
||||||
Series series = seriesList[j];
|
float scaleWid = coordinateHig / (yAxis.scaleNum - 1);
|
||||||
Color color = legend.GetColor(j);
|
float barWid = barData.barWid > 1 ? barData.barWid : scaleWid * barData.barWid;
|
||||||
for (int i = 0; i < series.dataList.Count; i++)
|
float offset = (scaleWid - barWid * seriesCount - barData.space * (seriesCount - 1)) / 2;
|
||||||
|
float max = GetMaxValue();
|
||||||
|
for (int j = 0; j < seriesCount; j++)
|
||||||
{
|
{
|
||||||
SeriesData data = series.dataList[i];
|
if (!legend.IsShowSeries(j)) continue;
|
||||||
float pX = zeroX + i * coordinateWid / (xAxis.scaleNum - 1);
|
Series series = seriesList[j];
|
||||||
float pY = zeroY + coordinate.tickness;
|
Color color = legend.GetColor(j);
|
||||||
float barHig = data.value / max * coordinateHig;
|
for (int i = 0; i < series.dataList.Count; i++)
|
||||||
float space = offset + j * (barWid + barData.space);
|
{
|
||||||
Vector3 p1 = new Vector3(pX + space, pY);
|
SeriesData data = series.dataList[i];
|
||||||
Vector3 p2 = new Vector3(pX + space, pY + barHig);
|
float pX = zeroX + coordinate.tickness;
|
||||||
Vector3 p3 = new Vector3(pX + space + barWid, pY + barHig);
|
float pY = zeroY + i * coordinateHig / (yAxis.scaleNum - 1);
|
||||||
Vector3 p4 = new Vector3(pX + space + barWid, pY);
|
float barHig = data.value / max * coordinateWid;
|
||||||
ChartUtils.DrawPolygon(vh, p1, p2, p3, p4, color);
|
float space = offset + j * (barWid + barData.space);
|
||||||
|
Vector3 p1 = new Vector3(pX, pY + space + barWid);
|
||||||
|
Vector3 p2 = new Vector3(pX + barHig, pY + space + barWid);
|
||||||
|
Vector3 p3 = new Vector3(pX + barHig, pY + space);
|
||||||
|
Vector3 p4 = new Vector3(pX, pY + space);
|
||||||
|
ChartUtils.DrawPolygon(vh, p1, p2, p3, p4, color);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
float seriesCount = seriesList.Count;
|
||||||
|
float scaleWid = coordinateWid / (xAxis.scaleNum - 1);
|
||||||
|
float barWid = barData.barWid > 1 ? barData.barWid : scaleWid * barData.barWid;
|
||||||
|
float offset = (scaleWid - barWid * seriesCount - barData.space * (seriesCount - 1)) / 2;
|
||||||
|
float max = GetMaxValue();
|
||||||
|
for (int j = 0; j < seriesCount; j++)
|
||||||
|
{
|
||||||
|
if (!legend.IsShowSeries(j)) continue;
|
||||||
|
Series series = seriesList[j];
|
||||||
|
Color color = legend.GetColor(j);
|
||||||
|
for (int i = 0; i < series.dataList.Count; i++)
|
||||||
|
{
|
||||||
|
SeriesData data = series.dataList[i];
|
||||||
|
float pX = zeroX + i * coordinateWid / (xAxis.scaleNum - 1);
|
||||||
|
float pY = zeroY + coordinate.tickness;
|
||||||
|
float barHig = data.value / max * coordinateHig;
|
||||||
|
float space = offset + j * (barWid + barData.space);
|
||||||
|
Vector3 p1 = new Vector3(pX + space, pY);
|
||||||
|
Vector3 p2 = new Vector3(pX + space, pY + barHig);
|
||||||
|
Vector3 p3 = new Vector3(pX + space + barWid, pY + barHig);
|
||||||
|
Vector3 p4 = new Vector3(pX + space + barWid, pY);
|
||||||
|
ChartUtils.DrawPolygon(vh, p1, p2, p3, p4, color);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
1389
demo.unity
1389
demo.unity
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user