欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

openlayers?模仿高德箭頭導航路線圖的代碼詳解

 更新時間:2022年05月28日 09:53:12   作者:追風少兒狼  
這篇文章主要介紹了openlayers?模仿高德箭頭導航路線圖的示例代碼,主要包括原始數(shù)據(jù)、起點/終點尋找、起點和終點樣式函數(shù),結(jié)合示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

效果展示

原始數(shù)據(jù)

const routeFeature = {
  type: "Feature",
  geometry: {
    type: "LineString",
    coordinates: [
      [105.9420397836494, 27.911864399055588, 0.0],
      [105.94204506457491, 27.911868653873896, 0.0],
      [105.94203985374624, 27.911863549317346, 0.0],
      [105.9894250218576, 28.057236450358882, 0.0],
      [106.10215274353018, 28.284607012841803, 0.0],
      [106.07371540920602, 28.280436458801173, 0.0],
      [106.07873615012684, 28.28931130115016, 0.0],
      [106.05978977915458, 28.29067898838156, 0.0],
      [106.01532125560543, 28.29250735826644, 0.0],
      [106.11251696408775, 28.335110012326794, 0.0],
      [106.07311049420407, 28.334906534881487, 0.0],
      [106.02507910445651, 28.336362174118438, 0.0],
      [106.02489694766722, 28.359663055160034, 0.0],
      [106.01964893419249, 28.36218521264283, 0.0],
      [106.02051116393352, 28.363011171722473, 0.0],
      [106.02205644084118, 28.363104546940434, 0.0],
      [106.02162537170554, 28.362978005991447, 0.0],
      [106.06032150948916, 28.372102355412082, 0.0],
      [106.04706634723237, 28.410958515915414, 0.0],
      [106.16865262249493, 28.364800431812483, 0.0],
      [106.15259292905644, 28.30510828317908, 0.0],
    ],
  },
};
export{
   routeFeature
}

起點/終點尋找

    const coordinates = routeFeature.geometry.coordinates;
    let start = coordinates[0].slice(0, 2),
     end = coordinates[coordinates.length - 1].slice(0, 2);

起點和終點樣式函數(shù)

function styleFn(text) {
  return new Style({
    image: new Icon({
      src: mark,
      scale: 1,
    }),
    text: new Text({
      textAlign: "center",
      textBaseline: "middle",
      font: "normal 14px 微軟雅黑",
      text,
      fill: new Fill({ color: "#aa3300" }),
      stroke: new Stroke({ color: "#ffcc33", width: 2 }),
      offsetX: 0,
      scale: 1,
      offsetY: 0,
    }),
  });
}

起點和終點layer創(chuàng)建函數(shù)

const Mark = (point, name) => {
  return new VectorLayer({
    style: styleFn(name),
    source: new VectorSource({
      features: [
        new Feature({
          geometryName: "centerMark",
          geometry: new Point(point),
        }),
      ],
    }),
  });
};

路線feature創(chuàng)建

var lineFeature = new GeoJSON({
  geometryName: "line",
}).readFeature(routeFeature.geometry);
const polyLineLayer = new VectorLayer({
  source: new VectorSource({
    features: [lineFeature],
  }),
  style: styleFunction,
});

路線樣式函數(shù)

function styleFunction(featrue, resolution) {
  var geometry = featrue.getGeometry();
  var length = geometry.getLength(); //獲取線段長度
  var radio = (100 * resolution) / length;
  var dradio = 10000;  //投影坐標系,如EPSG3857設(shè)置dradio=1,在EPSG:4326下可以設(shè)置dradio=10000,其他坐標系可以調(diào)整
  var styles = [
    new Style({
      stroke: new Stroke({
        color: "green",
        width: 10,
      }),
    }),
  ];
  for (var i = 0; i <= 1; i += radio) {
    var arrowLocation = geometry.getCoordinateAt(i);
    geometry.forEachSegment(function (start, end) {
      if (start[0] == end[0] || start[1] == end[1]) return;
      var dx1 = end[0] - arrowLocation[0];
      var dy1 = end[1] - arrowLocation[1];
      var dx2 = arrowLocation[0] - start[0];
      var dy2 = arrowLocation[1] - start[1];
      if (dx1 != dx2 && dy1 != dy2) {
        if (Math.abs(dradio * dx1 * dy2 - dradio * dx2 * dy1) < 0.001) {
          var dx = end[0] - start[0];
          var dy = end[1] - start[1];
          var rotation = Math.atan2(dy, dx);
          styles.push(
            new Style({
              geometry: new Point(arrowLocation),
              image: new Icon({
                size: toSize([13, 7]),
                src: arrow,
                anchor: [0.5, 0.5],
                rotateWithView: false,
                rotation: -rotation + (Math.PI * 3) / 2, //旋轉(zhuǎn)角度可能跟圖標角度有關(guān),自行調(diào)整
              }),
            })
          );
        }
      }
    });
  }
  return styles;
}

