Unity繪制二維動(dòng)態(tài)曲線
一、前言
之前用Line Render實(shí)現(xiàn)過(guò)這個(gè)動(dòng)態(tài)曲線的繪制,使用這個(gè)實(shí)在太不方便了,一直尋思怎么在一張圖片上通過(guò)控制圖片的像素值實(shí)現(xiàn)曲線的動(dòng)態(tài)繪制。參考了Unity的官網(wǎng)教程實(shí)現(xiàn)了這個(gè),效果圖如圖所示:

這樣實(shí)現(xiàn)的效果比LineRender 要好,并且不怎么消耗計(jì)算和渲染
二、實(shí)現(xiàn)
1、代碼創(chuàng)建一個(gè)背景貼圖,并將這個(gè)貼圖給UGUI的RawImage控件
//創(chuàng)建背景貼圖 widthPixels = (int)(Screen.width * width); heightPixels = (int)(Screen.height * height); bgTexture = new Texture2D(widthPixels, heightPixels); bgImage.texture = bgTexture; bgImage.SetNativeSize();
2、計(jì)算曲線數(shù)據(jù)列表對(duì)應(yīng)貼圖中的像素索引
int i;
int j;
if (Mathf.Abs(to.x - from.x) > Mathf.Abs(to.y - from.y))
{
// Horizontal line.
i = 0;
j = 1;
}
else
{
// Vertical line.
i = 1;
j = 0;
}
int x = (int)from[i];
int delta = (int)Mathf.Sign(to[i] - from[i]);
while (x != (int)to[i])
{
int y = (int)Mathf.Round(from[j] + (x - from[i]) * (to[j] - from[j]) / (to[i] - from[i]));
int index;
if (i == 0)
index = y * widthPixels + x;
else
index = x * widthPixels + y;
index = Mathf.Clamp(index, 0, pixelsDrawLine.Length - 1);
pixelsDrawLine[index] = color;
x += delta;
}
3、在Update里實(shí)時(shí)更新貼圖的像素值
Array.Copy(pixelsBg, pixelsDrawLine, pixelsBg.Length);
// 基準(zhǔn)線
DrawLine(new Vector2(0f, heightPixels * 0.5f), new Vector2(widthPixels, heightPixels * 0.5f), zeroColor);
for (int i = 0; i < listPoints.Count-1; i++)
{
Vector2 from = listPoints[i];
Vector2 to = listPoints[i + 1];
DrawLine(from, to, colorLine1);
}
bgTexture.SetPixels32(pixelsDrawLine);
bgTexture.Apply();
三、總結(jié)
1、比使用Line Render要節(jié)省計(jì)算和渲染
2、真正實(shí)現(xiàn)了二維的曲線繪制,Line Render始終是3維的
3、曲線坐標(biāo)的X和Y的值不能超過(guò)貼圖的寬度和高度,否則不能繪制
4、完整的工程下載地址:Unity繪制二維動(dòng)態(tài)曲線
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
10分鐘學(xué)會(huì)Visual Studio將自己創(chuàng)建的類(lèi)庫(kù)打包到NuGet進(jìn)行引用(net,net core,C#)
這篇文章主要介紹了10分鐘學(xué)會(huì)Visual Studio將自己創(chuàng)建的類(lèi)庫(kù)打包到NuGet進(jìn)行引用(net,net core,C#),本文給大家介紹的非常詳細(xì)對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09
深入淺出掌握Unity ShaderLab語(yǔ)法基礎(chǔ)
Unity中所有Shader文件都通過(guò)一種陳述性語(yǔ)言進(jìn)行描述,稱(chēng)為“ShaderLab”, 這篇文章主要介紹了Unity圖形學(xué)之ShaderLab入門(mén)基礎(chǔ),需要的朋友可以參考下2023-05-05
教你創(chuàng)建一個(gè)帶診斷工具的.NET鏡像
本文編寫(xiě)的初衷是因?yàn)樵谌豪镉泻芏嘈』锇橛龅缴a(chǎn)環(huán)境性能問(wèn)題的時(shí)候,.NET的runtime鏡像中沒(méi)有帶一些工具,安裝和使用起來(lái)很麻煩,所以分享一些我們公司內(nèi)部一些技巧,對(duì).NET鏡像帶診斷工具相關(guān)知識(shí)感興趣的朋友一起看看吧2022-07-07
Unity 百度AI實(shí)現(xiàn)人像動(dòng)漫化效果
這篇文章主要介紹了Unity如何接入百度AI接口, 運(yùn)用對(duì)抗生成網(wǎng)絡(luò)技術(shù),為用戶(hù)量身定制千人千面的二次元?jiǎng)勇蜗?,并支持通過(guò)參數(shù)設(shè)置,生成二次元?jiǎng)勇讼?。感興趣的可以學(xué)習(xí)一下2022-01-01

