public void SetTexture (string name, Texture value);
public void SetTexture (int nameID, Texture value);
public void SetTexture (string name, RenderTexture value, Rendering.RenderTextureSubElement element);
public void SetTexture (int nameID, RenderTexture value, Rendering.RenderTextureSubElement element);

Parámetros

nameIDNombre del ID de la propiedad, utilice Shader.PropertyToID para obtenerla.
nameNombre de propiedad e.g. "_MainTex".
valueTexture to set.
elementOptional parameter that specifies the type of data from the render texture to set.

Descripción

Sets a named texture.

Muchos shaders utilizan más de una textura. Utilice SetTexture para cambiar la textura (identificada por la propiedad shader name, o propiedad única name ID).

Al configurar texturas en materiales utilizando el Shader estándar, debe tener en cuenta que puede ser necesario utilizar EnableKeyword para habilitar las características del shader que no estaban en uso anteriormente. Para más detalles, lea Accessing Materials via Script.

Common texture names used by Unity's builtin shaders:
"_MainTex" is the main diffuse texture. This can also be accessed via mainTexture property.
"_BumpMap" is the normal map.

The shader properties also show some of the keywords needed to set the Texture of a Material. To see this, go to your Material and right click on the Shader dropdown at the top. Next, pick Select Shader.

By specifying a RenderTextureSubElement, you can indicate which type of data from the render texture to set. The possible options are: RenderTextureSubElement.Color, RenderTextureSubElement.Depth, RenderTextureSubElement.Stencil.

See Also: mainTexture property, GetTexture, Shader.PropertyToID, Properties in Shader Programs, RenderTextureSubElement.

//Attach this script to your GameObject (make sure it has a Renderer component)
//Click on the GameObject. Attach your own Textures in the GameObject’s Inspector.

//This script takes your GameObject’s material and changes its Normal Map, Albedo, and Metallic properties to the Textures you attach in the GameObject’s Inspector. This happens when you enter Play Mode

using UnityEngine;

public class Example : MonoBehaviour {

//Set these Textures in the Inspector public Texture m_MainTexture, m_Normal, m_Metal; Renderer m_Renderer;

// Use this for initialization void Start () { //Fetch the Renderer from the GameObject m_Renderer = GetComponent<Renderer> ();

//Make sure to enable the Keywords m_Renderer.material.EnableKeyword ("_NORMALMAP"); m_Renderer.material.EnableKeyword ("_METALLICGLOSSMAP");

//Set the Texture you assign in the Inspector as the main texture (Or Albedo) m_Renderer.material.SetTexture("_MainTex", m_MainTexture); //Set the Normal map using the Texture you assign in the Inspector m_Renderer.material.SetTexture("_BumpMap", m_Normal); //Set the Metallic Texture as a Texture you assign in the Inspector m_Renderer.material.SetTexture ("_MetallicGlossMap", m_Metal); } }
Copyright © 2023 Unity Technologies
优美缔软件(上海)有限公司 版权所有
"Unity"、Unity 徽标及其他 Unity 商标是 Unity Technologies 或其附属机构在美国及其他地区的商标或注册商标。其他名称或品牌是其各自所有者的商标。
公安部备案号:
31010902002961