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

使用GPS經(jīng)緯度定位附近地點(某一點范圍內(nèi)查詢)

 更新時間:2013年12月30日 09:49:19   作者:  
目前的工作是需要手機查找附近N米以內(nèi)的商戶,致想法是已知一個中心點,一個半徑,求圓包含于圓拋物線里所有的點,經(jīng)緯度是一個點,半徑是一個距離,不能直接加減,下面提供C#的解決方法

數(shù)據(jù)庫中記錄了商家在百度標注的經(jīng)緯度(如:116.412007, 39.947545)

最初想法,以圓心點為中心點,對半徑做循環(huán),半徑每增加一個像素(暫定1米)再對周長做循環(huán),到數(shù)據(jù)庫中查詢對應點的商家(真是一個長時間的循環(huán)工作),上網(wǎng)百度類似的文章有了點眉目

大致想法是已知一個中心點,一個半徑,求圓包含于圓拋物線里所有的點,這樣的話就需要知道所要求的這個圓的對角線的頂點,問題來了 經(jīng)緯度是一個點,半徑是一個距離,不能直接加減

復制代碼 代碼如下:

/// <summary>
    /// 經(jīng)緯度坐標
    /// </summary>   

  public class Degree
    {
        public Degree(double x, double y)
        {
            X = x;
            Y = y;
        }
        private double x;

        public double X
        {
            get { return x; }
            set { x = value; }
        }
        private double y;

        public double Y
        {
            get { return y; }
            set { y = value; }
        }
    }


    public class CoordDispose
    {
        private const double EARTH_RADIUS = 6378137.0;//地球半徑(米)

        /// <summary>
        /// 角度數(shù)轉(zhuǎn)換為弧度公式
        /// </summary>
        /// <param name="d"></param>
        /// <returns></returns>
        private static double radians(double d)
        {
            return d * Math.PI / 180.0;
        }

        /// <summary>
        /// 弧度轉(zhuǎn)換為角度數(shù)公式
        /// </summary>
        /// <param name="d"></param>
        /// <returns></returns>
        private static double degrees(double d)
        {
            return d * (180 / Math.PI);
        }

        /// <summary>
        /// 計算兩個經(jīng)緯度之間的直接距離
        /// </summary>

        public static double GetDistance(Degree Degree1, Degree Degree2)
        {
            double radLat1 = radians(Degree1.X);
            double radLat2 = radians(Degree2.X);
            double a = radLat1 - radLat2;
            double b = radians(Degree1.Y) - radians(Degree2.Y);

            double s = 2 * Math.Asin(Math.Sqrt(Math.Pow(Math.Sin(a / 2), 2) +
             Math.Cos(radLat1) * Math.Cos(radLat2) * Math.Pow(Math.Sin(b / 2), 2)));
            s = s * EARTH_RADIUS;
            s = Math.Round(s * 10000) / 10000;
            return s;
        }

        /// <summary>
        /// 計算兩個經(jīng)緯度之間的直接距離(google 算法)
        /// </summary>
        public static double GetDistanceGoogle(Degree Degree1, Degree Degree2)
        {
            double radLat1 = radians(Degree1.X);
            double radLng1 = radians(Degree1.Y);
            double radLat2 = radians(Degree2.X);
            double radLng2 = radians(Degree2.Y);

            double s = Math.Acos(Math.Cos(radLat1) * Math.Cos(radLat2) * Math.Cos(radLng1 - radLng2) + Math.Sin(radLat1) * Math.Sin(radLat2));
            s = s * EARTH_RADIUS;
            s = Math.Round(s * 10000) / 10000;
            return s;
        }

        /// <summary>
        /// 以一個經(jīng)緯度為中心計算出四個頂點
        /// </summary>
        /// <param name="distance">半徑(米)</param>
        /// <returns></returns>
        public static Degree[] GetDegreeCoordinates(Degree Degree1, double distance)
        {
            double dlng = 2 * Math.Asin(Math.Sin(distance / (2 * EARTH_RADIUS)) / Math.Cos(Degree1.X));
            dlng = degrees(dlng);//一定轉(zhuǎn)換成角度數(shù)  原PHP文章這個地方說的不清楚根本不正確 后來lz又查了很多資料終于搞定了

            double dlat = distance / EARTH_RADIUS;
            dlat = degrees(dlat);//一定轉(zhuǎn)換成角度數(shù)

            return new Degree[] { new Degree(Math.Round(Degree1.X + dlat,6), Math.Round(Degree1.Y - dlng,6)),//left-top
                                  new Degree(Math.Round(Degree1.X - dlat,6), Math.Round(Degree1.Y - dlng,6)),//left-bottom
                                  new Degree(Math.Round(Degree1.X + dlat,6), Math.Round(Degree1.Y + dlng,6)),//right-top
                                  new Degree(Math.Round(Degree1.X - dlat,6), Math.Round(Degree1.Y + dlng,6)) //right-bottom
            };

        }
    }

測試方法:

復制代碼 代碼如下:

