Version: 2022.3
public static byte[] EncodeToEXR (Texture2D tex, Texture2D.EXRFlags flags);

参数

tex 要转换的纹理。
flags Flags used to control compression and the output format. The default is Texture2D.EXRFlags.None

描述

将该纹理编码为 EXR 格式。

This function returns a byte array which is the EXR file data. You can store the encoded data as a file or send it over the network without further processing.

This function does not work on any compressed format. Although it is best to use this function for HDR texture formats (either 16-bit or 32-bit floats), it can be used with other formats (and the data is converted on the fly). The default output format is uncompressed 16-bit float EXR and can be controlled using the passed in flags. For the texture pass in, Texture.isReadable must be true. The encoded EXR data will only contain an alpha channel when the passed-in format has one. For single-channel red textures ( R8, R16, RFloat and RHalf ), the encoded data will be in grayscale mode.

See Also: EXRFlags, EncodeToJPG, EncodeToPNG.

// Saves HDR RenderTexture as an EXR file.
using UnityEngine;
using System.Collections;
using System.IO;

public class SaveRenderTextureToEXR : MonoBehaviour { RenderTexture m_InputTexture;

void SaveRenderTexture() { if (m_InputTexture != null) { int width = m_InputTexture.width; int height = m_InputTexture.height;

Texture2D tex = new Texture2D(width, height, TextureFormat.RGBAFloat, false);

// Read screen contents into the texture Graphics.SetRenderTarget(m_InputTexture); tex.ReadPixels(new Rect(0, 0, width, height), 0, 0); tex.Apply();

// Encode texture into the EXR byte[] bytes = ImageConversion.EncodeToEXR(tex, Texture2D.EXRFlags.CompressZIP); File.WriteAllBytes(Application.dataPath + "/../SavedRenderTexture.exr", bytes);

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