国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識(shí)百科 - 正文

EF保存平面數(shù)據(jù)到SqlServer

來源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-09 07:38:47
文檔

EF保存平面數(shù)據(jù)到SqlServer

EF保存平面數(shù)據(jù)到SqlServer:前言 公司開展一個(gè)項(xiàng)目,需要根據(jù)客戶手機(jī)定位獲取周圍內(nèi)的精準(zhǔn)廣告,具體是管理員在地圖上繪制多邊形的廣告范圍,落在范圍內(nèi)的客戶就看到此廣告。下面將我的實(shí)現(xiàn)方法簡單敘述一下,以供有相同需求的朋友參考。 EF平面對(duì)象DbGeometry DbGeometry可以表
推薦度:
導(dǎo)讀EF保存平面數(shù)據(jù)到SqlServer:前言 公司開展一個(gè)項(xiàng)目,需要根據(jù)客戶手機(jī)定位獲取周圍內(nèi)的精準(zhǔn)廣告,具體是管理員在地圖上繪制多邊形的廣告范圍,落在范圍內(nèi)的客戶就看到此廣告。下面將我的實(shí)現(xiàn)方法簡單敘述一下,以供有相同需求的朋友參考。 EF平面對(duì)象DbGeometry DbGeometry可以表

前言 公司開展一個(gè)項(xiàng)目,需要根據(jù)客戶手機(jī)定位獲取周圍內(nèi)的精準(zhǔn)廣告,具體是管理員在地圖上繪制多邊形的廣告范圍,落在范圍內(nèi)的客戶就看到此廣告。下面將我的實(shí)現(xiàn)方法簡單敘述一下,以供有相同需求的朋友參考。 EF平面對(duì)象DbGeometry DbGeometry可以表示點(diǎn)、

前言

公司開展一個(gè)項(xiàng)目,需要根據(jù)客戶手機(jī)定位獲取周圍內(nèi)的精準(zhǔn)廣告,具體是管理員在地圖上繪制多邊形的廣告范圍,落在范圍內(nèi)的客戶就看到此廣告。下面將我的實(shí)現(xiàn)方法簡單敘述一下,以供有相同需求的朋友參考。

EF平面對(duì)象DbGeometry

DbGeometry可以表示點(diǎn)、線、多邊形等平面對(duì)象,輸入對(duì)象可以是WKT(Well-known text),我們可以把百度地圖上的polygon對(duì)象的點(diǎn)轉(zhuǎn)換為多邊形的wkt描述,再轉(zhuǎn)為DbGeometry進(jìn)行保存。

 /// 
 /// 從多點(diǎn)數(shù)據(jù)生成多邊形
 /// 
 /// 百度地圖多邊形的點(diǎn)集
 public static DbGeometry PolygonFromPointsJson(string pointsJson)
 {
 var points = JsonSerializer.ToEntity>(pointsJson);
 if (points.First().GetHashCode() != points.Last().GetHashCode())
 {
 points.Add(points.First());
 }

 var closePoints = ((IEnumerable)points).Select(item => string.Format("{0} {1}", item.Lng, item.Lat));
 var wkt = "POLYGON((" + string.Join(",", closePoints) + "))";
 return DbGeometry.PolygonFromText(wkt, SYSTEM_ID);
 }

View Code

廣告實(shí)體里用DbGeometry類型記錄多邊形范圍

 /// 
 /// 廣告范圍表
 /// 
 [Serializable]
 public class AdvRange : Entity
 {
 /// 
 /// 廣告范圍名
 /// 
 [Required]
 [Length(20)]
 public string Name { get; set; }

 /// 
 /// 所屬城市標(biāo)識(shí)ID
 /// 
 public Guid CityId { get; set; }

 /// 
 /// 多邊形
 ///  
 public DbGeometry Polygon { get; set; }
 }

View Code

從DbGeometry對(duì)象獲取多邊形的點(diǎn)

DbGeometry對(duì)象的WellKnownValue屬性的可以獲取WKT文本,目前我沒有找到相關(guān)工具轉(zhuǎn)WKT轉(zhuǎn)為Json,所以用正則表達(dá)式獲取也能滿足需要,然后將結(jié)果轉(zhuǎn)換為json就可以放到地圖上進(jìn)行展示了。

 /// 
 /// 獲取多邊形的點(diǎn)
 /// 
 /// 
 public static List GetPolygonPoints(this DbGeometry geometry)
 {
 var list = new List();
 var points = geometry.WellKnownValue.WellKnownText.Matches(@"-?[1-9]\d*\.\d*|-?0\.\d*[1-9]\d*").Select(item => decimal.Parse(item)).ToArray();
 for (var i = 0; i < points.Length; i = i + 2)
 {
 list.Add(new LngLat { Lng = points[i], Lat = points[i + 1] });
 }
 if (list.First().GetHashCode() == list.Last().GetHashCode())
 {
 list.RemoveAt(list.Count - 1);
 }
 return list;
 }

View Code


廣告范圍是否包含客戶位置的點(diǎn)

DbGeometry有很多方法和屬性,EF可以將其翻譯到對(duì)應(yīng)的sql語句,其中Polygon.Intersects(point)可以判斷點(diǎn)是否在多邊形內(nèi)。

效果圖(中心的紅標(biāo)注為多邊形的重心)

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

EF保存平面數(shù)據(jù)到SqlServer

EF保存平面數(shù)據(jù)到SqlServer:前言 公司開展一個(gè)項(xiàng)目,需要根據(jù)客戶手機(jī)定位獲取周圍內(nèi)的精準(zhǔn)廣告,具體是管理員在地圖上繪制多邊形的廣告范圍,落在范圍內(nèi)的客戶就看到此廣告。下面將我的實(shí)現(xiàn)方法簡單敘述一下,以供有相同需求的朋友參考。 EF平面對(duì)象DbGeometry DbGeometry可以表
推薦度:
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 国产日韩欧美 | 日本a级精品一区二区三区 日本不卡视频一区二区三区 | 三级中文字幕电影大全 | 色综合色狠狠天天综合色 | 另类欧美日韩 | 熟年中出交尾六十路七十路 | 在线免费观看亚洲视频 | 国产va在线视频观看 | 久久久久亚洲精品美女 | 日韩欧美区 | 久久国产精品一区二区 | 国产香蕉视频在线 | 亚洲全黄 | 国产精品视频免费观看 | 99精品久久99久久久久 | 欧美系列在线 | 国产在线视频一区二区三区 | 在线免费国产 | 欧美日韩视频一区二区在线观看 | 日韩在线综合 | 最新国产在线视频 | 欧美中出 | 亚洲伊人久久综合一区二区 | 国产色在线 | 欧美精品在线视频观看 | 国产99精品视频 | 最新国产在线视频 | 在线视频一区二区 | 欧美 第一页 | 久久精品国产亚洲 | 国产日韩在线播放 | 国产麻豆流白浆在线观看 | 亚洲一区二区三区久久精品 | 国产精品1区2区3区在线播放 | 日韩不卡一区二区三区 | 在线日韩欧美一区二区三区 | 国产一二三区视频 | www国产精品| 欧美日本韩国一区二区 | 91精品久久久久 | 亚洲欧美在线视频 |