亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? globalmap.h

?? InnovLabSimu在vc++下實(shí)現(xiàn)
?? H
字號(hào):
#pragma once

#include <vector>
#include <fstream>
#include "../particleFlt/sir_pf_share.h"
#include "../Global.h"
#include "../Localization.h"
//#include <afxwin.h>
/********************************************************************
	created:	2008/07/11
	created:	11:7:2008   9:20
	filename: 	c:\RoboCupSimu\RoboCupSimu2\RoboCupSimu\controllers\Robot2005_V2\GlobalMap.h
	file path:	c:\RoboCupSimu\RoboCupSimu2\RoboCupSimu\controllers\Robot2005_V2
	file base:	GlobalMap
	file ext:	h
	author:		GaoYang
	
	purpose:	全局地圖類(lèi),包括讀入地圖,從地圖中查找值,地圖按照webots中仿真的坐標(biāo)系建立,地圖中央為原點(diǎn),坐標(biāo)有正負(fù),坐標(biāo)系方向則是向上為Y軸正向,與仿真中的Z軸反向
	            x軸與仿真中的webots重合
	            而地圖文件中是以左上角為原點(diǎn),右、下方向?yàn)檎?*********************************************************************/
#define JUDGE_EDGE_POINT_IN_MAP//bool地圖中是否單獨(dú)考慮了障礙物的邊界點(diǎn),若是,則定義它,則讀入bool地圖是,需注意,地圖中的邊界點(diǎn),值不是0,而是2000
typedef std::vector<std::vector<float>> MAP_TYPE;
typedef std::vector<std::vector<bool>> BoolMapType;

