Объявление
public NativeArrayПараметры
mipLevel | MIP-уровень для ссылки. |
face | Лицо кубической карты для ссылки. |
Возвращает
NativeArray
Описание
Получает необработанные данные из текстуры для чтения или записи.
Эта функция возвращает прямое «представление» данных пикселей текстуры в виде массива Unity.Collections.NativeArray.
Срез данных будет возвращен в соответствии с запрошенным уровнем MIP и лицом Cubemap. Например, для текстуры размером 16x16 в формате RGBA32 получение уровня mip=1 (размер 8x8) приведет к массиву размером 256 байт или массиву из 64 элементов, если Color32 используется как тип.
Вы можете читать и записывать в возвращаемый массив. Если вы записываете в него, вы должны вызвать метод Apply, чтобы загрузить текстуру в GPU. Если массив, возвращенный GetPixelData, использовался для заполнения мип-карты уровня, отличного от 0, то перед вызовом метода Apply для updateMipmaps необходимо установить значение false.
GetPixelData не выделяет память; возвращенный NativeArray напрямую указывает на буфер данных системной памяти текстур.
Рекомендуется немедленно использовать или изменить данные, полученные этим методом, и не сохранять возвращенный массив для последующего использования, так как возвращенный массив может стать недействительным (т. е. он больше не указывает на допустимую память), если Текстура изменена или обновлено после того, как вы вызвали этот метод.
GetPixelData
выдает исключение в случае сбоя.
Смотрите так же: Apply, SetPixels, GetPixelData.
using UnityEngine;
public class ExampleScript : MonoBehaviour
{
public void Start()
{
var m_Cubemap = new Cubemap(16, TextureFormat.RGBA32, true);
var mip0Face4 = m_Cubemap.GetPixelData<Color32>(1, CubemapFace.PositiveZ);
// pixels in mip = 1, CubemapFace.PositiveZ are filled with white color
for (int i = 0; i < mip0Face4.Length; i++)
{
mip0Face4[i] = new Color32(255, 255, 255, 255);
}
m_Cubemap.Apply(false);
}
}