当前位置: 代码迷 >> 综合 >> (十)UI Mesh
  详细解决方案

(十)UI Mesh

热度:38   发布时间:2023-11-26 15:14:15.0

文章目录

  • 1.概述
  • 2.UI Mesh
    • 2.1 操作步骤
    • 3.2 VertexHelper添加顶点
      • 3.2.1 普通方法
      • 3.2.2 顶点编辑
      • 3.2.3 顶点流方法
      • 3.2.4 添加quad
      • 3.2.5 添加三角形流

1.概述

在unity 网格系列的最后来处理一下UGUI的mesh问题。ugui所有的网格mesh默认为四边形(可以通过自定义改为特殊形状,比如圆形圆环等),边长为1,即mesh顶点坐标为四个。由于所有的ui均从Graphic类衍生,所以只要重写虚方法OnPopulateMesh即可。OnPopulateMesh存在两个,入口参数不同,一个时VertexHelper一个时Mesh。入口参数为Mesh的方法已经过失,所以本文主讲VertexHelper生成mesh的方法。如下所示:

    protected override void OnPopulateMesh(VertexHelper vh){
    base.OnPopulateMesh(vh);vh.Clear();vh.AddVert(new Vector3(-50,-50), Color.white, new Vector2(0, 0));vh.AddVert(new Vector3(50, -50), Color.red, new Vector2(1, 0));vh.AddVert(new Vector3(50, 50), Color.red, new Vector2(1, 1));vh.AddVert(new Vector3(-50, 50), Color.white, new Vector2(0, 1));vh.AddTriangle(0, 1, 2);vh.AddTriangle(0, 2, 3);}

2.UI Mesh

2.1 操作步骤

新建canvas,并在canvas下新建空的游戏物体,新建一个继承自Graphic脚本并挂载在其上。然后就可以重写OnPopulateMesh方法,并自定义网格。比如可以自定义圆形或者圆环,或者采用ui进行函数曲线的绘制等。

**注意:**在进行网格顶点计算时,要考虑ui的大小,比如概述中顶点坐标对应游戏物体大小为100*100,也可以使用方法GetPixelAdjustedRect()来获取像素大小。

3.2 VertexHelper添加顶点

3.2.1 普通方法

普通方法如概述所示,只要定义顶点,每个顶点的颜色、uv以及三角形即可。颜色可以默认为白色。

3.2.2 顶点编辑

如果要编辑某个顶点信息可以采用PopulateUIVertex方法获取到某个顶点,然后采用SetUIVertex方法重新设置顶点属性。

    void CreateMeshRegular(VertexHelper vh){
    Rect size = GetPixelAdjustedRect();vh.AddVert(new Vector3(-0.5f * size.width, -0.5f * size.height), Color.white, new Vector2(0, 0));vh.AddVert(new Vector3(0.5f * size.width, -0.5f * size.height), Color.red, new Vector2(1, 0));vh.AddVert(new Vector3(0.5f * size.width, 0.5f * size.height), Color.red, new Vector2(1, 1));vh.AddVert(new Vector3(-0.5f * size.width, 0.5f * size.height), Color.white, new Vector2(0, 1));vh.AddTriangle(0, 1, 2);vh.AddTriangle(0, 2, 3);UIVertex selectedUIVertex = new UIVertex();vh.PopulateUIVertex(ref selectedUIVertex, 2);selectedUIVertex.color = Color.green;vh.SetUIVertex(selectedUIVertex, 2);}

3.2.3 顶点流方法

顶点流方法是指采用AddUIVertexStream,通过顶点以及三角形的list添加mesh 的方法,如下所示:

   void CreateMeshByVertexStream(VertexHelper vh){
    Rect size = GetPixelAdjustedRect();UIVertex vertices0 = new UIVertex();vertices0.position = new Vector3(-0.5f * size.width, -0.5f * size.height);vertices0.color = Color.blue;vertices0.uv0 = new Vector2(0, 0);UIVertex vertices1 = new UIVertex();vertices1.position = new Vector3(0.5f * size.width, -0.5f * size.height);vertices1.color = Color.red;vertices1.uv0 = new Vector2(1, 0);UIVertex vertices2 = new UIVertex();vertices2.position = new Vector3(0.5f * size.width, 0.5f * size.height);vertices2.color = Color.red;vertices2.uv0 = new Vector2(1, 1);UIVertex vertices3 = new UIVertex();vertices3.position = new Vector3(-0.5f * size.width, 0.5f * size.height);vertices3.color = Color.white;vertices3.uv0 = new Vector2(0, 1);List<UIVertex> vertices = new List<UIVertex>(){
    vertices0,vertices1,vertices2,vertices3};List<int> triangles = new List<int>(){
    0,1,2,0,2,3};vh.AddUIVertexStream(vertices, triangles);}

