青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

   C++ 技術中心

   :: 首頁 :: 聯系 ::  :: 管理
  160 Posts :: 0 Stories :: 87 Comments :: 0 Trackbacks

公告

鄭重聲明:本BLOG所發表的原創文章,作者保留一切權利。必須經過作者本人同意后方可轉載,并注名作者(天空)和出處(CppBlog.com)。作者Email:coder@luckcoder.com

留言簿(27)

搜索

  •  

最新隨筆

最新評論

評論排行榜

#ifndef _ASTAR_FLY_H__
#define _ASTAR_FLY_H__
#include "Coordinate.h"
#include <map>
#include <set>

using namespace std;



typedef struct 
{
    int x;
    int y;
    int f; // f = g + h
    int g;
    int h;

    void Init(int _x,int _y)
    {
        f = 0;
        g = 0;
        h = 0;
        x = _x;
        y = _y;
    }
} APoint, *PAPoint;



class CAStarFly
{
public:
    typedef std::list<CIntPoint> PosList;


    CAStarFly();
    ~CAStarFly();

    bool CalcPath(PosList& pathList, const CIntPoint& from, const CIntPoint& to);
protected:
    virtual int GetMapWidth();
    virtual int GetMapHeight();
    virtual CIntSize GetRoleSize();
    virtual bool GetNearPos(int curX,int curY,PosList &nearPos);
    virtual bool IsCanFly(int x,int y);
    virtual void OnAddBestPoint(int x, int y);
    virtual void OnUnAddBestPoint(int x, int y);
private:
    PAPoint CalcNextPoint(PosList& pathList, PAPoint ptCalc); // 應用遞歸的辦法進行查詢

    void SetStartPoint(int x, int y);
    void SetEndPoint(int x, int y);
    void SetOpened(int x, int y);
    void SetClosed(int x, int y);
    void SetCurrent(int x, int y);

    int32 GetPosIndex(int x, int y);
    int32 GetFValue(const CIntPoint &pos);
    bool IsNotClosePos(int x, int y);
private:
    APoint m_startPoint; //起始點
    APoint m_endPoint;   //結束點
    APoint m_curPoint;   //當前移到點
    set<int32> m_setClosePos;
    int m_curGValue;     //當前G值
};

#endif/*_ASTAR_FLY_H__*/



#include "stdafx.h"
#include "AStarFly.h"


CAStarFly::CAStarFly()
{
}

CAStarFly::~CAStarFly()
{
}

bool CAStarFly::CalcPath(PosList& pathList, const CIntPoint& from, const CIntPoint& to)
{
    //1.先設置開始與目標
    SetStartPoint(from.x, from.y);
    SetEndPoint(to.x, to.y);
    m_curPoint = m_startPoint;
    SetClosed(m_startPoint.x, m_startPoint.y); //路徑搜索不再經過
    m_curGValue = 0;

    //從起點開始計算路徑點
    return CalcNextPoint(pathList, nullptr)!=nullptr;
}

PAPoint CAStarFly::CalcNextPoint(PosList& pathList, PAPoint ptCalc)
{
    if (nullptr == ptCalc)
    {
        ptCalc = &m_startPoint;
    }
    int curX = ptCalc->x;
    int curY = ptCalc->y;
    int destX = m_endPoint.x;
    int destY = m_endPoint.y;

    //判斷是否已經到了最終位置
    if ((curX == destX && abs(curY - destY) == 1) || (curY == destY && abs(curX - destX) == 1))
    {
        pathList.push_back(CIntPoint(m_endPoint.x, m_endPoint.y));
        OnAddBestPoint(m_endPoint.x, m_endPoint.y);
        return &m_endPoint;
    }

    // 最優步驟的坐標和值
    int xmin = curX;
    int ymin = curY;
    int fmin = 0;

    //獲得當前周邊點的的坐標
    PosList nearPos;
    if (GetNearPos(curX,curY,nearPos) == false)
    {
        return nullptr;
    }

    //刪除不能飛的區塊
    
//找出最優f值
    for (auto itPos : nearPos)
    {
        int fValue = GetFValue(itPos);
        if (fmin == 0 || fValue<fmin)
        {
            fmin = fValue;
            xmin = itPos.x;
            ymin = itPos.y;
        }
    }

    if (fmin > 0)
    {
        SetCurrent(xmin, ymin);
        SetClosed(xmin, ymin); //路徑搜索不再經過
        pathList.push_back(CIntPoint(xmin,ymin));
        OnAddBestPoint(xmin, ymin);
        PAPoint pAPoint= CalcNextPoint(pathList,&m_curPoint);
        if (nullptr == pAPoint)
        {
            SetCurrent(curX, curY);
            SetClosed(xmin, ymin); //路徑搜索不再經過

            
//將最后一次入的隊刪除
            pathList.pop_back();
            OnUnAddBestPoint(xmin, ymin);
            return CalcNextPoint(pathList, &m_curPoint);
        }

        return pAPoint;
    }
    

    return nullptr;
}

