A* (AStar) 尋路

//調用工具類獲取路線

? ? ? ? let route = AStarSearch.getRoute(start_point, end_point, this.mapFloor.map_point);

map_point 是所有可走點的集合

import { _decorator, Component, Node, Prefab, instantiate, v3, Vec2 } from 'cc';
import { oops } from "../../../../../extensions/oops-plugin-framework/assets/core/Oops";
import { GameWorld } from "../../../GameWorld";
import { MapFloor, RowColData } from "../../../../Scripts/MapEditor/MapFloor";export class Point {x: number;y: number;constructor(x: number, y: number) {this.x = x;this.y = y;}G: number = 0;   //G = 從起點A,沿著產生的路徑,移動到網格上指定方格的移動耗費。H: number = 0;   //H = 從網格上那個方格移動到終點B的預估移動耗費F: number = 0;   //F = G + Hfather: Point = null;   //這個點的上一個點,通過回溯可以找到起點 is_close: boolean = false;   //是否關閉搜索
}export class AStarSearch {static start: Point = null;      //起點static end: Point = null;        //終點static map: Map<string, Point> = null;   //地圖pointstatic openSet: Set<Point> = new Set();  //開放隊列static pppp: Point = null;       //執行完尋路,它就有值了,除非沒找到/*** 獲取路線 (此尋路不走斜線)*/static getRoute(start: Point, end: Point, map_point: Map<string, { row: number, col: number }>): Point[] {//清空上次尋路,并賦值this.is_find = false;this.openSet.clear();this.pppp = null;this.start = { ...start };this.end = { ...end };this.map = new Map<string, Point>();map_point.forEach((value, key) => {let point = new Point(value.row, value.col);this.map.set(key, point);});let route = new Array<Point>();let keyStr = this.start.x + "_" + this.start.y;if (!this.map.has(keyStr)) {return route;}this.map.get(keyStr).G = 0;       //起點的G是0//開始尋路try {this.search(this.start);     //內存不夠會報錯,一般是起點或終點封閉} catch (error) {console.warn("位置不對", error);return route;}if (this.pppp) {this.getFather(this.pppp, route);}return route;}/*** 尋路*/static is_find = false;    //是否已經找到路線static search(point: Point) {if (point.x == this.end.x && point.y == this.end.y) {this.is_find = true;this.pppp = point;return;}let arr = this.getAround(point);arr.forEach(p => {this.setFather(p, point);});//arr按照F排序 從小到大this.openSet = new Set([...this.openSet].sort(this.compare));//遞歸繼續找this.openSet.forEach((pp, index, arr) => {if (pp.is_close) {        //刪除沒用的this.openSet.delete(pp);}if (!this.is_find) {this.search(pp);}});}/*** 獲取周圍4個點,上下左右*/static getAround(point: Point) {point.is_close = true;let arr = new Array<Point>();let index: string;let p: Point;//上、下、左、右let aroundPos = [{ x: point.x, y: point.y - 1 },{ x: point.x, y: point.y + 1 },{ x: point.x - 1, y: point.y },{ x: point.x + 1, y: point.y }]aroundPos.forEach(point => {index = point.x + "_" + point.y;p = this.map.get(index);if (p && !p.is_close) {arr.push(p);this.openSet.add(p);}})return arr;}/*** point換父親,并重新計算G、H、F*/static setFather(son: Point, father: Point) {if (!son.father || son.father.G > father.G) {son.father = father;son.G = son.father.G + 1;son.H = Math.abs(son.x - this.end.x) + Math.abs(son.y - this.end.y);son.F = son.G + son.H;}}/*** 比較器*/static compare(p1: Point, p2: Point) {if (p1.F > p2.F) {return 1;} else {return -1;}}/*** 遞歸 把祖宗放進route里面*/static getFather(point: Point, route: Array<Point>) {let father = point.father;if (father) {this.getFather(father, route);}route.push(point);}
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/80181.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/80181.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/80181.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

深度解析動態IP業務核心場景:從技術演進到行業實踐

引言&#xff1a;動態IP的技術演進與行業價值 在數字化轉型加速的今天&#xff0c;IP地址已從單純的網絡標識演變為支撐數字經濟的核心基礎設施。動態IP作為靈活高效的地址分配方案&#xff0c;正突破傳統認知邊界&#xff0c;在網絡安全防護、數據價值挖掘、全球業務拓展等領…

MySQL 性能調優:從執行計劃到硬件瓶頸

MySQL 性能調優&#xff1a;從執行計劃到硬件瓶頸 一、性能調優的宏觀視角與核心挑戰 在數字化浪潮下&#xff0c;企業數據量呈指數級增長&#xff0c;MySQL 作為主流關系型數據庫&#xff0c;面臨著巨大的性能壓力。某電商平臺日均訂單量突破千萬&#xff0c;高峰期數據庫響…

開源數字人框架 AWESOME - DIGITAL - HUMAN:技術革新與行業標桿價值剖析

一、項目核心價值:解鎖數字人技術新境界 1. 技術普及:降低準入門檻,推動行業民主化 AWESOME - DIGITAL - HUMAN 項目猶如一場技術春雨,為數字人領域帶來了普惠甘霖。它集成了 ASR、LLM、TTS 等關鍵能力,并提供模塊化擴展接口,將原本復雜高深的數字人開發流程,轉化為一…

robotframe啟動ride.py

我的雙擊ride.py會自動用pycharm打開&#xff0c;變成代碼文件 解決方法&#xff1a;定位到ride.py所在文件夾&#xff08;在anaconda的scripts里面&#xff09;&#xff0c;文件夾上方輸入cmd 再輸入該命令即可

怎樣簡單實現不同數據庫的表間的 JOIN 運算

數據分析涉及不同業務系統時就要做跨庫計算&#xff0c;而表間 JOIN 是最麻煩的&#xff0c;很多數據庫都不具備這樣的能力&#xff0c;用 Java 取數再計算又太復雜。用 esProc 完成跨庫 JOIN 會簡單很多。 數據與用例 車輛管理系統&#xff08;DB_Vehicle&#xff09;保存了…

Nacos源碼—4.Nacos集群高可用分析三

大綱 6.CAP原則與Raft協議 7.Nacos實現的Raft協議是如何寫入數據的 8.Nacos實現的Raft協議是如何選舉Leader節點的 9.Nacos實現的Raft協議是如何同步數據的 10.Nacos如何實現Raft協議的簡版總結 6.CAP原則與Raft協議 (1)CAP分別指的是什么 (2)什么是分區以及容錯 (3)為…

普通IT的股票交易成長史--20250509晚復盤

聲明&#xff1a; 本文章的內容只是自己學習的總結&#xff0c;不構成投資建議。價格行為理論學習可參考簡介中的幾位&#xff0c;感謝他們的無私奉獻。 送給自己的話&#xff1a; 倉位就是生命&#xff0c;絕對不能滿倉&#xff01;&#xff01;&#xff01;&#xff01;&…

python實現點餐系統

使用python實現點餐系統的增加菜品及價格&#xff0c;刪除菜品&#xff0c;查詢菜單&#xff0c;點菜以及會員折扣價等功能。 代碼&#xff1a; 下面展示一些 內聯代碼片。 # coding utf-8menu {拍黃瓜: 6, 小炒肉: 28, 西紅柿炒蛋: 18, 烤魚: 30, 紅燒肉: 38, 手撕雞: 45,…

從ellisys空口分析藍牙耳機回連手機失敗案例

問題背景&#xff1a; 前兩天同事發現我們現在做的項目&#xff0c;耳機在跟某些特定類型安卓手機&#xff08;尤其是比較新的手機&#xff09;回連會失敗&#xff0c;然后我幫他分析了一些log&#xff0c;記錄如下&#xff1a; 回連失敗所做步驟如下&#xff1a; 手機和耳機…

教育+AI:個性化學習能否顛覆傳統課堂?

近年來&#xff0c;人工智能&#xff08;AI&#xff09;技術迅猛發展&#xff0c;逐漸滲透到各行各業&#xff0c;教育領域也不例外。從智能輔導系統到自適應學習平臺&#xff0c;AI正在改變傳統的教學模式&#xff0c;使個性化學習成為可能。然而&#xff0c;這種變革能否真正…

【C++設計模式之Strategy策略模式】

C設計模式之Strategy策略模式 模式定義核心思想動機(Motivation)結構(Structure)實現步驟1. 定義策略接口&#xff08;基于繼承&#xff09;2.實現具體策略3.上下文類(Context)4. 在main中調用 應用場景&#xff08;基于繼承&#xff09;1.定義策略接口2.實現具體策略3.上下文類…

Python企業級MySQL數據庫開發實戰指南

簡介 Python與MySQL的完美結合是現代Web應用和數據分析系統的基石,能夠創建高效穩定的企業級數據庫解決方案。本文將從零開始,全面介紹如何使用Python連接MySQL數據庫,設計健壯的表結構,實現CRUD操作,并掌握連接池管理、事務處理、批量操作和防止SQL注入等企業級開發核心…

matlab轉python

1 matlab2python開源程序 https://blog.csdn.net/qq_43426078/article/details/123384265 2 網址 轉換網址&#xff1a;https://app.codeconvert.ai/code-converter?inputLangMatlab&outputLangPython 文件比較網址&#xff1a;https://www.diffchecker.com/text-comp…

Vue 3 中編譯時和運行時的概念區別

文章目錄 前言Vue 3 中的編譯時 vs 運行時區別模板在編譯時轉化為渲染函數編譯時的優化處理運行時的工作:創建組件實例與渲染流程前言 詳細整理 Vue 3 中編譯時和運行時的概念區別,并重點解釋為什么組件實例是在運行時創建的。 我會結合官方文檔、源碼分析和社區解釋,確保內…

Spring 框架實戰:如何實現高效的依賴注入,優化項目結構?

Spring 框架實戰&#xff1a;如何實現高效的依賴注入&#xff0c;優化項目結構&#xff1f; 在當今的 Java 開發領域&#xff0c;Spring 框架占據著舉足輕重的地位。而依賴注入作為 Spring 的核心概念之一&#xff0c;對于構建高效、靈活且易于維護的項目結構有著關鍵作用。本…

創建虛擬服務時實現持久連接。

在調度器中配置虛擬服務&#xff0c;實現持久性連接&#xff0c;解決會話保持問題。 -p 【timeout】 -p 300 這5分鐘之內調度器會把來自同一個客戶端的請求轉發到同一個后端服務器。【不管使用的調度算法是什么。】【稱為持久性連接。】 作用&#xff1a;將客戶端一段時間…

說下RabbitMQ的整體架構

RabbitMQ 是一個基于 AMQP&#xff08;Advanced Message Queuing Protocol&#xff09; 協議的開源消息中間件&#xff0c;RabbitMQ的整體架構圍繞消息的生產、路由、存儲和消費設計&#xff0c;旨在實現高效、可靠的消息傳遞&#xff0c;它由多個核心組件協同工作。 核心組件 …

STM32--GPIO

教程 視頻 博主教程 STM32系統結構圖 GPIO GPIO&#xff08;General Purpose Input/Output&#xff09;是STM32內部的一種外設。 一個STM32芯片內存在多個GPIO外設&#xff0c;每個GPIO外設有16個引腳&#xff1b; 比如GPIOA&#xff1a;PA0~PA15; GPIOB&#xff1a;PB0~…

QUIC協議優化:HTTP_3環境下的超高速異步抓取方案

摘要 隨著 QUIC 和 HTTP/3 的普及&#xff0c;基于 UDP 的連接復用與內置加密帶來了遠超 HTTP/2 的性能提升&#xff0c;可顯著降低連接握手與擁塞恢復的開銷。本文以爬取知乎熱榜數據為目標&#xff0c;提出一種基于 HTTPX aioquic 的異步抓取方案&#xff0c;并結合代理 IP設…

[論文閱讀]MCP Guardian: A Security-First Layer for Safeguarding MCP-Based AI System

MCP Guardian: A Security-First Layer for Safeguarding MCP-Based AI System http://arxiv.org/abs/2504.12757 推出了 MCP Guardian&#xff0c;這是一個框架&#xff0c;通過身份驗證、速率限制、日志記錄、跟蹤和 Web 應用程序防火墻 &#xff08;WAF&#xff09; 掃描來…