data:image/s3,"s3://crabby-images/f21b3/f21b32c43dc11c1be82384c8d2981fe96a101c21" alt=""
- Thay đổi vật liệu cho vật thể bằng GUI - |
Tùy biến ảnh giao đại diện thường dùng một hoặc nhiều ảnh/vật liệu mẫu đã có và gắn nó vào ảnh đại diện. Bài viết này, sẽ sử dụng GUI để kết hợp 2 vật liệu (texture) để tạo nên ảnh đại diện do người dùng lựa chọn.
Chuẩn bị
SelectTexture.unitypackage
Cách để làm
B1. Nhấp phải vào thẻ Project và chọn Import Package | Custom Package và mở file SelectTexture vừa tải ở trên.
data:image/s3,"s3://crabby-images/3752e/3752ec9b3b4e1b41afc2d921b583b576a9b4ecdf" alt=""
B2. Tại thẻ Project, double click vào selTexScene.
data:image/s3,"s3://crabby-images/faa1a/faa1afbfe0e2423ea4f00ef97647b77c2dfe4bb7" alt=""
B3. Vẫn tại thẻ Project, nhấp nút Create | Material và đặt tên là selectableMaterial. Ở thẻ Inspector, đổi Shader thành Decal.
data:image/s3,"s3://crabby-images/99653/99653c5b557f87168cb6e42295c76fa2fb510fd4" alt=""
B4. Kéo thả material vừa tạo ở thẻ Project vào Avatar ở thẻ Hierarchy.
data:image/s3,"s3://crabby-images/deece/deece3e7febbaa0a80d3f90dbd43b8687d873f6b" alt=""
B5. Tại thẻ Project, nhấp chọn nút Create | C# Script và đặt tên là SelectTexture. Chèn đoạn code sau vào:
using UnityEngine;
using System.Collections;
public class SelectTexture : MonoBehaviour
{
public Texture2D[] faces;
public Texture2D[] props;
void OnGUI() {
for (int i = 0; i < faces.Length; i++)
if (GUI.Button(new Rect(0, i * 64, 128, 64), faces[i])) ChangeMaterial("faces", i);
for (int j = 0; j < props.Length; j++)
if (GUI.Button(new Rect(128, j * 64, 128, 64), props[j])) ChangeMaterial("props", j);
}
void ChangeMaterial(string category, int index)
{
if (category == "faces")
renderer.material.mainTexture = faces[index];
if (category == "props")
renderer.material.SetTexture("_DecalTex", props[index]);
}
}
B6. Lưu đoạn code lại và kéo thả vào Avatar ở thẻ Hierarchy.
data:image/s3,"s3://crabby-images/f40a8/f40a8034e43b2ce2c574129de0798385d43dcfd1" alt=""
B7. Nhấp chọn Avatar, qua thẻ Inspector, đổi giá trị Size của Faces và Props thành 2 và kéo thả các file ảnh face1, face2, prop1, prop2 ở thẻ Project vào thẻ Inspetor ở các vị trí như sau:
data:image/s3,"s3://crabby-images/cb0ac/cb0ac35b0e42e1f42b45e2201e0372372c490c28" alt=""
B8. Ấn nút Play để kiểm tra thành quả.
No comments:
Post a Comment