3.2.4 添加quad

通过AddUIVertexQuad方法添加四边形,我们只要定义四边形的四个顶点信息,不用定义三角形即可。如下

    void CreateMeshByQuad(VertexHelper vh){
    Rect size = GetPixelAdjustedRect();UIVertex[] vertices0= new UIVertex[4];vertices0[0].position = new Vector3(-0.5f * size.width, -0.5f * size.height);vertices0[0].color = Color.white;vertices0[0].uv0 = new Vector2(0, 0);vertices0[1].position = new Vector3(0.5f * size.width, -0.5f * size.height);vertices0[1].color = Color.red;vertices0[1].uv0 = new Vector2(1, 0);vertices0[2].position = new Vector3(0.5f * size.width, 0.5f * size.height);vertices0[2].color = Color.red;vertices0[2].uv0 = new Vector2(1, 1);vertices0[3].position = new Vector3(-0.5f * size.width, 0.5f * size.height);vertices0[3].color = Color.white;vertices0[3].uv0 = new Vector2(0, 1);UIVertex[] vertices1 = new UIVertex[4];vertices1[0].position = new Vector3(-0.5f * size.width, 0.5f * size.height);vertices1[0].color = Color.white;vertices1[0].uv0 = new Vector2(0, 0);vertices1[1].position = new Vector3(0.5f * size.width, 0.5f * size.height);vertices1[1].color = Color.red;vertices1[1].uv0 = new Vector2(1, 0);vertices1[2].position = new Vector3(0.5f * size.width, 1.5f * size.height);vertices1[2].color = Color.red;vertices1[2].uv0 = new Vector2(1, 1);vertices1[3].position = new Vector3(-0.5f * size.width, 1.5f * size.height);vertices1[3].color = Color.white;vertices1[3].uv0 = new Vector2(0, 1);vh.AddUIVertexQuad(vertices0);vh.AddUIVertexQuad(vertices1);}

3.2.5 添加三角形流

直接添加通过顶点list添加,此时会没三个顶点生成一个三角形,不用定义三角形数组,但是list要是三的倍数,否则后续顶点会省略掉。如下

    void CreateMeshByTriangleStream(VertexHelper vh){
    Rect size = GetPixelAdjustedRect();UIVertex vertices0 = new UIVertex();vertices0.position = new Vector3(-0.5f * size.width, -0.5f * size.height);vertices0.color = Color.blue;vertices0.uv0 = new Vector2(0, 0);UIVertex vertices1 = new UIVertex();vertices1.position = new Vector3(0.5f * size.width, -0.5f * size.height);vertices1.color = Color.red;vertices1.uv0 = new Vector2(1, 0);UIVertex vertices2 = new UIVertex();vertices2.position = new Vector3(0.5f * size.width, 0.5f * size.height);vertices2.color = Color.red;vertices2.uv0 = new Vector2(1, 1);UIVertex vertices3 = new UIVertex();vertices3.position = new Vector3(-0.5f * size.width, 0.5f * size.height);vertices3.color = Color.white;vertices3.uv0 = new Vector2(0, 1);UIVertex vertices4 = new UIVertex();vertices4.position = new Vector3(1.5f * size.width, -0.5f * size.height);vertices4.color = Color.blue;vertices4.uv0 = new Vector2(0, 0);List<UIVertex> vertexList = new List<UIVertex>(){
    vertices0,vertices1,vertices2,vertices1,vertices4,vertices2};vh.AddUIVertexTriangleStream(vertexList);}
  相关解决方案