其他分享
首页 > 其他分享> > 【自走棋】地图格子高亮效果

【自走棋】地图格子高亮效果

作者:互联网

<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; }

  

 

标签:map,高亮,格子,int,List,Add,new,走棋
来源: https://www.cnblogs.com/cocotang/p/10825340.html