利用百度地圖JavaScript API繪制運(yùn)動(dòng)軌跡

寫在前面
歡迎訪問我的博客

  1. 如果需要使用百度地圖javasript api,需先進(jìn)行開發(fā)者認(rèn)證胸囱,balalalala寫上一堆理由之后認(rèn)證就行幸乒,然后創(chuàng)建瀏覽器端的應(yīng)用掏呼,得到可用的Ak筷黔,詳情見百度地圖開放平臺(tái)姐仅。
  2. 假設(shè)你會(huì)一些簡單的地圖API應(yīng)用绰播,不會(huì)的話請(qǐng)移步這里API應(yīng)用示例骄噪。
  3. 本文能做的就是用QT把一些點(diǎn)經(jīng)緯度傳給JS,并且按順序繪制軌跡蠢箩,在首尾加上標(biāo)注链蕊。

QT

在mainwindow.cpp中修改槽函數(shù):

void MainWindow::on_pushButton_clicked()
{
    QJsonArray num_json,num2_json;                       //聲明QJsonArray
    QJsonDocument num_document,num2_document;    //將QJsonArray改為QJsonDocument類
    QByteArray num_byteArray,num2_byteArray;      //

    double num[2]={114.12,114.13};              //隨便打的
    double num2[2]={30.12,30.13};               //表示兩個(gè)點(diǎn)的經(jīng)緯度
    int i=0;
    for(i=0;i<2;i++)                            //將數(shù)組傳入壓入num_json
    {
        num_json.append(num[i]);
        num2_json.append(num2[i]);
    }

    num_document.setArray(num_json);
    num2_document.setArray(num2_json);
    num_byteArray = num_document.toJson(QJsonDocument::Compact);
    num2_byteArray = num2_document.toJson(QJsonDocument::Compact);
    QString numJson(num_byteArray);             //再轉(zhuǎn)為QString
    QString num2Json(num2_byteArray);             //再轉(zhuǎn)為QString

    //qDebug() << numJson;
    QWebFrame *webFrame = ui->webView->page()->mainFrame();
    QString cmd = QString("showarray(\"%1\",\"%2\")").arg(numJson).arg(num2Json);
    webFrame->evaluateJavaScript(cmd);          //傳給javascript

}

html

<!DOCTYPE html>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
    <style type="text/css">
    body, html,#allmap {width: 100%;height: 100%;overflow: hidden;margin:0;font-family:"微軟雅黑";}
    </style>
    <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=替換成你自己的AK "></script>
    <title>基于GPS的位置追蹤及地理圍欄</title>
</head>
<body>
    <div id="allmap"></div>
</body>
</html>
<script type="text/javascript">
////地圖初始化

var mapOptions={

                minZoom: 3,                 //最小級(jí)別
                maxZoom:19,                 //最大級(jí)別
                mapType:  BMAP_NORMAL_MAP   //默認(rèn)街道圖
              }

var map = new BMap.Map("allmap",mapOptions);        // 創(chuàng)建Map實(shí)例 命名空間為BMAP
map.centerAndZoom(new BMap.Point(114.0, 30.0), 5);  // 初始化地圖,設(shè)置中心點(diǎn)坐標(biāo)和地圖級(jí)別
map.setCurrentCity("武漢");          // 設(shè)置地圖顯示的城市
map.enableScrollWheelZoom(true);     //開啟鼠標(biāo)滾輪縮放


function showhello()
{
    //alert("Welcome, newbird ");
    var string= "hello oldbird";
    ReinforcePC.showinfo(string);//調(diào)用qt中的showinfo函數(shù)
}