static void Main(string[] args)
        {
            double a = CoordDispose.GetDistance(new Degree(116.412007, 39.947545), new Degree(116.412924, 39.947918));//116.416984,39.944959
            double b = CoordDispose.GetDistanceGoogle(new Degree(116.412007, 39.947545), new Degree(116.412924, 39.947918));
            Degree[] dd = CoordDispose.GetDegreeCoordinates(new Degree(116.412007, 39.947545), 102);
            Console.WriteLine(a+" "+b);
            Console.WriteLine(dd[0].X + "," + dd[0].Y );
            Console.WriteLine(dd[3].X + "," + dd[3].Y);
            Console.ReadLine();
        }

試了很多次 誤差在1米左右

拿到圓的頂點就好辦了

數(shù)據(jù)庫要是sql 2008的可以直接進行空間索引經(jīng)緯度字段,這樣應該性能更好(沒有試過)

lz公司數(shù)據(jù)庫還老 2005的 這也沒關(guān)系,關(guān)鍵是經(jīng)緯度拆分計算,這個就不用說了 網(wǎng)上多的是 最后上個實現(xiàn)的sql語句

復制代碼 代碼如下:

SELECT id,zuobiao FROM dbo.zuobiao WHERE zuobiao<>'' AND
dbo.Get_StrArrayStrOfIndex(zuobiao,',',1)>116.41021 AND
dbo.Get_StrArrayStrOfIndex(zuobiao,',',1)<116.413804 AND
dbo.Get_StrArrayStrOfIndex(zuobiao,',',2)<39.949369 AND
dbo.Get_StrArrayStrOfIndex(zuobiao,',',2)>39.945721

相關(guān)文章

  • C#使用OpenCvSharp實現(xiàn)透視變換功能

    C#使用OpenCvSharp實現(xiàn)透視變換功能

    這篇文章主要為大家詳細介紹了C#如何使用OpenCvSharp實現(xiàn)透視變換的功能,文中的示例代碼簡潔易懂,具有一定的學習價值,需要的小伙伴可以參考下
    2023-11-11
  • C#用Topshelf創(chuàng)建Windows服務的步驟分享

    C#用Topshelf創(chuàng)建Windows服務的步驟分享

    這篇文章主要給大家介紹了關(guān)于C#如何利用Topshelf創(chuàng)建Windows服務的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用C#具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2020-05-05
  • C#中改變DataGridView控件邊框顏色的方法

    C#中改變DataGridView控件邊框顏色的方法

    這篇文章主要介紹了C#中改變DataGridView控件邊框顏色的方法,默認的DataGridView邊框顏色很丑,本文用編程方法實現(xiàn)修改DataGridView邊框顏色,需要的朋友可以參考下
    2014-08-08
  • C#操作XML文件實例匯總

    C#操作XML文件實例匯總

    這篇文章主要介紹了C#操作xml文件實例,包括了對XML文件節(jié)點的查找、遍歷、刪除、添加等。是C#程序設計中非常重要的技巧,需要的朋友可以參考下
    2014-08-08
  • C#圖像偽彩色處理方法

    C#圖像偽彩色處理方法

    這篇文章主要介紹了C#圖像偽彩色處理方法,涉及C#操作圖像的偽彩色相關(guān)技巧,需要的朋友可以參考下
    2015-04-04
  • C# HttpClient 如何使用 Consul 發(fā)現(xiàn)服務

    C# HttpClient 如何使用 Consul 發(fā)現(xiàn)服務

    這篇文章主要介紹了C# HttpClient 如何使用 Consul 發(fā)現(xiàn)服務,幫助大家更好的理解和使用c#,感興趣的朋友可以了解下
    2021-02-02
  • 詳解C#使用AD(Active Directory)驗證內(nèi)網(wǎng)用戶名密碼

    詳解C#使用AD(Active Directory)驗證內(nèi)網(wǎng)用戶名密碼

    這篇文章主要介紹了詳解C#使用AD(Active Directory)驗證內(nèi)網(wǎng)用戶名密碼的相關(guān)資料,希望通過本文能幫助到大家,讓大家實現(xiàn)這樣的功能,需要的朋友可以參考下
    2017-10-10
  • C#實現(xiàn)HTTP上傳文件的方法

    C#實現(xiàn)HTTP上傳文件的方法

    這篇文章主要介紹了C#實現(xiàn)HTTP上傳文件的方法,包括了發(fā)送文件與接收文件的實現(xiàn)代碼,具有不錯的參考價值,需要的朋友可以參考下
    2014-11-11
  • C#使用String和StringBuilder運行速度測試及各自常用方法簡介

    C#使用String和StringBuilder運行速度測試及各自常用方法簡介

    今天小編就為大家分享一篇關(guān)于C#使用String和StringBuilder運行速度測試及各自常用方法簡介,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-10-10
  • C#中使用Microsoft Unity記錄日志

    C#中使用Microsoft Unity記錄日志

    這篇文章介紹了C#中使用Microsoft Unity記錄日志的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-08-08

最新評論