CIntSize CAStarFly::GetRoleSize()
{
    return CIntSize(1,1);
}

int CAStarFly::GetMapWidth()
{
    return -1;
}

int CAStarFly::GetMapHeight()
{
    return -1;
}

void CAStarFly::SetStartPoint(int x, int y)
{
    m_startPoint.Init( x,y);
}

void CAStarFly::SetEndPoint(int x, int y)
{
    m_endPoint.Init(x,y);
}


void CAStarFly::SetClosed(int x, int y)
{
    m_setClosePos.insert(GetPosIndex(x,y));
}

void CAStarFly::SetCurrent(int x, int y)
{
    m_curPoint.Init( x, y);
}

int32 CAStarFly::GetPosIndex(int x,int y)
{
    return  y * GetMapWidth() + x;
}


bool CAStarFly::GetNearPos(int curX, int curY, PosList &nearPos)
{
    int newX;
    int newY;
    //1.上
    if (curY > 0)
    {
        newX = curX;
        newY = curY - 1;

        if (IsNotClosePos(newX, newY) && IsCanFly(newX, newY))
        {
            nearPos.push_back(CIntPoint(newX, newY));
        }
    }
    
     
    


    //3.左
    if (curX > 0)
    {
        newX = curX - 1;
        newY = curY;

        if (IsNotClosePos(newX, newY) && IsCanFly(newX, newY))
        {
            nearPos.push_back(CIntPoint(newX, newY));
        }
    }
    

    //4.右
    if (curX < GetMapWidth())
    {
        newX = curX + 1;
        newY = curY;

        if (IsNotClosePos(newX, newY) && IsCanFly(newX, newY))
        {
            nearPos.push_back(CIntPoint(newX, newY));
        }
    }
    
    //2.下
    if (curY < GetMapHeight())
    {
        newX = curX;
        newY = curY + 1;

        if (IsNotClosePos(newX, newY) && IsCanFly(newX, newY))
        {
            nearPos.push_back(CIntPoint(newX, newY));
        }
    }
    return nearPos.size()>0;
}

bool CAStarFly::IsCanFly(int x, int y)
{
    return true;
}

int32 CAStarFly::GetFValue(const CIntPoint &pos)
{
    int xDis = abs(pos.x - m_endPoint.x)*100;
    int yDis = abs(pos.y - m_endPoint.y)*100;
    return m_curGValue +  (int32)sqrt(xDis*xDis + yDis*yDis);
}



bool CAStarFly::IsNotClosePos(int x, int y)
{
    return m_setClosePos.find(GetPosIndex(x, y)) == m_setClosePos.end();
}

void CAStarFly::OnAddBestPoint(int x, int y)
{
    m_curGValue += 100;
}

void CAStarFly::OnUnAddBestPoint(int x, int y)
{
    m_curGValue -= 100;
}


#include "AStarFly.h"
#include <memory>

class CNewMap;

class CMobAStarFly : public CAStarFly
{
public:
    static CMobAStarFly& GetInstance();
    bool FindPath(const std::shared_ptr<CNewMap>& pMap, const CIntPoint& from, const CIntPoint& to, CAStarFly::PosList& pathList, const CIntSize& roleSize = CIntSize(1, 1));
    void setpath(int x, int y);
    void show();

    virtual int GetMapWidth() override;
    virtual int GetMapHeight() override;
    virtual CIntSize GetRoleSize() override;
    virtual bool IsCanFly(int x, int y) override;
    void OnAddBestPoint(int x, int y) override;
    void OnUnAddBestPoint(int x, int y) override;
private:
    weak_ptr<CNewMap> m_pNewMap;
    CIntSize m_roleSize;
};