function showarray(numlist,num2list)                    //僅把qt傳來的數(shù)組轉(zhuǎn)換成可用的list
{
    //alert(numlist);
    var num_list,num2_list;                         //以下為格式轉(zhuǎn)換,分割成可用的數(shù)組
    num_list = numlist.substring(1,numlist.length-1);
    num2_list = num2list.substring(1,num2list.length-1);
    num_list = num_list.split(",");
    num2_list = num2_list.split(",");
    //alert("the num_list is: "+num_list[0]+" "+num_list[1]);

    var tracelist = [];     //為軌跡做準(zhǔn)備谬泌,把所有的點(diǎn)扔里面滔韵,但不對(duì)每個(gè)點(diǎn)標(biāo)注
    for(i=0;i<num_list.length;i++)
    {
        point= new BMap.Point(num_list[i],num2_list[i]);
        tracelist.push(point);                                  //將每個(gè)點(diǎn)壓入數(shù)組
    }

    var polyline =new BMap.Polyline(tracelist, {
    enableEditing: false,//是否啟用線編輯,默認(rèn)為false
    enableClicking: false,//是否響應(yīng)點(diǎn)擊事件掌实,默認(rèn)為true
    strokeWeight:'4',//折線的寬度陪蜻,以像素為單位
    strokeOpacity: 0.8,//折線的透明度,取值范圍0 - 1
    strokeColor:"red" //折線顏色
    });
    map.addOverlay(polyline);          //增加折線
    map.centerAndZoom(tracelist[num_list.length-1], 15);

    //首尾加上標(biāo)注點(diǎn)
    var marker = new BMap.Marker(tracelist[0]); // 創(chuàng)建點(diǎn)
    map.addOverlay(marker);                 // 加載標(biāo)注

    var marker = new BMap.Marker(tracelist[num_list.length-1]); // 創(chuàng)建點(diǎn)
    map.addOverlay(marker);                 // 加載標(biāo)注

}
</script>

結(jié)果

  1. 初始化


    初始化
  2. 2點(diǎn)(我也不知道這是哪贱鼻。宴卖。滋将。)


    2點(diǎn)
  3. 3點(diǎn)
    在QT中做如下修改:
double num[3]={114.12,114.13,114.14};              //隨便打的
    double num2[3]={30.12,30.13,30.11};
    int i=0;
    for(i=0;i<3;i++)                            //將數(shù)組傳入壓入num_json
    {
        num_json.append(num[i]);
        num2_json.append(num2[i]);
    }

結(jié)果:


3點(diǎn)
  1. n點(diǎn)
    n點(diǎn)

    因此,你要你有一系列的經(jīng)緯度症昏,就能很容易的繪制出軌跡随闽,那怎么得到這些經(jīng)緯度呢,見NMEA解析齿兔。

可能有不正確的地方橱脸,敬請(qǐng)諒解,如果覺得對(duì)您有所幫助分苇,請(qǐng)打賞一下唄添诉,謝謝~
碼字不易,轉(zhuǎn)載請(qǐng)注明地址

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末医寿,一起剝皮案震驚了整個(gè)濱河市栏赴,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌靖秩,老刑警劉巖须眷,帶你破解...
    沈念sama閱讀 211,042評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異沟突,居然都是意外死亡花颗,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門惠拭,熙熙樓的掌柜王于貴愁眉苦臉地迎上來扩劝,“玉大人,你說我怎么就攤上這事职辅“羟海” “怎么了?”我有些...
    開封第一講書人閱讀 156,674評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵域携,是天一觀的道長簇秒。 經(jīng)常有香客問我,道長秀鞭,這世上最難降的妖魔是什么趋观? 我笑而不...
    開封第一講書人閱讀 56,340評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮气筋,結(jié)果婚禮上拆内,老公的妹妹穿的比我還像新娘。我一直安慰自己宠默,他們只是感情好麸恍,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,404評(píng)論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般抹沪。 火紅的嫁衣襯著肌膚如雪刻肄。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,749評(píng)論 1 289
  • 那天融欧,我揣著相機(jī)與錄音敏弃,去河邊找鬼。 笑死噪馏,一個(gè)胖子當(dāng)著我的面吹牛麦到,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播欠肾,決...
    沈念sama閱讀 38,902評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼瓶颠,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了刺桃?” 一聲冷哼從身側(cè)響起粹淋,我...
    開封第一講書人閱讀 37,662評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎瑟慈,沒想到半個(gè)月后桃移,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,110評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡葛碧,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年借杰,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片进泼。...
    茶點(diǎn)故事閱讀 38,577評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡第步,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出缘琅,到底是詐尸還是另有隱情,我是刑警寧澤廓推,帶...
    沈念sama閱讀 34,258評(píng)論 4 328
  • 正文 年R本政府宣布刷袍,位于F島的核電站,受9級(jí)特大地震影響樊展,放射性物質(zhì)發(fā)生泄漏呻纹。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,848評(píng)論 3 312
  • 文/蒙蒙 一专缠、第九天 我趴在偏房一處隱蔽的房頂上張望雷酪。 院中可真熱鬧,春花似錦涝婉、人聲如沸哥力。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽吩跋。三九已至寞射,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間锌钮,已是汗流浹背桥温。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評(píng)論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留梁丘,地道東北人侵浸。 一個(gè)月前我還...
    沈念sama閱讀 46,271評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像氛谜,于是被迫代替她去往敵國和親掏觉。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,452評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容