Version: 2020.3
public void SetPixelData (T[] data, int mipLevel, int element, int sourceDataStartIndex);
public void SetPixelData (NativeArray<T> data, int mipLevel, int element, int sourceDataStartIndex);

参数

data 用于初始化纹理像素的数据数组。
mipLevel 要填充的 Mip 级别。
element 要向其中复制像素的数组切片。
sourceDataStartIndex 要从其开始复制的源数组索引(默认值为 0)。

描述

用原始预格式化数据设置像素值。

此函数使用原始数据填充一个 Mip 级别和一个数组元素的纹理像素内存。如果要将压缩或其他非颜色纹理格式数据加载到纹理中,此函数很有用。

传递的数据应具有所需的大小,以便根据其宽度、高度和数据格式填充整个纹理 Mip 级别。否则,Unity 将抛出异常。

设置图像数据后,调用 Apply 会将其实际上传到 GPU。

See Also: SetPixels, GetPixelData, ::Apply.

using UnityEngine;

public class ExampleScript : MonoBehaviour { public Texture2DArray texture; public void Start() { texture = new Texture2DArray(2, 2, 3, TextureFormat.RGB24, true); var data = new byte[] { // mip 0: 2x2 size 255, 0, 0, // red 0, 255, 0, // green 0, 0, 255, // blue 255, 235, 4, // yellow // mip 1: 1x1 size 0, 255, 255 // cyan }; texture.SetPixelData(data, 0, 0, 0); // mip 0 texture.SetPixelData(data, 1, 0, 12); // mip 1 texture.filterMode = FilterMode.Point; texture.Apply(updateMipmaps: false); } }
Copyright © 2023 Unity Technologies
优美缔软件(上海)有限公司 版权所有
"Unity"、Unity 徽标及其他 Unity 商标是 Unity Technologies 或其附属机构在美国及其他地区的商标或注册商标。其他名称或品牌是其各自所有者的商标。
公安部备案号:
31010902002961