A*寻路-2(忘了哪个是最终版的)
using UnityEngine;
using System.Collections.Generic;
public class TestAStar : MonoBehaviour
{
    //以点为方格
    //A点 [1,2]    B点[6,7]
    private List<float[,]> parentPosList = new List<float[,]>();
    List<Son> sonList = new List<Son>();
    List<Son> parentList = new List<Son>();
    List<Son> oldList = new List<Son>();
List<float[,]> barrierPosList = new List<float[,]>();
    //防止测试死机
    private int n = 0;
    private float[,] start = new float[1, 2] { { 1, 2 } };
    private float[,] end = new float[1, 2] { { 6, 7 } };
    void Start()
    {
        barrierPosList.Add(new float[,] { { 2, 4 } });
        barrierPosList.Add(new float[,] { { 3, 4 } });
        barrierPosList.Add(new float[,] { { 4, 4 } });
        XunLu(start, end);
    }
    public void XunLu(float[,] start, float[,] end)
    {
        //找到起始点A  周围8个点  F=G+H  G值由父点决定(决定周围8点)   H值由终点B点决定
        //需要一个存 父点 的list parent
        //首先可以知道start点 周围8点坐标  存到list son   
        //存父节点
        //List<Son> parent = new List<Son>();
        parentPosList.Add(start);
        //===
        sonList.Clear();
        //拿到周围8个点坐标  
        Son one = new Son(new float[1, 2] { { start[0, 0], start[0, 1] + 1 } });
        Son two = new Son(new float[1, 2] { { start[0, 0] + 1, start[0, 1] + 1 } });
        Son three = new Son(new float[1, 2] { { start[0, 0] + 1, start[0, 1] } });
        Son four = new Son(new float[1, 2] { { start[0, 0] + 1, start[0, 1] - 1 } });
        Son five = new Son(new float[1, 2] { { start[0, 0], start[0, 1] - 1 } });
        Son six = new Son(new float[1, 2] { { start[0, 0] - 1, start[0, 1] - 1 } });
        Son seven = new Son(new float[1, 2] { { start[0, 0] - 1, start[0, 1] } });
        Son eight = new Son(new float[1, 2] { { start[0, 0] - 1, start[0, 1] + 1 } });
        sonList.Add(one); sonList.Add(two); sonList.Add(three); sonList.Add(four); sonList.Add(five); sonList.Add(six); sonList.Add(seven); sonList.Add(eight);
        //sonDict.Add(0, one); sonDict.Add(1, two); sonDict.Add(2, three); sonDict.Add(3, four); sonDict.Add(4, five); sonDict.Add(5, six); sonDict.Add(6, seven); sonDict.Add(7, eight);
        //oldoldDict = sonDict;
        //遍历sondict 如果有终点坐标   return
        n++;
        for (int i = 0; i < sonList.Count; i++)
        {
            if (sonList[i].pos[0, 0] == end[0, 0] && sonList[i].pos[0, 1] == end[0, 1])
            {
                Debug.Log("路径已经找到!!");
                Debug.Log("输出路径:");
                for (int j = 0; j < parentPosList.Count; j++)
                {
                    Debug.Log("路径坐标:" + parentPosList[j][0, 0] + "  ,  " + parentPosList[j][0, 1]);
                }
                return;
            }
        }
        if (n > 100)
        {
            Debug.Log("n>100 return!!!");
            Debug.Log(parentPosList.Count);
            return;
        }
        //清除之前的   新加son
        //oldDict.Clear();
        //oldDict = oldoldDict;
        //oldoldDict.Clear();
        //周围8点的G H值  还需要存    //sonDict里面只剩下 需要求G H值的son点  知道son的pos和end点   求 G H值  父节点就是start
        //for (int i = 0; i < sonDict.Count - 1; i++)
        //{
        //    if (sonDict.ContainsKey(i))
        //    {
        //        sonDict[i].H = Mathf.Abs(end[0, 0] - sonDict[i].pos[0, 0]) + Mathf.Abs(end[0, 1] - sonDict[i].pos[0, 1]);//H
        //        if (sonDict[i].pos[0, 0] == start[0, 0] || sonDict[i].pos[0, 1] == start[0, 1])//G
        //        {
        //            sonDict[i].G = 10;
        //        }
        //        else
        //        {
        //            sonDict[i].G = 14;
        //        }
        //        sonDict[i].F = sonDict[i].G + sonDict[i].H;
        //    }
        //}
        for (int i = 0; i < sonList.Count; i++)
        {
            sonList[i].H = (Mathf.Abs(end[0, 0] - sonList[i].pos[0, 0]) + Mathf.Abs(end[0, 1] - sonList[i].pos[0, 1])) * 10;//H
            if (sonList[i].pos[0, 0] == start[0, 0] || sonList[i].pos[0, 1] == start[0, 1])
            {
                sonList[i].G = 10;
            }
            else
            {
                sonList[i].G = 14;
            }
            sonList[i].F = sonList[i].G + sonList[i].H;
        }
        for (int i = 0; i < sonList.Count; i++)
        {
            for (int j = 0; j < barrierPosList.Count; j++)
            {
                if (sonList[i].pos[0, 0] == barrierPosList[j][0, 0] && sonList[i].pos[0, 1] == barrierPosList[j][0, 1])
                {
                    sonList[i].F = 1000;
                }
            }
        }
        for (int i = 0; i < sonList.Count - 1; i++)
        {
            if (sonList[i].F < sonList[i + 1].F)
            {
                sonList[i + 1] = sonList[i];
            }
        }
        float[,] pos = sonList[7].pos;
        XunLu(pos, end);
        //判断son中  那个点F值最小
        //for (int i = 0; i < listI.Count - 1; i++)
        //{
        //    if (sonDict[listI[i]].F < sonDict[listI[i + 1]].F)
        //    {
        //        Debug.Log(sonDict[listI[i]].F); Debug.Log(sonDict[listI[i+1]].F);
        //        sonDict[listI[i]] = sonDict[listI[i + 1]];
        //        Debug.Log(sonDict[listI[i]].F); Debug.Log(sonDict[listI[i + 1]].F);
        //    }
        //}
        //List<Son> listSon = new List<Son>();
        //foreach (var item in sonDict.Values)
        //{
        //    listSon.Add(item);
        //    Debug.Log("item.add   = " + listSon.Count);
        //}
        //for (int i = 0; i < listSon.Count - 1; i++)
        //{
        //    if (listSon[i].F < listSon[i + 1].F)
        //    {
        //        listSon[i + 1] = listSon[i];
        //    }
        //}
        //最小的F sonDict[listI[listI.count-1]] 
        //Debug.Log(listSon.Count);
        //parentList.Add(listSon[listSon.Count - 1]);
        //dict第8个的F值最小  设置他为父节点
        //float[,] parent = sonList[index];
        //parentList.Add(parent);
        //清除sonlist  oldlist做下次判断
        //sonList.Clear();
        //sonDict.Clear();
        //
        //XunLu( sonDict[listI[listI.Count-1]].pos, end);]
        //int len = parentList.Count - 1;
        //XunLu(parentList[len].pos, end);
        //Dictionary<int, List<float>> dictSon = new Dictionary<int, List<float>>();
        //计算8点的的G  H值
        //8点的G值  存到dict
        //dictSon[0][0]= 10; dictSon[1][0] = 14; dictSon[2][0] = 10; dictSon[3][0] = 14;
        //dictSon[4][0] = 10; dictSon[5][0] = 14; dictSon[6][0] = 10; dictSon[7][0] = 14;
        //8点的H值   //应该是遍历sonlist里面有几个点,拿到这几个点的G H值 
        //float oneH = Mathf.Abs((end[0, 0] - one[0, 0]) + (end[0, 1] - one[0, 1])) * 10; //H值
        //float twoH = Mathf.Abs((end[0, 0] - two[0, 0]) + (end[0, 1] - two[0, 1])) * 10;
        //float threeH = Mathf.Abs((end[0, 0] - three[0, 0]) + (end[0, 1] - three[0, 1])) * 10;
        //float fourH = Mathf.Abs((end[0, 0] - four[0, 0]) + (end[0, 1] - four[0, 1])) * 10;
        //float fiveH = Mathf.Abs((end[0, 0] - five[0, 0]) + (end[0, 1] - five[0, 1])) * 10;
        //float sixH = Mathf.Abs((end[0, 0] - six[0, 0]) + (end[0, 1] - six[0, 1])) * 10;
        //float sevenH = Mathf.Abs((end[0, 0] - seven[0, 0]) + (end[0, 1] - seven[0, 1])) * 10;
        //float eightH = Mathf.Abs((end[0, 0] - eight[0, 0]) + (end[0, 1] - eight[0, 1])) * 10;
        //8点H值 存到dict
        //dictSon[0][1] = oneH; dictSon[1][1] = twoH; dictSon[2][1] = threeH; dictSon[3][1] = fourH;
        //dictSon[4][1] = fiveH; dictSon[5][1] = sixH; dictSon[6][1] = sevenH; dictSon[7][1] = eightH;
        //存
        //dictSon.Add(1, new List<float> { 10, oneH }); dictSon.Add(2, new List<float> { 14, twoH });
        //dictSon.Add(3, new List<float> { 10, threeH }); dictSon.Add(4, new List<float> { 14, fourH });
        //dictSon.Add(5, new List<float> { 10, fiveH }); dictSon.Add(6, new List<float> { 14, sixH });
        //dictSon.Add(7, new List<float> { 10, sevenH }); dictSon.Add(8, new List<float> { 14, eightH });
        //比较8点之中 F=G+H 的最小值 
        //int index = 0;
        //for (int i = 0; i < dictSon.Count - 1; i++)
        //{
        //    if ((dictSon[i][0] + dictSon[i][1]) - (dictSon[i + 1][0] + dictSon[i + 1][1]) < 0)
        //    {
        //        List<float> list = new List<float> { dictSon[i + 1][0], dictSon[i + 1][1] };
        //        dictSon.Remove(i + 1);
        //        dictSon.Add(i + 1, list);
        //        index = i;
        //    }
        //}
    }
    public class Son
    {
        public float F;
        public float G;
        public float H;
        public float[,] pos;
        public float[,] parentPos;
        public Son(float[,] pos)
        {
            this.pos = pos;
        }
}
}
 
                    
                     
                    
                 
                    
                 
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号