中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

UnityUI中怎么繪制線狀統計圖

發布時間:2022-04-11 10:39:40 來源:億速云 閱讀:124 作者:iii 欄目:開發技術

這篇“UnityUI中怎么繪制線狀統計圖”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“UnityUI中怎么繪制線狀統計圖”文章吧。

先來個效果圖

UnityUI中怎么繪制線狀統計圖
覺得不好看可以自己調整

1.繪制數據點

線狀圖一般由數據點和連線組成
在繪制連線之前,我們先標出數據點
這里我選擇用Image圖片來繪制數據點

新建Canvas,添加空物體Graph
在Graph上添加空物體 GraphContainer 和 Image BackGround
在 GraphContainer 上添加 Image BackGround

UnityUI中怎么繪制線狀統計圖

修改兩個BackGround的大小和顏色制作背景

UnityUI中怎么繪制線狀統計圖

注意:這里GraphContainer 錨點為左下角
左下角默認為原點(0,0),之后所有的圖形繪制都會在GraphContainer之內

UnityUI中怎么繪制線狀統計圖

UnityUI中怎么繪制線狀統計圖

在Graph上新建腳本MyGraph

public class MyGraph : MonoBehaviour
{
    [SerializeField]
    private Sprite circleSprite;	//需要畫的圖像,這里賦值為了一個Unity自帶的圓形,也可改為其它圖形

    private RectTransform graphContainer;	//聲明一個 RectTransform,用于修改圖片的大小
    
    private void Awake()
    {
        //獲取graphContainer的RectTransform并賦值,為內側的小矩形,會作為我們的畫板
        graphContainer = transform.Find("GraphContainer").GetComponent<RectTransform>();
        CreateCircle(new Vector2(200, 200));	//在(200,200)的地方創建圓,用于測試
    }

    private void CreateCircle(Vector2 anchoredPosition)
    {
        GameObject gameObject = new GameObject("circle", typeof(Image));	//生成新物體,該物體包含一個圖片組件
        gameObject.transform.SetParent(graphContainer, false);			//將圖片設為graphContainer的子物體
        gameObject.GetComponent<Image>().sprite = circleSprite;			//將圖片賦值為Inspector中設置的圖片

        //獲取新建圖片物體的RectTransform并賦值
        RectTransform rectTransform = gameObject.GetComponent<RectTransform>();
        rectTransform.anchoredPosition = anchoredPosition;			//設置圖片位置
        rectTransform.sizeDelta = new Vector2(20, 20);				//設置圖片大小,可設為公共變量來修改
        
        //下面兩句將生成圖片的錨點設為了父物體左下角(原點)
        rectTransform.anchorMin = new Vector2(0, 0);
        rectTransform.anchorMax = new Vector2(0, 0);
    }
}

運行后便會出現一個點

UnityUI中怎么繪制線狀統計圖

2.根據List列表輸入繪制出多個圓點

繼續修改MyGraph

public class MyGraph : MonoBehaviour
{
    //[SerializeField]
    //private Sprite circleSprite;

    //private RectTransform graphContainer;
    private void Awake()
    {
        //graphContainer = transform.Find("GraphContainer").GetComponent<RectTransform>();
        //聲明一個列表用于測試
        List<int> valueList = new List<int>() { 1, 2, 4, 9, 16, 25, 36, 49, 64, 81, 100, 80, 50, 20, 10 };
        ShowGraph(valueList);
    }

    private void CreateCircle(Vector2 anchoredPosition)
    {
        ......
    }

    private void ShowGraph(List<int> valueList)
    {
        int maxValue = 0;
        foreach (int value in valueList)	//找出列表中的最大值
        {
            if (maxValue <= value)
            {
                maxValue = value;
            }
        }
        
        float graphWidth = graphContainer.sizeDelta.x;	    //獲取畫布graphContainer的寬度
        float graphHeight = graphContainer.sizeDelta.y;	    //獲取畫布graphContainer的高度

        float xSpace = graphWidth / (valueList.Count - 1);  //數據點x坐標的間距
        float ySpace = graphHeight / maxValue;		    //數據的y坐標的比例

        for (int i = 0; i < valueList.Count; i++)
        {
            float xPos = i * xSpace;			    //x坐標為線性固定增長
            float yPos = ySpace * valueList[i];		    //y坐標是以列表中最大值為畫布高度,按值的大小與最大值的比例取高度
            CreateCircle(new Vector2(xPos, yPos));	    //畫出點
        }
    }
}

