棒グラフのスクリプトメモです。
コードC#
using UnityEngine;
using UnityEngine.UI;
[RequireComponent(typeof(CanvasRenderer))]
[ExecuteInEditMode]
public class BarGraph : Graphic
{
public float[] data;
float graphWidth;
float graphHeight;
float barWidth;
float maxDataValue;
protected override void OnPopulateMesh(VertexHelper vh)
{
vh.Clear();
if (data == null || data.Length == 0) return;
graphWidth = rectTransform.rect.width;
graphHeight = rectTransform.rect.height;
barWidth = graphWidth / data.Length;
maxDataValue = Mathf.Max(data);
for (int i = 0; i < data.Length; i++)
{
float barHeight = (data[i] / maxDataValue) * graphHeight;
UIVertex[] quad = new UIVertex[4];
quad[0].position = new Vector3(i * barWidth, 0);
quad[1].position = new Vector3(i * barWidth + barWidth, 0);
quad[2].position = new Vector3(i * barWidth + barWidth, barHeight);
quad[3].position = new Vector3(i * barWidth, barHeight);
quad[0].color = color;
quad[1].color = color;
quad[2].color = color;
quad[3].color = color;
vh.AddUIVertexQuad(quad);
}
}
}
使い方
キャンバス内に空のオブジェクトを作成する
data:image/s3,"s3://crabby-images/05b46/05b46d2088fd546e7e5b0bda5073e13c393a6c9f" alt=""
オブジェクトにBarGraphスクリプトを貼り付ける
data:image/s3,"s3://crabby-images/2f190/2f1905b4a34aae226f9e875562292a2b45e71308" alt=""
完成
data:image/s3,"s3://crabby-images/05594/05594cfba790180515e60b3d8d5ab13813fad4f6" alt=""
任意:pivotの値を0,0にする
data:image/s3,"s3://crabby-images/b02ba/b02ba92c7b027b9c6a7e5d991b9b347615966211" alt=""
data:image/s3,"s3://crabby-images/77d41/77d4151d42cba42b09b0ca8e8451a5a601fbd167" alt=""
基準の位置はスクリプトを書き直しても変更できます。
コメント