#include "stdafx.h"
#include "MobFlyAStar.h"
#include "NewMap.h"

CMobAStarFly& CMobAStarFly::GetInstance()
{
    static CMobAStarFly s_Instance;
    return s_Instance;
}

bool CMobAStarFly::FindPath(const std::shared_ptr<CNewMap>& pMap, const CIntPoint& from, const CIntPoint& to, CAStarFly::PosList& pathList, const CIntSize& roleSize)
{
    m_pNewMap = pMap;
    m_roleSize = roleSize;

    return CalcPath(pathList, from, to);
}

int CMobAStarFly::GetMapWidth()
{
    if (m_pNewMap.lock() == nullptr)
        return 0;

    return m_pNewMap.lock()->GetWidth();
}

int CMobAStarFly::GetMapHeight()
{
    if (m_pNewMap.lock() == nullptr)
        return 0;

    return m_pNewMap.lock()->GetHeight();
}

CIntSize CMobAStarFly::GetRoleSize()
{
    return m_roleSize;
}

bool CMobAStarFly::IsCanFly(int x, int y)
{
    for (int w = 0; w < m_roleSize.width; ++w)
    {
        for (int h = 0; h < m_roleSize.height; ++h)
        {
            if (m_pNewMap.lock()->IsPosBlock(m_pNewMap.lock()->PosToWorldX(x + w), m_pNewMap.lock()->PosToWorldY(y - h)))    {
                return false;
            }
        }
    }

    return true;
}

void CMobAStarFly::setpath(int x, int y)
{
    
}

void CMobAStarFly::show()
{

}

void CMobAStarFly::OnAddBestPoint(int x, int y)
{

}

void CMobAStarFly::OnUnAddBestPoint(int x, int y)
{

}
posted on 2017-08-17 14:43 C++技術中心 閱讀(1493) 評論(1)  編輯 收藏 引用 所屬分類: 游戲開發

Feedback

