首頁>技術>

## 一、前言

近期重新將這個地圖綜合應用進行大幅度的改進更新升級,包括使用示例也做了非常多的改進和調整,其中就包括路徑規劃功能,之前只是呼叫了百度地圖的JS互動介面,根據起始點座標經緯度和結束點座標經緯度,查詢出合適的路線,而並木有將查詢到的路徑的軌跡點座標集合取出來,用於其他處理比如發給機器人,讓機器人按照這個軌跡點移動,為了確保取出來的軌跡點座標集合是正確的,還可以將軌跡點用不同的顏色重新繪製出來,和查詢路線得到的軌跡線路進行對比,高度重合就說明是對的。

關於起始座標和結束座標,最開始做的是直接傳入具體中文地址即可,後面百度地圖不再開放此功能,貌似變成了收費功能,但是經緯度和地址互相轉換的功能還是開放的,所以就多了一個步驟,後面做的是直接傳入經緯度座標進行查詢,需要手動輸入,現在做的是直接地圖選點,在起始座標後面的單選框選中然後在地圖上直接選點,對應經緯度座標值會自動填入,這樣相對來說更人性化一些。

拿到軌跡點座標集合進行繪製,其實呼叫的就是addPolyline函式進行繪製,注意收到的軌跡點座標集合很可能是多段的,而不是完整的一段,傳過來的是陣列的陣列,所以需要搞個迴圈將收到的路徑點集合分線段繪製,至於線條的顏色+邊框+透明度都可以設定,以便區分原來的路徑查詢自動繪製的路徑。

## 二、功能特點

1. 同時支援線上地圖和離線地圖兩種模式。

2. 同時支援webkit核心、webengine核心、miniblink核心、IE核心。

3. 支援設定多個標註點,資訊包括名稱、地址、經緯度。

4. 可設定地圖是否可單擊、拖動、滑鼠滾輪縮放。

5. 可設定協議版本、秘鑰、主題樣式、中心座標、中心城市、地理編碼位置等。

6. 可設定地圖縮放比例和級別,縮圖、比例尺、路況資訊等控制元件的可見。

7. 支援地圖互動,比如滑鼠按下獲取對應位置的經緯度。

8. 支援查詢路線,可設定起點位置、終點位置、路線模式、路線方式、路線方案(最少時間、最少換乘、最少步行、不乘地鐵、最短距離、避開高速)。

9. 可顯示點線面工具,可直接在地圖上劃線、點、矩形、圓形等。

10. 可設定行政區劃,指定某個城市區域繪製圖層,線上地圖自動輸出行政區劃邊界點集合到js檔案給離線地圖使用。

11. 可靜態或者動態新增多個覆蓋物。支援點、折線、多邊形、矩形、圓形、弧線、點聚合等。

12. 提供函式介面處理經緯度解析成地址和地址解析成經緯度座標。

13. 提供的demo直接可以單獨選點執行對應的處理比如路線查詢。

14. 可以拿到路線查詢到的點座標資訊集合,比如用於機器人座標導航等。

16. 標註點彈框資訊可以自定義內容,標準html格式。

17. 標註點單擊事件可選 0-不處理 1-自己彈框 2-傳送訊號。

18. 標註點可設定動畫效果 0-不處理 1-跳動 2-墜落

19. 標註點可設定本地圖片檔案等。

20. 函式介面友好和統一,使用簡單方便,就一個類。

22. 支援任意Qt版本、任意系統、任意編譯器。

## 三、體驗地址

1. 體驗地址:[https://pan.baidu.com/s/1ZxG-oyUKe286LPMPxOrO2A](https://pan.baidu.com/s/1ZxG-oyUKe286LPMPxOrO2A) 提取碼:o05q 檔名:bin_map.zip

2. 國內站點:[https://gitee.com/feiyangqingyun](https://gitee.com/feiyangqingyun)

3. 國際站點:[https://github.com/feiyangqingyun](https://github.com/feiyangqingyun)

4. 個人主頁:[https://blog.csdn.net/feiyangqingyun](https://blog.csdn.net/feiyangqingyun)

5. 知乎主頁:[https://www.zhihu.com/people/feiyangqingyun/](https://www.zhihu.com/people/feiyangqingyun/)

## 四、效果圖 ## 五、相關程式碼
void MapBaiDu::addRoute(QStringList &list){    if (startAddr.isEmpty() || endAddr.isEmpty()) {        return;    }    //地址中帶了 , 表示採用的經緯度形式    if (startAddr.contains(",")) {        list << QString("  var p1 = new BMap.Point(%1);").arg(startAddr);        list << QString("  var p2 = new BMap.Point(%1);").arg(endAddr);    } else {        list << QString("  var p1 = \"%1\";").arg(startAddr);        list << QString("  var p2 = \"%1\";").arg(endAddr);    }    //0-公交 1-駕車 2-步行 3-騎行    QString renderOptions = QString("{renderOptions:{map:map, panel:\"result\"}, policy:%1}").arg(policyType);    if (routeType == 0) {        list << QString("  var route = new BMap.TransitRoute(map, %1);").arg(renderOptions);    } else if (routeType == 1) {        list << QString("  var route = new BMap.DrivingRoute(map, %1);").arg(renderOptions);    } else if (routeType == 2) {        list << QString("  var route = new BMap.WalkingRoute(map, %1);").arg(renderOptions);    } else if (routeType == 3) {        list << QString("  var route = new BMap.RidingRoute(map, %1);").arg(renderOptions);    }    //獲取路徑的系列點    QStringList temp;    temp << QString("  route.setSearchCompleteCallback(function(results)");    temp << QString("  {");    temp << QString("    if (route.getStatus() == BMAP_STATUS_SUCCESS) {");    //獲取路線結果,可能有多條,預設取第一條一般是最優的    temp << QString("      var routesAll = route.getResults().getPlan(0);");    //獲取線路段數,可能有多段    temp << QString("      var routesCount = routesAll.getNumRoutes(0);");    //temp << QString("      alert(routesCount);");    //獲取所有座標點位的陣列    temp << QString("      var pointsAll = [];");    temp << QString("      for (var i = 0; i < routesCount; i++) {");    temp << QString("        var pts = routesAll.getRoute(i).getPath();");    temp << QString("        var pathsCount = pts.length;");    temp << QString("        var points = [];");    temp << QString("        for (var j = 0; j < pathsCount; j++) {");    temp << QString("          var point = pts[j].lng + ',' + pts[j].lat;");    temp << QString("          points.push(point);");    temp << QString("        }");    temp << QString("        pointsAll.push(points);");    temp << QString("      }");#ifndef webkit    //測試下來發現webkit不支援陣列的資料形式返回    temp << QString("      receiveData('routepoints', pointsAll);");#endif    temp << QString("    }");    temp << QString("  })");    list << temp.join("\r\n");    //查詢路徑    list << QString("  route.search(p1, p2);");}

16
最新評論
  • BSA-TRITC(10mg/ml) TRITC-BSA 牛血清白蛋白改性標記羅丹明
  • 純程式碼寫一個時鐘程式(C語言)