Version: 2022.1
언어: 한국어

GL.MultiTexCoord2

매뉴얼로 전환
public static void MultiTexCoord2 (int unit, float x, float y);

설명

Sets current texture coordinate (x,y) for 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.

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

using UnityEngine;

public class Example : MonoBehaviour { // Changes between two textures assigned to a material // When pressed space Material mat; 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.MultiTexCoord2(0, 0, 0); // main texture } else { GL.MultiTexCoord2(1, 0, 0); // second texture } GL.Vertex3(0.25f, 0.25f, 0); if (flagTex) { GL.MultiTexCoord2(0, 0, 1); } else { GL.MultiTexCoord2(1, 0, 1); } GL.Vertex3(0.25f, 0.75f, 0); if (flagTex) { GL.MultiTexCoord2(0, 1, 1); } else { GL.MultiTexCoord2(1, 1, 1); } GL.Vertex3(0.75f, 0.75f, 0); if (flagTex) { GL.MultiTexCoord2(0, 1, 0); } else { GL.MultiTexCoord2(1, 1, 0); } GL.Vertex3(0.75f, 0.25f, 0); GL.End(); GL.PopMatrix(); } }
Copyright © 2023 Unity Technologies
优美缔软件(上海)有限公司 版权所有
"Unity"、Unity 徽标及其他 Unity 商标是 Unity Technologies 或其附属机构在美国及其他地区的商标或注册商标。其他名称或品牌是其各自所有者的商标。
公安部备案号:
31010902002961