Version: 5.3 (switch to 5.4b)
IdiomaEnglish
  • C#
  • JS

Idioma de script

Selecciona tu lenguaje de programación favorito. Todos los fragmentos de código serán mostrados en este lenguaje.

GL.MultiTexCoord

Sugiere un cambio

¡Éxito!

Gracias por ayudarnos a mejorar la calidad de la documentación de Unity. A pesar de que no podemos aceptar todas las sugerencias, leemos cada cambio propuesto por nuestros usuarios y actualizaremos los que sean aplicables.

Cerrar

No se puedo enviar

Por alguna razón su cambio sugerido no pudo ser enviado. Por favor <a>intente nuevamente</a> en unos minutos. Gracias por tomarse un tiempo para ayudarnos a mejorar la calidad de la documentación de Unity.

Cerrar

Cancelar

Cambiar al Manual
public static function MultiTexCoord(unit: int, v: Vector3): void;
public static void MultiTexCoord(int unit, Vector3 v);

Parámetros

Descripción

Sets current texture coordinate (v.x,v.y,v.z) to the actual texture unit.

In OpenGL this matches glMultiTexCoord for the given texture unit if multi-texturing is available. On other graphics APIs the same functionality is emulated.

The Z component is used only when:
1. You access a cubemap (which you access with a vector coordinate, hence x,y & z).
2. You do "projective texturing", where the X & Y coordinates are divided by Z to get the final coordinate. This would be mostly useful for water reflections and similar things.

This function can only be called between GL.Begin and GL.End functions.

	// Changes between two textures assigned to a material
	// When pressed space
	var mat : Material;
	private var flagTex : boolean = true;
	function Update() {
		if (Input.GetKeyDown(KeyCode.Space)) {
			if(flagTex) {
				flagTex = false;
			} else {
				flagTex = true;
			}
		}
	}

function OnPostRender() { if (!mat) { Debug.LogError("Please Assign a material on the inspector"); return; } GL.PushMatrix(); mat.SetPass(1); GL.LoadOrtho(); GL.Begin(GL.QUADS); if (flagTex) { GL.MultiTexCoord(0,Vector3(0,0,0)); // main texture } else { GL.MultiTexCoord(1,Vector3(0,0,0)); // second texture } GL.Vertex3(0.25,0.25,0); if (flagTex) { GL.MultiTexCoord(0,Vector3(0,1,0)); } else { GL.MultiTexCoord(1,Vector3(0,1,0)); } GL.Vertex3(0.25,0.75,0); if (flagTex) { GL.MultiTexCoord(0,Vector3(1,1,0)); } else { GL.MultiTexCoord(1,Vector3(1,1,0)); } GL.Vertex3(0.75,0.75,0); if (flagTex) { GL.MultiTexCoord(0,Vector3(1,0,0)); } else { GL.MultiTexCoord(1,Vector3(1,0,0)); } GL.Vertex3(0.75,0.25,0); GL.End(); GL.PopMatrix(); }
using UnityEngine;
using System.Collections;

public class ExampleClass : MonoBehaviour { public Material mat; private bool flagTex = true; void Update() { if (Input.GetKeyDown(KeyCode.Space)) if (flagTex) flagTex = false; else flagTex = true; } void OnPostRender() { if (!mat) { Debug.LogError("Please Assign a material on the inspector"); return; } GL.PushMatrix(); mat.SetPass(1); GL.LoadOrtho(); GL.Begin(GL.QUADS); if (flagTex) GL.MultiTexCoord(0, new Vector3(0, 0, 0)); else GL.MultiTexCoord(1, new Vector3(0, 0, 0)); GL.Vertex3(0.25F, 0.25F, 0); if (flagTex) GL.MultiTexCoord(0, new Vector3(0, 1, 0)); else GL.MultiTexCoord(1, new Vector3(0, 1, 0)); GL.Vertex3(0.25F, 0.75F, 0); if (flagTex) GL.MultiTexCoord(0, new Vector3(1, 1, 0)); else GL.MultiTexCoord(1, new Vector3(1, 1, 0)); GL.Vertex3(0.75F, 0.75F, 0); if (flagTex) GL.MultiTexCoord(0, new Vector3(1, 0, 0)); else GL.MultiTexCoord(1, new Vector3(1, 0, 0)); GL.Vertex3(0.75F, 0.25F, 0); GL.End(); GL.PopMatrix(); } }