運行顯示結果

UnityUI中怎么繪制線狀統計圖

為了好看點,可以將內側灰色的背景放大點

UnityUI中怎么繪制線狀統計圖

所有點都在 GraphContainer 之內,點在x坐標平均分布,最高點為列表中的最大值

UnityUI中怎么繪制線狀統計圖

3.繪制點之間的連線

這里點之間的連線我仍然使用Image,只要Image足夠細就能夠看作線條
之后我會嘗試能否使用LineRenderer
這里畫線的想法是在兩點中點創建一個線條狀的Image,然后旋轉一定角度

UnityUI中怎么繪制線狀統計圖

繼續修改MyGraph

public class MyGraph : MonoBehaviour
{
    ......
    private void ShowGraph(List<int> valueList)
    {
        ......

        float xSpace = graphWidth / (valueList.Count - 1);
        float ySpace = graphHeight / maxValue;

        GameObject lastPoint = null;	//用于保存上一個點,畫出上一個點到現在點的連線,這樣就不用管最后一個點
        for (int i = 0; i < valueList.Count; i++)
        {
            //float xPos = i * xSpace;
            //float yPos = ySpace * valueList[i];
            
            GameObject circleGameobject = CreateCircle(new Vector2(xPos, yPos));//獲取創建的點
            if (lastPoint != null)
            {
                //畫線,參數為上一個點的位置,和當前點的位置
                DrawLine(lastPoint.GetComponent<RectTransform>().anchoredPosition, circleGameobject.GetComponent<RectTransform>().anchoredPosition);
            }
            lastPoint = circleGameobject;	//畫完連線之后,變為上一個點
        }
    }

    private void DrawLine(Vector2 pointA, Vector2 pointB)	//畫線方法
    {
        GameObject gameObject = new GameObject("line", typeof(Image));//新建一個物體包含一個Image組件
        gameObject.transform.SetParent(graphContainer, false);		 //將該圖片設為graphContainer的子物體
																//就是在畫板內畫線
        RectTransform rectTransform = gameObject.GetComponent<RectTransform>();	//獲取 RectTransform 組件
        Vector2 dir = pointB - pointA;	//兩點間的向量

        //同樣將線段錨點設為畫板左下角(原點)
        rectTransform.anchorMin = new Vector2(0, 0);
        rectTransform.anchorMax = new Vector2(0, 0);
        rectTransform.sizeDelta = new Vector2(dir.magnitude, 3f);	//線段的長寬,長為兩點間向量的長度,就是兩點間距離

        rectTransform.anchoredPosition = pointA + dir / 2;			//線段的中心點,為兩點間的中心點
        float angle = RotateAngle(dir.x, dir.y);				   //線段的旋轉角度
        rectTransform.localEulerAngles = new Vector3(0, 0, angle);	//旋轉線段
    }
    private float RotateAngle(float x, float y)	//旋轉方法
    {
        float angle = Mathf.Atan2(y, x) * 180 / 3.14f;//Atan2返回的是弧度,需要乘以180/PI得到角度,這里PI直接用了3.14
        return angle;
    }
}

RotateAngle()方法中Mathf.Atan2會返回角&theta;的弧度

UnityUI中怎么繪制線狀統計圖

圖片所示情況會返回正數,如果右邊的點更矮則是負數,可以直接用于旋轉

運行后顯示效果:

UnityUI中怎么繪制線狀統計圖

以上就是關于“UnityUI中怎么繪制線狀統計圖”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

根河市| 台东市| 丰台区| 贺州市| 科尔| 迭部县| 花垣县| 漠河县| 南和县| 德昌县| 自治县| 阳东县| 格尔木市| 安国市| 鄂托克前旗| 杂多县| 武安市| 郴州市| 炉霍县| 弥渡县| 苗栗县| 石河子市| 西和县| 井陉县| 永清县| 台湾省| 合作市| 拉萨市| 竹山县| 长岛县| 阿坝| 恩平市| 固安县| 九龙城区| 遂宁市| 梨树县| 博湖县| 灵璧县| 渭源县| 临安市| 分宜县|