# re: A*算法實現 2020-08-26 14:42 放屁阿狗
我也寫了個astar 演示程序
http://wallizard.com/eric/astar/  回復  更多評論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美激情成人在线视频| 亚洲日本久久| 亚洲欧美综合v| 欧美视频一区在线观看| 亚洲图片在区色| 亚洲一区二区不卡免费| 国产日韩视频一区二区三区| 久久久另类综合| 欧美高清在线视频观看不卡| 一区二区三区高清在线观看| 一本大道久久a久久精品综合 | 亚洲第一主播视频| 欧美成人亚洲成人| 亚洲一区二区动漫| 午夜在线电影亚洲一区| 在线免费一区三区| av成人手机在线| 合欧美一区二区三区| 亚洲国产另类久久精品| 国产精品日韩精品| 欧美顶级少妇做爰| 国产精品久久久久久久久久三级| 久久精品91久久久久久再现| 女生裸体视频一区二区三区| 一区二区欧美激情| 亚洲免费中文字幕| 亚洲激情电影中文字幕| 99re国产精品| ●精品国产综合乱码久久久久| 亚洲精品激情| 伊人狠狠色j香婷婷综合| 亚洲精品久久久蜜桃| 国产一区二区三区免费不卡 | 久久久久一区| 欧美激情第三页| 玖玖玖国产精品| 国产精品毛片| 亚洲国产欧美国产综合一区| 国产精品视频xxx| 亚洲激情成人| 亚洲国产成人在线| 亚洲免费影视| 一本大道久久a久久精二百| 欧美一区午夜精品| 亚洲午夜一区二区三区| 欧美大片一区二区| 欧美11—12娇小xxxx| 国产精品一区二区久久久久| 亚洲人成艺术| 亚洲精品婷婷| 久久亚洲一区二区三区四区| 久久久99国产精品免费| 欧美视频国产精品| 亚洲免费成人av| 99精品国产福利在线观看免费| 久久精品国产免费看久久精品| 欧美亚洲综合在线| 国产精品久久精品日日| 99综合视频| 亚洲深夜福利| 欧美日韩精品一区| 亚洲欧洲一区二区三区久久| 最近看过的日韩成人| 久热精品视频在线免费观看| 免费观看成人鲁鲁鲁鲁鲁视频| 国产亚洲视频在线| 西西裸体人体做爰大胆久久久| 欧美一区二区免费| 国产麻豆日韩| 欧美在线视频日韩| 麻豆国产精品va在线观看不卡| 影音先锋在线一区| 久久久亚洲精品一区二区三区| 免费不卡视频| 91久久综合亚洲鲁鲁五月天| 欧美韩日高清| 99热精品在线| 欧美在线观看一区二区| 国产日韩久久| 久久一区二区三区超碰国产精品| 欧美成人免费大片| 亚洲伦理在线免费看| 欧美激情第一页xxx| 一本色道久久综合狠狠躁篇怎么玩| 国产精品99久久久久久久女警| 欧美日韩视频一区二区三区| 亚洲在线免费视频| 理论片一区二区在线| 亚洲精品国产系列| 国产精品超碰97尤物18| 欧美一区二区三区四区高清| 免费成人在线视频网站| 99精品国产在热久久下载| 国产精品久久久久久福利一牛影视 | 香蕉久久一区二区不卡无毒影院| 国产欧美一区二区三区另类精品 | 亚洲欧美在线免费| 久久天天躁狠狠躁夜夜爽蜜月| 91久久黄色| 国产精品久久久久久户外露出| 久久不射中文字幕| 亚洲国产小视频| 久久精品国产精品| 亚洲欧洲日韩女同| 国产精品揄拍500视频| 免费成人av资源网| 亚洲男女自偷自拍图片另类| 亚洲国产成人在线| 欧美在线3区| 一区二区三区日韩精品视频| 国产在线欧美| 欧美日韩一区二区三| 久久久国产91| 亚洲午夜精品网| 亚洲国产美国国产综合一区二区| 欧美一区二区三区日韩| 日韩视频永久免费| 黄色日韩网站| 国产农村妇女精品| 欧美日韩蜜桃| 激情欧美一区二区三区在线观看 | 亚洲欧美综合精品久久成人| 美女诱惑一区| 欧美亚洲在线视频| 亚洲午夜国产一区99re久久| 亚洲国产导航| 激情亚洲网站| 国产一区视频网站| 国产伦精品一区二区三区高清 | 久久三级视频| 欧美亚洲在线视频| 亚洲一区二区日本| 一片黄亚洲嫩模| 亚洲免费成人av| 亚洲精品一二区| 最新日韩在线| 亚洲国产精品一区| 欧美激情1区| 欧美aaaaaaaa牛牛影院| 久久久亚洲高清| 久久久久91| 久久青草欧美一区二区三区| 久久久精品午夜少妇| 欧美在线视频一区| 久久精品水蜜桃av综合天堂| 欧美一区在线直播| 欧美一区三区二区在线观看| 午夜日韩视频| 久久精品国产77777蜜臀| 久久精品国产免费看久久精品 | 亚洲黄色成人| 亚洲电影免费观看高清完整版| 国内精品久久久久久久影视麻豆 | 免费成人在线观看视频| 久久综合久久综合九色| 蜜桃久久精品乱码一区二区| 欧美二区在线看| 亚洲人成绝费网站色www| 亚洲人成在线播放网站岛国| 一区二区欧美日韩| 亚洲欧洲av一区二区| 欧美在线高清视频| 看欧美日韩国产| 欧美日韩国产va另类| 国产精品欧美日韩| 狠狠入ady亚洲精品| 亚洲欧洲一区二区在线播放| 中文av字幕一区| 欧美自拍偷拍| 欧美激情在线狂野欧美精品| 99re这里只有精品6| 午夜精品久久久久久久久久久久久 | 欧美成人亚洲| av成人毛片| 久久久999精品视频| 欧美风情在线观看| 国产乱肥老妇国产一区二| 在线观看欧美日本| 亚洲自拍偷拍麻豆| 久久噜噜亚洲综合| 亚洲精品永久免费精品| 香蕉久久精品日日躁夜夜躁| 欧美freesex8一10精品| 国产精品一区二区视频| 亚洲精品乱码久久久久久蜜桃91 | 亚洲综合国产精品| 蜜桃av一区| 亚洲新中文字幕| 欧美xart系列高清| 国产亚洲欧美色| 亚洲一区二区三区高清不卡| 久久综合狠狠| 一区二区三区日韩| 欧美1区2区| 精品69视频一区二区三区| 亚洲欧美日韩专区| 91久久精品一区| 久久影院午夜片一区| 国产精品丝袜久久久久久app| 亚洲裸体在线观看|