【自走棋】地图格子高亮效果
<1>效果:








<2>思路:
需求把地图划分成均匀网格,放置玩家到任意一个网格,显示玩家可攻击范围所有网格高亮(放置)
1.如何划分网格?
定义行和列最大数量(自走棋row=8 col=8)
定义起始位置Vector3 startPos 从起始点 向X轴正方向延伸列 向Z轴正方向延伸行
为什么单独实例化每个格子?方便做高亮效果,开销也不大,替换材质球,dc不高
//行
private int row = 8;
//列
private int col = 8;
//缓存obj
private List<GameObject> cells = new List<GameObject>();
//起始位置
private Vector3 startPos = Vector3.zero;
//初始化地图格子 从起始点 向X轴正方向延伸列 向Z轴正方向延伸行
void InitCells()
{
int num = row * col;
for (int i = 0; i < num; i++)
{
GameObject go = GameObject.Instantiate(tempCell) as GameObject;
cells.Add(go);
int index = i + 1;
go.name = index.ToString();
int grow = getRow(index);
int gcol = getCol(index);
go.transform.position = new Vector3(gcol, 0, grow);
Color color = (index + grow) % 2 == 0 ? Color.blue : Color.green;
int state = (index + grow) % 2 == 0 ? 1 : 2;
setMaterial(go, color, state);
}
}
2.如何确定攻击范围?
这个问题需要与策划商量,一种方式是给每个棋子攻击范围公式,二是策划配置攻击范围格子(因为有些攻击范围很奇葩)
如果使用第二种方式,配置一张表,最大和最小攻击格子都在其中,15*15=225
策划需要配置什么形状的攻击范围,都由策划配置在每个棋子的攻击范围列表中
例如3种攻击范围:索引到下面的map
private List<int> atkLst1 = new List<int>() { 0, 2, 3, 4, 5, 6, 7, 8, 9 };//上缺1
private List<int> atkLst2 = new List<int>() { 0, 1, 2, 3, 4, 5, 6, 7, 8 };//九宫格
private List<int> atkLst3 = new List<int>() { 0, 1, 2, 3, 4 };//十字形
private Dictionary<int, int[]> map = new Dictionary<int, int[]>();
//攻击范围格子索引 配置一张表 225个元素 15*15
void init()
{
map.Add(0, new int[2] { 0, 0 });
map.Add(1, new int[2] { 1, 0 });
map.Add(2, new int[2] { -1, 0 });
map.Add(3, new int[2] { 0, 1 });
map.Add(4, new int[2] { 0, -1 });
map.Add(5, new int[2] { -1, 1 });
map.Add(6, new int[2] { -1, -1 });
map.Add(7, new int[2] { 1, 1 });
map.Add(8, new int[2] { 1, -1 });
map.Add(9, new int[2] { 2, 0 });
}
<3>怎么显示攻击范围高亮?
1.需要取到攻击范围格子
取到放置格子的row,col,遍历攻击范围格子索引,求出每个攻击格子的相对放置格子索引,验证求得的格子是否合法
回退之前的高亮格子,高亮当前攻击范围格子
2.高亮替换格子材质(dc并不高,3中材质互换)
//index = 棋子放置所在格子 attackLst = 玩家攻击范围格子索引列表
//Ray ray = Camera.main.ScreenPointToRay(Input.mousePosition);测试鼠标选中格子高亮范围
private void showVaildCells(int index, List<int> attackLst) { int srow = getRow(index); int scol = getCol(index); List<int> list = new List<int>(); int[] delta = new int[2]; for (int i = 0; i < attackLst.Count; i++) { int[] xy = map[attackLst[i]]; delta[0] = xy[0] + srow - 1; delta[1] = xy[1] + scol; if (isVaildIndex(delta)) { list.Add(delta[0] * row + delta[1]); } } showLst(list); } private bool isVaildIndex(int[] xy) { return xy[0] >= 0 && xy[0] < row && xy[1] > 0 && xy[1] <= col; }
浙公网安备 33010602011771号