首页
/
每日頭條
/
生活
/
js計算點到直線的距離
js計算點到直線的距離
更新时间:2026-03-10 03:44:55

最近在做有關車輛定位及曆史軌迹的項目,需要顯示車輛當前位置信息、車輛曆史軌迹及行駛公裡數,需要這樣的效果。

js計算點到直線的距離(js根據經緯度換算行駛裡程)1

軌迹回放使用的百度的路書功能,包含了開始、暫定、重置功能,但是後台返回的數據隻包含了坐标點,

js計算點到直線的距離(js根據經緯度換算行駛裡程)2

行駛裡程數需要前台頁面計算。開始查資料,百度提供計算裡程的api,提供開始和結束的幾個坐标點,再選擇是騎車、步行、駕車、是否走高速之類的條件,百度自動計算行車裡程,但是這種誤差相對比較大,于是放棄。換了另一種方案,根據兩個坐标點計算段之間的距離,再累加,這種計算的是實際行駛的裡程,開始coding。

先找到計算兩個坐标點之間距離的方法

// 計算兩個坐标點距離 getFlatternDistance(lon1, lat1, lon2, lat2) { var DEF_PI = 3.14159265359; // PI var DEF_2PI = 6.28318530712; // 2*PI var DEF_PI180 = 0.01745329252; // PI/180.0 var DEF_R = 6370693.5; // radius of earth var ew1, ns1, ew2, ns2; var dx, dy, dew; var distance; // 角度轉換為弧度 ew1 = lon1 * DEF_PI180; ns1 = lat1 * DEF_PI180; ew2 = lon2 * DEF_PI180; ns2 = lat2 * DEF_PI180; // 經度差 dew = ew1 - ew2; // 若跨東經和西經180 度,進行調整 if (dew > DEF_PI) dew = DEF_2PI - dew; else if (dew < -DEF_PI) dew = DEF_2PI dew; dx = DEF_R * Math.cos(ns1) * dew; // 東西方向長度(在緯度圈上的投影長度) dy = DEF_R * (ns1 - ns2); // 南北方向長度(在經度圈上的投影長度) // 勾股定理求斜邊長 distance = Math.sqrt(dx * dx dy * dy).toFixed(0); return distance; }

獲取坐标集合,調用計算公式

// 計算裡程數 calculateMileage(history) { let mileage = 0; for (let i = 0; i < history.length - 1; i ) { mileage = parseInt( this.getFlatternDistance( history[i].longitude, history[i].latitude, history[i 1].longitude, history[i 1].latitude ) ); } this.mileage = mileage == 0 ? "--:--" : (mileage / 1000).toFixed(2) "公裡"; }

mileage就是最後的裡程數。看下計算時間

js計算點到直線的距離(js根據經緯度換算行駛裡程)3

749個坐标點,用時1.39501953125ms,對頁面顯示影響不大。至此結束。

,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
結締組織中的幼稚細胞是白細胞嗎
結締組織中的幼稚細胞是白細胞嗎
外周血單個核細胞(PeripheralBloodMononuclearCells,PBMC)是外周血中具有單個核的細胞的混合群體,是免疫細胞的豐富來源,可以進一步純化分離出單個細胞類型,如天然殺傷細胞(naturalkillercell,N...
2026-03-10
c語言怎麼輸入一些數
c語言怎麼輸入一些數
計算機的輸入設備通常是鍵盤和鼠标,在C語言中,我們可以向計算機輸入一些内容,這些内容可以是數值,也可以是字符串。本例将演示如何通過鍵盤輸入數值,并将這些數值顯示在屏幕上。對于C語言程序來說,如果需要顯示計算機輸入的内容,那麼,首先需要知道這...
2026-03-10
菩提祖師的師兄是誰
菩提祖師的師兄是誰
西遊記裡菩提祖師是孫悟空的師父,實力強大無比,卻一直隐居在方寸山,不問世事。那麼問題來了,菩提祖師的師父是誰呢?為何能教出一位這麼厲害的徒弟來?我們都知道,三界一共有六位聖人,他們的分别是太上老君、元始天尊、通天教主、接引、準提和女娲。這六...
2026-03-10
特别容易崴腳怎麼回事
特别容易崴腳怎麼回事
特别容易崴腳怎麼回事?經常出現崴腳的原因,多數是由于足踝扭傷導緻韌帶松弛或者是踝穴增寬,在活動的時候可能容易出現疼痛,那麼不敢受力就容易出現崴腳,再加上穿一些尖頭皮鞋或者是高跟鞋,走一些不平的路面容易出現這種現象,接下來我們就來聊聊關于特别...
2026-03-10
大魚經典台詞
大魚經典台詞
大魚經典台詞?人們說當你遇上你的摯愛時,時間會暫停真的是這樣但人們沒有告訴你,當時針再度恢複轉動,它會無比飛快,讓人無法趕上,接下來我們就來聊聊關于大魚經典台詞?以下内容大家不妨參考一二希望能幫到您!大魚經典台詞人們說當你遇上你的摯愛時,時...
2026-03-10
Copyright 2023-2026 - www.tftnews.com All Rights Reserved