data:image/s3,"s3://crabby-images/56a7f/56a7f9cb05702129044a60fe63e5868d2383cc1f" alt=""
利申:自學Unity,非專業教學,如果有錯誤歡迎補充指正
data:image/s3,"s3://crabby-images/fc32f/fc32f380e9a1d46e1a951076864e287a8405d062" alt=""
開始前俾大家睇下啲例子先:
Mindusty
data:image/s3,"s3://crabby-images/673cb/673cb1ad8b5a692fe95dc7972777b0c2398e3e32" alt=""
Core Keeper
data:image/s3,"s3://crabby-images/c98f4/c98f419ab036fb3cb34e3f4e8e3e0b3a0b1f234e" alt=""
-----------------------------------------------------
首先開個新2D Project,我用嘅Unity版本係2022.2.7f1
data:image/s3,"s3://crabby-images/31832/318325799c3254a4cfc168b480c800999840e789" alt=""
首先我哋要用Grid將地圖割開一格格先(Grid Cell),加個Empty GameObject再撳Add Component加Grid (2D同3D都可以用Grid)
data:image/s3,"s3://crabby-images/fe5b5/fe5b5edc38011b8a825bc1e57e11e8067ad77804" alt=""
Grid有4個Properties可以set
1) Cell Size: 每一格嘅大小
2) Cell Gap: 每一格嘅間隔
3) Cell Layout: 每一格嘅形狀,有4款可以揀:
Rectangle
data:image/s3,"s3://crabby-images/3111b/3111b249c8448cc8aeb0a33eb3663977adc9bcf5" alt=""
Hexagon
data:image/s3,"s3://crabby-images/18e82/18e82ab04b74d7a5956afd4fc6f711a0d3ec0366" alt=""
Isometric 同埋 Isometric Z as Y
data:image/s3,"s3://crabby-images/04717/047170d2ce26b757ef789bc636f4b2c85924e62e" alt=""
4) Cell Swizzle: 將XYZ重新排序做其中一個選項
-----------------------------------------------------
之後要將mouse postion反映返落去grid cell到,create一個新script:
using UnityEngine;
public class InputManager : MonoBehaviour
{
//攞Grid Component
[SerializeField]private Grid grid;
//顯示Mouse目前所在位置
[SerializeField]private GameObject mouseIndicator;
//攞Main Camera
private Camera mainCamera;
//Save低Mouse位置
private Vector2 mousePosition;
private void Start()
{
//Camera.main會係套用MainCamera Tag嘅Camera
mainCamera = Camera.main;
}
private void Update()
{
UpdateMouseIndicator();
}
private void UpdateMouseIndicator(){
//攞Mouse目前所在位置
mousePosition = mainCamera.ScreenToWorldPoint(Input.mousePosition);
//更新mouseIndicator位置
mouseIndicator.transform.position = grid.WorldToCell(mousePosition);
}
}
[SerializeField]: 正常private field唔會喺Inspector顯示,加呢句就可以強制serialize個private field
mouseIndicator: 一個要嚟顯示目前所在位置嘅GameObject
data:image/s3,"s3://crabby-images/f6d0c/f6d0c6f22b633e430fb4620cc1aa754bd97ce495" alt=""
data:image/s3,"s3://crabby-images/8116f/8116fc6842ec053b9ea9728ba305645486962897" alt=""
Camera.main: 用緊MainCamera Tag嘅Camera
data:image/s3,"s3://crabby-images/b94d6/b94d6a82fc15865fe40ad2ee0d08587443a9bee3" alt=""
ScreenToWorldPoint: 將座標從Screen Position轉換為World Position
WorldToCell: 將座標從World Position轉換為Cell Position,咁就可以將GameObject正確放喺Cell上面
-----------------------------------------------------
Hierarchy嘅樣
data:image/s3,"s3://crabby-images/a91a8/a91a8d46c9f0e6e61f32ebe4243342c63dea991e" alt=""
Input Manager
data:image/s3,"s3://crabby-images/027fe/027feda1e2995f1368aec9aff0705801eb652668" alt=""
Grid System
data:image/s3,"s3://crabby-images/fe5b5/fe5b5edc38011b8a825bc1e57e11e8067ad77804" alt=""
-----------------------------------------------------
完成效果
data:image/s3,"s3://crabby-images/f59e6/f59e63902f35cc281fd3eea5c958c54486461e96" alt=""
之後會整埋鏡頭移動先可加建築系統
data:image/s3,"s3://crabby-images/2da46/2da467a7a7295f1c67e6749f8e647c0288bfe46e" alt=""
-----------------------------------------------------
詳細嘅document:
Grid
https://docs.unity3d.com/2022.2/Documentation/ScriptReference/Grid.html
SerializeField
https://docs.unity3d.com/2022.2/Documentation/ScriptReference/SerializeField.html
Camera.main
https://docs.unity3d.com/2022.2/Documentation/ScriptReference/Camera-main.html
ScreenToWorldPoint
https://docs.unity3d.com/2022.2/Documentation/ScriptReference/Camera.ScreenToWorldPoint.html
WorldToCell
https://docs.unity3d.com/2022.2/Documentation/ScriptReference/GridLayout.WorldToCell.html