Version: 2019.3
public Color[] colors ;

説明

メッシュの頂点の色配列

頂点カラーが使用できない場合、空の配列が返されます。

// Sets the vertex color to be red at the y=0 and green at y=1.
// (Note that most built-in Shaders don't display vertex colors. Use one that does, such as a Particle Shader, to see vertex colors)

using UnityEngine;

public class ExampleClass : MonoBehaviour { void Start() { Mesh mesh = GetComponent<MeshFilter>().mesh; Vector3[] vertices = mesh.vertices;

// create new colors array where the colors will be created. Color[] colors = new Color[vertices.Length];

for (int i = 0; i < vertices.Length; i++) colors[i] = Color.Lerp(Color.red, Color.green, vertices[i].y);

// assign the array of colors to the Mesh. mesh.colors = colors; } }

パフォーマンス上の理由から、代わりに colors32 を使うことを検討してください。 これにより Colors における byte から float への変換を避け、一時メモリの使用を少なくします。

Copyright © 2023 Unity Technologies
优美缔软件(上海)有限公司 版权所有
"Unity"、Unity 徽标及其他 Unity 商标是 Unity Technologies 或其附属机构在美国及其他地区的商标或注册商标。其他名称或品牌是其各自所有者的商标。
公安部备案号:
31010902002961