Unity绘制二维动态曲线

所属分类: 软件编程 / C#教程 阅读数: 75
收藏 0 赞 0 分享

一、前言

之前用Line Render实现过这个动态曲线的绘制,使用这个实在太不方便了,一直寻思怎么在一张图片上通过控制图片的像素值实现曲线的动态绘制。参考了Unity的官网教程实现了这个,效果图如图所示:

这样实现的效果比LineRender 要好,并且不怎么消耗计算和渲染

二、实现

1、代码创建一个背景贴图,并将这个贴图给UGUI的RawImage控件

//创建背景贴图
  widthPixels = (int)(Screen.width * width);
  heightPixels = (int)(Screen.height * height);
  bgTexture = new Texture2D(widthPixels, heightPixels);
 
  bgImage.texture = bgTexture;
  bgImage.SetNativeSize();

2、计算曲线数据列表对应贴图中的像素索引

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里实时更新贴图的像素值

Array.Copy(pixelsBg, pixelsDrawLine, pixelsBg.Length);
 
  // 基准线
  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();

三、总结

1、比使用Line Render要节省计算和渲染

2、真正实现了二维的曲线绘制,Line Render始终是3维的

3、曲线坐标的X和Y的值不能超过贴图的宽度和高度,否则不能绘制

4、完整的工程下载地址:Unity绘制二维动态曲线

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

更多精彩内容其他人还在看

WPF仿三星手机充电界面实现代码

这篇文章主要为大家详细介绍了WPF仿三星手机充电界面实现代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

浅谈C#各种数组直接的数据复制/转换

下面小编就为大家带来一篇浅谈C#各种数组直接的数据复制/转换。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享

C#访问SQLServer增删改查代码实例

这篇文章主要为大家详细介绍了C#访问SQLServer增删改查代码实例,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

C#根据身份证号码判断出生日期和性别

这篇文章主要为大家详细介绍了C#根据身份证号码判断出生日期和性别的方法,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

C# 向Word中设置/更改文本方向的方法(两种)

在一般情况下word中输入的文字都是横向的,今天小编给大家带来两种方法来设置更改文本方向的方法,非常不错,对c# word 更改文本方向的知识感兴趣的朋友一起看看吧
收藏 0 赞 0 分享

让C# Excel导入导出 支持不同版本Office

让C# Excel导入导出,支持不同版本的Office,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
收藏 0 赞 0 分享

C#设置自定义文件图标实现双击启动(修改注册表)

这篇文章介绍的是利用C#设置自定义文件图标,然后实现双击启动的功能,文章给出了示例代码,介绍的很详细,有需要的可以参考借鉴。
收藏 0 赞 0 分享

C#两个相同属性的类赋值方法

这篇文章主要介绍了C#两个相同属性的类赋值方法的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

C#中ListView控件实现窗体代码

这篇文章主要介绍了C#中ListView控件实现窗体的核心代码,非常不错,具有参考借鉴价值,对c#listview相关知识感兴趣的朋友一起学习吧
收藏 0 赞 0 分享

浅谈C# 序列化与反序列化几种格式的转换

下面小编就为大家带来一篇浅谈C# 序列化与反序列化几种格式的转换。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0 赞 0 分享
查看更多