Version: 5.3 (switch to 5.4b)
ЯзыкEnglish
  • C#
  • JS

Язык программирования

Выберите подходящий для вас язык программирования. Все примеры кода будут представлены на выбранном языке.

GL.MultiTexCoord

Предложить изменения

Успех!

Благодарим вас за то, что вы помогаете нам улучшить качество документации по Unity. Однако, мы не можем принять любой перевод. Мы проверяем каждый предложенный вами вариант перевода и принимаем его только если он соответствует оригиналу.

Закрыть

Ошибка внесения изменений

По определённым причинам предложенный вами перевод не может быть принят. Пожалуйста <a>попробуйте снова</a> через пару минут. И выражаем вам свою благодарность за то, что вы уделяете время, чтобы улучшить документацию по Unity.

Закрыть

Отменить

Руководство
public static function MultiTexCoord(unit: int, v: Vector3): void;
public static void MultiTexCoord(int unit, Vector3 v);

Параметры

Описание

Устанавливает текстурные координаты (v.x,v.y,v.z) текстурному блоку unit.

В OpenGL это соответствует glMultiTexCoord для данного текстурного блока, если мультитекстурирование доступно. В других графических API эта функциональность эмулируется.

The Z component is used only when:
1. You access a cubemap (which you access with a vector coordinate, hence x,y & z).
2. Вы делаете "projective texturing", где координаты X и Y делятся на Z, чтобы получить финальные координаты. Чаще всего это используется для отражений на воде и подобных вещей.

Эта функция может вызываться только между функциями GL.Begin и GL.End.

	// 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(); } }