<em id="09ttv"></em>
    <sup id="09ttv"><pre id="09ttv"></pre></sup>
    <dd id="09ttv"></dd>

        • 獲取json數據后在 地圖上打點,根據 json不斷移動點的位置

          2018-4-10    seo達人

          如果您想訂閱本博客內容,每天自動發到您的郵箱中, 請點這里

          <?php echo <<<_END <!doctype html>
          <html>
          <head>
              <meta charset="utf-8">
              <meta http-equiv="X-UA-Compatible" content="IE=edge">
              <meta name="viewport" content="initial-scale=1.0, user-scalable=no, width=device-width">
              <title>點標記</title>
              <link rel="stylesheet" />
              <style>
                  .marker {
                      color: #ff6600; padding: 4px 10px;
                      border: 1px solid #fff; white-space: nowrap;
                      font-size: 12px;
                      font-family: "";
                      background-color: #0066ff;  } </style>
              <script src="http://webapi.amap.com/maps?v=1.3&key=您申請的key值"></script>
              <script type="text/javascript" src="http://cache.amap.com/lbs/static/addToolbar.js"></script>
          </head>
          <body>
          <div id="container"></div>
          <script> var marker, map = new AMap.Map("container", {
                  resizeEnable: true, center: [126.60580555556, 45.702363888889], zoom: 13 }); var getJSON = function(url) { return new Promise(function(resolve, reject) { var xhr = new XMLHttpRequest();
                  xhr.open('get', url, true);
                  xhr.responseType = 'json';
                  xhr.onload = function() { var status = xhr.status; if (status == 200) {
                      resolve(xhr.response);
                    } else {
                      reject(status);
                    }
                  };
                  xhr.send();
                });
              };
          
              getJSON('http://web.cellpies.com/api/driving/getVehicleLocationPoints?vehicleDeviceId=0400000000030603&timeType=4&startTime=2017-03-17%2013:00:00&stopTime=2017-03-17%2014:00:00').then(function(jdata) { //alert('Your Json result is:  ' + jdata); //you can comment this, i used it to debug
                  //alert(jdata.data[0].gpsx);
                  //alert(jdata.data[0].gpsy); window.i=0; //addMarker(jdata.data[i].gpsx,jdata.data[i].gpsy); setInterval(function () { addMarker(jdata.data[window.i].gpsx,jdata.data[window.i].gpsy); },"1000");
          
              }, function(status) { //error detection.... alert('Something went wrong.');
              }); // 實例化點標記 function addMarker(v1,v2) {
          
               window.i+=10;
                  marker = new AMap.Marker({
                      icon: "http://webapi.amap.com/theme/v1.3/markers/n/mark_b.png", position: [v1,v2]
                  });
                  marker.setMap(map);
              } </script>
          </body>
          </html>
          
          </script>
          </body>
          </html> _END; ?>

          效果圖

          -----------------------------------------------------------------------更新---------------------------------------------------------

          去掉連續顯示多個點,每次只顯示一個點

          <?php echo<<<_END <!doctype html>
          <html>
          <head>
              <meta charset="utf-8">
              <meta http-equiv="X-UA-Compatible" content="IE=edge">
              <meta name="viewport" content="initial-scale=1.0, user-scalable=no, width=device-width">
              <title>點標記</title>
              <link rel="stylesheet" />
              <style>
                  .marker {
                      color: #ff6600; padding: 4px 10px;
                      border: 1px solid #fff; white-space: nowrap;
                      font-size: 12px;
                      font-family: "";
                      background-color: #0066ff;  } </style>
              <script src="http://webapi.amap.com/maps?v=1.3&key=您申請的key值"></script>
              <script type="text/javascript" src="http://cache.amap.com/lbs/static/addToolbar.js"></script>
          </head>
          <body>
          <div id="container"></div>
          <script> var marker, map = new AMap.Map("container", {
                  resizeEnable: true, center: [126.60580555556, 45.702363888889], zoom: 13 }); var getJSON = function(url) { return new Promise(function(resolve, reject) { var xhr = new XMLHttpRequest();
                  xhr.open('get', url, true);
                  xhr.responseType = 'json';
                  xhr.onload = function() { var status = xhr.status; if (status == 200) {
                      resolve(xhr.response);
                    } else {
                      reject(status);
                    }
                  };
                  xhr.send();
                });
              };
          
              getJSON('http://web.cellpies.com/api/driving/getVehicleLocationPoints?vehicleDeviceId=0400000000030603&timeType=4&startTime=2017-03-17%2013:00:00&stopTime=2017-03-17%2014:00:00').then(function(jdata) {
                  addMarker(jdata.data[0].gpsx,jdata.data[0].gpsy);
                  window.i=1; //updateMarker(jdata.data[1].gpsx,jdata.data[1].gpsy); setInterval(function () { updateMarker(jdata.data[window.i].gpsx,jdata.data[window.i].gpsy); },"1000");
          
              }, function(status) { //error detection.... alert('Something went wrong.');
              }); // 實例化點標記 function addMarker(v1,v2) {
          
                  marker = new AMap.Marker({
                      icon: "http://webapi.amap.com/theme/v1.3/markers/n/mark_b.png", position: [v1,v2]
                  });
                  marker.setMap(map);
              } function updateMarker(v1,v2) { //在地圖上更新標記
                  // 自定義點標記內容 window.i+=10; var markerContent = document.createElement("div"); // 點標記中的圖標 var markerImg = document.createElement("img");
                  markerImg.className = "markerlnglat";
                  markerImg.src = "http://webapi.amap.com/theme/v1.3/markers/n/mark_r.png";
                  markerContent.appendChild(markerImg); // 點標記中的文本 var markerSpan = document.createElement("span");
                  markerSpan.className = 'marker';
                  markerSpan.innerHTML = "Hi,我換新裝備啦!";
                  markerContent.appendChild(markerSpan);
          
                  marker.setContent(markerContent); //更新點標記內容 marker.setPosition([v1,v2]); //更新點標記位置  } </script>
          </body>
          </html>
          
          </script>
          </body>
          </html> _END; ?>

           

          涉及setInterval傳參的問題。

          發現用addMarker(jdata.data[i].gpsx,jdata.data[i].gpsy);時程序可正常運行,但是將該函數 放到setInterval中后卻出現了問題,可通過閉包解決。

          藍藍設計m.sdgs6788.com )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 、平面設計服務

          日歷

          鏈接

          個人資料

          藍藍設計的小編 http://m.sdgs6788.com

          存檔

          麻豆精品久久久一区二区| 色婷婷狠狠久久综合五月| 国产∨亚洲V天堂无码久久久| 亚洲AV日韩精品久久久久| 国产精品视频久久久| 亚洲一级Av无码毛片久久精品| 久久99久久99精品免视看动漫| 久久久精品免费国产四虎| 手机看片久久高清国产日韩| 亚洲AV无码1区2区久久| 精品国产91久久久久久久a| 色婷婷综合久久久久中文| 久久免费99精品国产自在现线 | 中文字幕日本人妻久久久免费| 久久精品视频网| 婷婷久久香蕉五月综合加勒比| 久久久久国产视频电影| 无码精品久久久久久人妻中字| 久久久久亚洲精品无码网址 | 欧美午夜精品久久久久免费视 | 国产偷久久久精品专区| 国产一区二区精品久久岳| jizzjizz国产精品久久| 精品久久久中文字幕人妻| 久久www免费人成精品香蕉| 青青草原综合久久| 好属妞这里只有精品久久| 久久99亚洲网美利坚合众国| 久久夜色精品国产亚洲| 一本色综合久久| 国产精品亚洲综合久久| 久久精品国产男包| 久久久久久久免费视频| 精品久久亚洲中文无码| 久久夜色精品国产网站| 久久亚洲精品成人av无码网站| 久久久久亚洲av成人网人人软件 | 久久av无码专区亚洲av桃花岛| 欧洲精品久久久av无码电影 | 国产人久久人人人人爽| 国产精品视频久久|