#define ONE_PIXEL_LENGTH 50///<每一像素的長(zhǎng)度,單位豪米,應(yīng)與DrawMap中對(duì)應(yīng)
#define PRECISION 100///<地圖中存的距離值的有效精度,因?yàn)榇娴氖钦?所以以這種方法保證小數(shù)點(diǎn)后的精度.實(shí)際上單位為毫米的距離=地圖值/PRECISION*10,
#define NON_OBJECT_VAL 16777215///<無(wú)障礙物點(diǎn)的地圖值
#define EDGE_POINT_VAL_IN_BOOL_MAP 2000///<存在二值地圖的文件中,表示障礙物點(diǎn)的地圖值
class CGlobalMap
{
public:
	CGlobalMap(void);
	CGlobalMap(unsigned Height,unsigned Width);
public:
	~CGlobalMap(void);
	/**
	*從已有文件中讀入二值地圖,1表示空白,0表示障礙物,本函數(shù)從默認(rèn)文件中讀
	*
	*/
	bool ReadBoolMapFromFile(unsigned Height,unsigned Width);
#ifdef JUDGE_EDGE_POINT_IN_MAP
	BoolMapType m_bvEdgePointMap;///<bool地圖,是邊界點(diǎn)則為真,不是則為假
	/**
	*@brief 是否邊界點(diǎn)的查詢(xún)函數(shù),輸入世界坐標(biāo)系坐標(biāo),但要求先轉(zhuǎn)化為像素為單位
	*
	*@parm XCoord 世界坐標(biāo)系X坐標(biāo),但要求先轉(zhuǎn)化為像素為單位
	*@parm YCoord 世界坐標(biāo)系Y坐標(biāo),但要求先轉(zhuǎn)化為像素為單位
	*@output 若是邊界點(diǎn)則返回真
	*/
	bool IsEdgePoint(float XCoord,float YCoord)
	{
		if (fabs(XCoord)>X_DisOfWordCord2MapCoord||
			fabs(YCoord)>Y_DisOfWordCord2MapCoord)
		{
			return false;//產(chǎn)生的點(diǎn)超出整個(gè)地圖范圍時(shí),返回不可能
		}
		float MemoryCoordX=X_DisOfWordCord2MapCoord+XCoord;//轉(zhuǎn)化為像素?cái)?shù)的圖像坐標(biāo)單位
		float MemoryCoordY=Y_DisOfWordCord2MapCoord-YCoord;//轉(zhuǎn)化為像素?cái)?shù)的圖像坐標(biāo)單位
		return  m_bvEdgePointMap[Floor4_Ceil5(MemoryCoordY)][Floor4_Ceil5(MemoryCoordX)];
	}

#endif
	BoolMapType m_BoolGolbalMap;
	MAP_TYPE m_mGolbalMap;///<全局地圖,由兩個(gè)vector嵌套而成,最外層的每一個(gè)元素為一行,即m_mGolbalMap[4][5]為下標(biāo)4行,5列的元素,下標(biāo)從0開(kāi)始數(shù)起
	size_t X_DisOfWordCord2MapCoord;///<世界地圖原點(diǎn)相對(duì)圖像原點(diǎn)沿地圖的圖像坐標(biāo)系的X軸方向偏移
	size_t Y_DisOfWordCord2MapCoord;///<世界地圖原點(diǎn)相對(duì)圖像原點(diǎn),沿地圖的圖像坐標(biāo)系的Y軸方向偏移
	/**
	*從已有文件中讀入地圖,本函數(shù)從默認(rèn)文件中讀,指定圖的寬度和高度
	*
	*/
	bool ReadMapFromFile(unsigned Height,unsigned Width);
	/**
	*從已有地圖中,依據(jù)X,Y坐標(biāo)查詢(xún)地圖對(duì)應(yīng)點(diǎn)的誤差距離值(地圖中對(duì)應(yīng)點(diǎn)存的值)
	*
	*/
	//float QueryGridValOnMap(float XCoord,float YCoord);
	/**
	*從已有地圖中,依據(jù)X,Y坐標(biāo)查詢(xún)地圖對(duì)應(yīng)點(diǎn)的誤差距離值(地圖中對(duì)應(yīng)點(diǎn)存的值),當(dāng)所查詢(xún)點(diǎn)為一個(gè)靠近邊緣的點(diǎn),則地圖中直接存了距離值取出即可
	*
	*
	*/
	float QueryAnFreeGridVal(float& XCoord,float& YCoord)
	{
		return QueryGridValOnMap(XCoord,YCoord);
	}
	/**
	*部分額外的數(shù)學(xué)運(yùn)算,目前包括四舍五入運(yùn)算
	*/
	long Floor4_Ceil5(float& NumTobeOperate)
	{
		long IntPart=floor(NumTobeOperate);//取整數(shù)部分
		if (NumTobeOperate-IntPart>=0.5)
		{
			return IntPart+1;
		}
		else
		{
			return IntPart;
		}
	}
	/**
	*@brief 在地圖中膨脹障礙物范圍,擴(kuò)充障礙物點(diǎn),獲得新的二值地圖結(jié)果仍然存放在m_BoolGolbalMap
	*
	*@parm Height地圖的高度
	*@parm Height地圖的寬度
	*@parm ExpandWidthInPixel對(duì)障礙物點(diǎn),需要向外擴(kuò)充多少個(gè)像素,注意單位是像素?cái)?shù)
	*/
	void ExpandObstacleOnboolMap(unsigned Height,unsigned Width,unsigned ExpandWidthInPixel);
	/**
	*@brief 從已有地圖中,依據(jù)X,Y坐標(biāo)查詢(xún)二值地圖對(duì)應(yīng)點(diǎn)的值(地圖中對(duì)應(yīng)點(diǎn)存的值)
	*返回1表示空白,0表示障礙物,越界則返回0(false)
	*/
	bool QueryboolMap(float& XCoord,float& YCoord)
	{
		if (fabs(XCoord)>X_DisOfWordCord2MapCoord||
			fabs(YCoord)>Y_DisOfWordCord2MapCoord)
		{
			return false;//產(chǎn)生的點(diǎn)超出整個(gè)地圖范圍時(shí),返回不可能
		}
		float MemoryCoordX=X_DisOfWordCord2MapCoord+XCoord;//轉(zhuǎn)化為像素?cái)?shù)的圖像坐標(biāo)單位
		float MemoryCoordY=Y_DisOfWordCord2MapCoord-YCoord;//轉(zhuǎn)化為像素?cái)?shù)的圖像坐標(biāo)單位
		bool tmp=m_mGolbalMap[Floor4_Ceil5(MemoryCoordY)][Floor4_Ceil5(MemoryCoordX)];//測(cè)試用,應(yīng)去掉
		return tmp;	
		
	}
	bool IsAPossibleLocate(CParticle& LocTobeCheck)
	{
		return QueryboolMap(LocTobeCheck.XCoord,LocTobeCheck.YCoord);
		
	}
	typedef bool (CGlobalMap::*pCheckLocPossibleFun)(CParticle& ParticleTobeCheck);
	bool (CGlobalMap::*m_pfCheckPossibleParticle)(CParticle& ParticleTobeCheck) ;///<指向IsAPossibleLocate函數(shù)的指針成員
	/**
	*@brief m_mGolbalMap地圖中存進(jìn)來(lái)的數(shù)據(jù)下標(biāo)是按照0開(kāi)始的,而輸入進(jìn)來(lái)的機(jī)器人世界坐標(biāo)系是原點(diǎn)在中心,有正負(fù),因此本函數(shù)
	*輸入世界坐標(biāo)系坐標(biāo),返回查詢(xún)到的坐標(biāo)值,不經(jīng)任何運(yùn)算,僅進(jìn)行坐標(biāo)轉(zhuǎn)化,并返回查到的內(nèi)容,并未考慮輸入的坐標(biāo)越界的情況!!!
	*
	*注意,本函數(shù)假設(shè) m_mGolbalMap地圖中存進(jìn)來(lái)的數(shù)據(jù)下標(biāo)是按照0開(kāi)始的,原點(diǎn)或者說(shuō)坐標(biāo)系以左上角為原點(diǎn),右、下方向?yàn)檎?	*而假設(shè)輸入的絕對(duì)世界坐標(biāo)系則,以webots中仿真的坐標(biāo)系,地圖中央為原點(diǎn),坐標(biāo)有正負(fù),坐標(biāo)系方向則是向上為Y軸正向,
	*X軸方向兩坐標(biāo)系相同,注意在地圖中是以像素為單位存的,而輸入的直角坐標(biāo)單位是毫米,一個(gè)像素=?毫米??所以要進(jìn)行一次轉(zhuǎn)化
	*
	*@todo 萬(wàn)一地圖的大小是奇數(shù),則進(jìn)行本函數(shù)轉(zhuǎn)化會(huì)有一個(gè)像素的誤差問(wèn)題!!
	*/
	float QueryGridValOnMap(float XCoord,float YCoord)
	{
		if (fabs(XCoord)>X_DisOfWordCord2MapCoord||
			fabs(YCoord)>Y_DisOfWordCord2MapCoord)
		{
			return 3.4e8;//產(chǎn)生的點(diǎn)超出整個(gè)地圖范圍時(shí),隨便返回的一個(gè)大的數(shù),表示不可能
		}
		float MemoryCoordX=X_DisOfWordCord2MapCoord+XCoord;//轉(zhuǎn)化為像素?cái)?shù)的圖像坐標(biāo)單位
		float MemoryCoordY=Y_DisOfWordCord2MapCoord-YCoord;//轉(zhuǎn)化為像素?cái)?shù)的圖像坐標(biāo)單位
		int MapDisVal=m_mGolbalMap[Floor4_Ceil5(MemoryCoordY)][Floor4_Ceil5(MemoryCoordX)];
		return TransferMapVal2RealDis(MapDisVal);///<將地圖存的距離轉(zhuǎn)化為實(shí)際單位為毫米的值
	}
	/**
	*@brief地圖中存的距離值的是整型數(shù),當(dāng)初保證小數(shù)點(diǎn)后的精度.定義了一個(gè)PRECISION參數(shù),所以實(shí)際上單位為毫米的實(shí)際距離=地圖值/PRECISION*10,
	*
	*@parm MapValue 地圖中存的距離值
	*/
	float TransferMapVal2RealDis(int MapValue)
	{
		return MapValue/PRECISION*10;
	}
	
};

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产91丝袜在线播放| 精品欧美一区二区久久| 91麻豆自制传媒国产之光| 国产成人免费视频网站高清观看视频| 日韩国产欧美在线播放| 日韩精品一二区| 日本伊人色综合网| 免费日本视频一区| 精品中文av资源站在线观看| 激情都市一区二区| 一道本成人在线| 5566中文字幕一区二区电影| 欧美亚洲国产bt| 欧美午夜不卡视频| 欧美午夜一区二区三区| 欧美人牲a欧美精品| 欧美一卡在线观看| 26uuu精品一区二区| 国产欧美日本一区二区三区| 国产精品天干天干在线综合| 亚洲精品免费一二三区| 亚洲第一av色| 久久9热精品视频| 国产高清不卡一区二区| 99精品久久99久久久久| 欧美在线你懂得| 欧美精品高清视频| 久久久99精品免费观看不卡| 国产精品久久久久桃色tv| 亚洲另类中文字| 人人精品人人爱| 国产高清不卡二三区| 一本一本久久a久久精品综合麻豆| 在线观看区一区二| 欧美精品v日韩精品v韩国精品v| 精品国一区二区三区| 国产精品热久久久久夜色精品三区 | 伊人夜夜躁av伊人久久| 日韩制服丝袜av| 国产精品99久久不卡二区| 91蜜桃视频在线| 日韩一区二区在线看| 国产欧美久久久精品影院| 亚洲一卡二卡三卡四卡 | 99在线视频精品| 欧美日韩国产综合久久| 久久久久久一级片| 一区二区三区精品久久久| 久久精品99国产精品| 91婷婷韩国欧美一区二区| 日韩一区二区在线观看视频| 国产精品久久久久9999吃药| 婷婷成人激情在线网| 国产成人午夜精品5599| 欧美日韩免费观看一区三区| 国产午夜亚洲精品羞羞网站| 亚洲一线二线三线视频| 国产成人aaa| 日韩视频中午一区| 亚洲免费av观看| 国产在线播放一区| 7777精品伊人久久久大香线蕉的 | 免费观看在线色综合| 丁香亚洲综合激情啪啪综合| 一区二区三区四区视频精品免费| 狠狠色丁香婷综合久久| 精品视频色一区| 国产欧美日韩精品一区| 青青草原综合久久大伊人精品| 成人v精品蜜桃久久一区| 日韩免费观看2025年上映的电影| 一区二区三区波多野结衣在线观看 | 亚洲国产日韩精品| 丁香网亚洲国际| 精品国产污污免费网站入口| 亚洲3atv精品一区二区三区| 成人一区二区视频| 欧美精品一区二区三区很污很色的| 亚洲bt欧美bt精品777| 99re热视频精品| 久久久久久久综合日本| 美女网站视频久久| 欧美日韩国产一级| 伊人性伊人情综合网| 99精品国产99久久久久久白柏 | 免费精品视频在线| 欧美三区在线观看| 亚洲男女一区二区三区| 成人一道本在线| 欧美国产精品v| 国内成人自拍视频| www国产成人免费观看视频 深夜成人网| 丝袜美腿亚洲一区| 欧美性大战久久久久久久蜜臀| 亚洲欧美色一区| 99久久综合狠狠综合久久| 中文子幕无线码一区tr| 国产91露脸合集magnet| 国产片一区二区三区| 国产精品综合一区二区三区| 亚洲精品一线二线三线 | 精品久久久久久久久久久久久久久| 日韩高清不卡一区| 7777精品伊人久久久大香线蕉超级流畅 | 欧美日韩精品综合在线| 亚洲午夜在线视频| 欧美日韩另类国产亚洲欧美一级| 亚洲v日本v欧美v久久精品| 欧美日韩美女一区二区| 日韩电影在线一区| 欧美一级精品大片| 九色综合狠狠综合久久| 久久青草欧美一区二区三区| 风间由美中文字幕在线看视频国产欧美 | 亚洲欧美日韩一区二区三区在线观看| 99精品欧美一区二区三区综合在线| 综合欧美亚洲日本| 色欧美片视频在线观看在线视频| 一区二区三区国产| 欧美日韩性生活| 免费成人在线网站| 久久人人超碰精品| 成人av资源网站| 亚洲一级片在线观看| 日韩视频免费直播| 国产精品18久久久久久久网站| 国产午夜亚洲精品午夜鲁丝片| 成人av网址在线| 亚洲成av人片| 久久久久久一二三区| 亚洲国产精品自拍| 国产午夜精品久久| 国产精品女上位| 国产片一区二区| 国产亚洲综合色| 久久你懂得1024| 中文字幕日韩av资源站| 91亚洲精品乱码久久久久久蜜桃| 日韩三级高清在线| 久久精品国产澳门| 日韩一区二区三区电影在线观看 | 日韩欧美一区二区在线视频| aaa亚洲精品| 久久精品亚洲精品国产欧美| 午夜亚洲国产au精品一区二区| 色综合一区二区| 精品视频一区 二区 三区| www.日韩大片| 成人国产免费视频| 欧美调教femdomvk| 国产成人精品亚洲777人妖| 国产·精品毛片| 久久97超碰国产精品超碰| av午夜精品一区二区三区| 91色视频在线| 亚洲精品一线二线三线无人区| 91精品国产欧美一区二区| 欧美三级韩国三级日本一级| 91精品黄色片免费大全| 国产精品久久久久影院色老大 | 日韩高清在线观看| 日韩精品电影一区亚洲| 狠狠色丁香婷婷综合| 色婷婷久久久亚洲一区二区三区| 色狠狠桃花综合| 欧美性xxxxxxxx| 久久久久久久久久久久久夜| 亚洲日本在线观看| 午夜日韩在线电影| 91精品国产全国免费观看| 久久丝袜美腿综合| 亚洲欧洲美洲综合色网| 另类欧美日韩国产在线| 成人黄页毛片网站| 在线视频一区二区三| 精品成人在线观看| 亚洲精品五月天| 国产一区激情在线| 欧美日韩国产在线观看| 1区2区3区国产精品| 亚洲一区av在线| 欧美日韩成人一区| 国产精品不卡一区二区三区| 国产成人免费9x9x人网站视频| 国产精品国产精品国产专区不蜜 | 欧美精品乱码久久久久久| 久久精品人人做| www.日韩精品| 亚洲最新在线观看| 色综合中文字幕| 亚洲欧美激情视频在线观看一区二区三区 | 精品欧美一区二区在线观看 | 不卡大黄网站免费看| 欧美精品乱人伦久久久久久| 亚洲在线免费播放| 亚洲欧洲精品一区二区三区 | 免费观看久久久4p| 五月综合激情婷婷六月色窝| 亚洲日本护士毛茸茸| 国产精品欧美综合在线|