初始化地圖生成線路圖

export default {
  name: "arrowMap",
  data() {
    return {
      map: null,
    };
  },
  mounted() {

    let map = new Map({
      // 設(shè)置地圖圖層
      layers: [
        gaodeMapLayer,
        polyLineLayer,
        Mark(start, "起點"),
        Mark(end, "終點"),
      ],
      // 設(shè)置顯示地圖的視圖
      view: new View({
        center: start,
        zoom: 10,
        minZoom: 2,
        maxZoom: 18,
        projection: "EPSG:4326",
        rotation: 0,
      }),
      // 讓id為map的div作為地圖的容器
      target: "arrowMap",
    });
  },
};

到此這篇關(guān)于openlayers 模仿高德箭頭導航路線圖的代碼詳解的文章就介紹到這了,更多相關(guān)openlayers 高德導航路線圖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 在IDEA(2020.2)中配置Git及使用Git的圖文詳解

    在IDEA(2020.2)中配置Git及使用Git的圖文詳解

    這篇文章主要介紹了在IDEA(2020.2)中配置Git及使用Git的圖文詳解,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-12-12
  • 程序員用vscode聽網(wǎng)易云的實現(xiàn)

    程序員用vscode聽網(wǎng)易云的實現(xiàn)

    很多程序員在工作的時候都喜歡聽歌,最近發(fā)現(xiàn)了一個vscode插件,可以直接使用vscode進行聽歌,本文就詳細的介紹一下如何使用,感興趣的可以了解一下
    2021-12-12
  • Git安裝詳細圖文教程(Git?安裝過程的每一個步驟)

    Git安裝詳細圖文教程(Git?安裝過程的每一個步驟)

    這篇文章主要介紹了Git安裝詳細圖文教程(Git?安裝過程的每一個步驟),本文以Git-2.35.1.2-64-bit.exe為例給大家講解安裝過程,需要的朋友可以參考下
    2023-02-02
  • Postman 使用指南及小技巧

    Postman 使用指南及小技巧

    Postman 簡化了構(gòu)建 API 的每個步驟,并簡化了協(xié)作,這樣就可以更快地創(chuàng)建 API。接下來通過本文給大家介紹Postman 使用指南及小技巧,感興趣的朋友跟隨小編一起看看吧
    2021-12-12
  • 如何使用VSCode插件Remote-Tunnels連接服務器

    如何使用VSCode插件Remote-Tunnels連接服務器

    本文介紹使用Remote?-?Tunnels連接服務器,該方法需要遠程服務器有流暢的網(wǎng)絡(luò)環(huán)境,它使用微軟的服務來建立隧道,需要登錄GitHub,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-11-11
  • Sublime?Text?4?安裝Package?Control的詳細步驟

    Sublime?Text?4?安裝Package?Control的詳細步驟

    最近換了臺電腦安裝了Sublime?Text?4但是按照之前的方法Package?Control怎么也安裝不上,查閱很多資料多次嘗試發(fā)現(xiàn)Sublime?Text?4可以直接安裝不需要之前那些步驟,下面小編把安裝步驟分享給大家,需要的朋友參考下吧
    2022-01-01
  • WinSCP和PuTTY(與Linux系統(tǒng)鏈接的工具)的安裝和使用圖文教程

    WinSCP和PuTTY(與Linux系統(tǒng)鏈接的工具)的安裝和使用圖文教程

    Putty是用來遠程連接服務器的,支持SSH、Telnet、Serial等協(xié)議的連接,WinSCP是一個Windows環(huán)境下使用SSH的開源圖形化SFTP客戶端,它的主要功能就是在本地與遠程計算機間安全的復制文件,本文重點給大家介紹WinSCP和PuTTY安裝使用,感興趣的朋友一起看看吧
    2022-06-06
  • vscode調(diào)試container中的程序的方法步驟

    vscode調(diào)試container中的程序的方法步驟

    本文主要介紹了vscode調(diào)試container中的程序的方法步驟,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 將Git存儲庫克隆到本地IntelliJ IDEA項目中的詳細教程

    將Git存儲庫克隆到本地IntelliJ IDEA項目中的詳細教程

    這篇文章主要介紹了將Git存儲庫克隆到本地IntelliJ IDEA項目中的詳細教程,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-10-10
  • HTTP請求 GET與POST方法的區(qū)別

    HTTP請求 GET與POST方法的區(qū)別

    HTTP定義了與服務器交互的不同方法,最基本的方法是 GET 和 POST.HTTP-GET和HTTP-POST是使用HTTP的標準協(xié)議動詞,用于編碼和傳送變量名/變量值對參數(shù),并且使用相關(guān)的請求語義。
    2009-12-12

最新評論