两个经纬度之间的距离

admin2年前Laravel686


    public function haversineGreatCircleDistance($latitude1, $longitude1, $latitude2, $longitude2)

    {

        

       

         

        // 地球半径(单位:米)

        $earthRadius = 6371009;

        // 将角度转换为弧度

        $latitude1 = deg2rad($latitude1);

        $latitude2 = deg2rad($latitude2);

        $longitude1 = deg2rad($longitude1);

        $longitude2 = deg2rad($longitude2);

        // 计算经纬度差值

        $latitudeDelta = $latitude2 - $latitude1;

        $longitudeDelta = $longitude2 - $longitude1;

        // 计算Fn

        $y = sin($latitudeDelta / 2) ** 2 + cos($latitude1) * cos($latitude2) * sin($longitudeDelta / 2) ** 2;

        $distance = 2 * atan2(sqrt($y), sqrt(1 - $y)) * $earthRadius;

        $distance = substr($distance,0,8);

      

        $distance = bcdiv($distance, 1000, 2);

        return $distance;

    }


返回列表

上一篇:过滤违禁词

下一篇:手机号替换

相关文章

下载文件

public function img_url() { $id = request()->param('id', 1122); $info = Db::name('...

压缩图片

public static function size($id, $img) { try { list($width, $height, $img_type, $attr) = @getimages...

微信支付V3

 public static function pay($order_sn = '11111', $money = '12', $uid = 7) ...

关注公众号并登录

/* * 服务端生成带唯一标识二维码并将唯一标识返回给前端 */ public function wx_code() { $scene_str = $this->get_...

php 优化

使用 gc_collect_cycles() 强制进行垃圾回收 PHP 的垃圾回收机制会自动释放不再使用的变量所占用的内存。然而,在某些情况下,尤其是在长时间运行的脚本(如 CLI...

微信开放平台-扫码登录

public function wx_info(){    $code = request()->input('code');    if...