当前位置: 首页 > news >正文

千海网站建设 小程序网站续费管理系统

千海网站建设 小程序,网站续费管理系统,没有空间可以做网站吗,wordpress内网访问现在的应用大都居于LBS服务#xff0c;用户地理位置的获取#xff08;经纬度坐标、所属行政区域#xff09;#xff0c;提供服务场所的地理位置也有行政区域信息和坐标信息。 用户与服务场所的联系#xff0c;就近服务原则的设计#xff0c;服务场所相对于用户的排序。 …现在的应用大都居于LBS服务用户地理位置的获取经纬度坐标、所属行政区域提供服务场所的地理位置也有行政区域信息和坐标信息。 用户与服务场所的联系就近服务原则的设计服务场所相对于用户的排序。 一个简单的案例的设计 根据用户定位获取服务场所按距离排序。 用户端提供信息居于经纬度的坐标信息例如纬度23.03057,经度113.75213区域信息省市区 服务场所信息经纬度区域信息 相关概念 目前国内主要有以下三种坐标系 WGS84为一种大地坐标系也是目前广泛使用的GPS全球卫星定位系统使用的坐标系。 GCJ02又称火星坐标系是由中国国家测绘局制订的地理信息系统的坐标系统。由WGS84坐标系经加密后的坐标系。 BD09为百度坐标系在GCJ02坐标系基础上再次加密。其中bd09ll表示百度经纬度坐标bd09mc表示百度墨卡托米制坐标。 非中国地区地图服务坐标统一使用WGS84坐标。 *这里我们先不考虑个坐标系的差异按统一的公式计算。 地理知识和相关三角函数计算 地球是一个近似于圆形的球体半径6378137米。在地球经线上1纬度为111km左右在地球纬线上1经度为111cosαα表示该纬线的纬度.在不同纬线上,经度每差1度的实际距离是不相等的。 计算2个经纬度的距离 坐标点A点23.03057,113.75213  B点23.03102,113.75212 计算2点的距离米 1、sql SELECT CAST(6378137.0 * ACOS(SIN(23.03057 / 180 * PI())* SIN(CAST(23.03102000 AS DECIMAL(18, 8)) / 180* PI()) COS(23.03057 / 180 * PI())* COS(CAST(23.03102000 AS DECIMAL(18, 8)) / 180* PI()) * COS(( 113.75213- CAST(113.75212000 AS DECIMAL(18,8)) ) / 180* PI())) AS INT) AS Distance 2、C#  public static double EARTH_RADIUS 6378137d;/// summary/// 计算两点位置的距离返回两点的距离单位公里或千米/// 该公式为GOOGLE提供误差小于0.2米/// var dis Utils.PointUtil.GetDistance(23.03057, 113.75213, 23.03102000, 113.75212000);/// /summary/// param namelat1第一点纬度/param/// param namelng1第一点经度/param/// param namelat2第二点纬度/param/// param namelng2第二点经度/param/// returns返回两点的距离单位公里或千米/returnspublic static double GetDistance(double lat1, double lng1, double lat2, double lng2){//地球半径单位米double radLat1 Rad(lat1);double radLng1 Rad(lng1);double radLat2 Rad(lat2);double radLng2 Rad(lng2);double a radLat1 - radLat2;double b radLng1 - radLng2;double result 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))) * EARTH_RADIUS;return result / 1000;}/// summary/// 经纬度转化成弧度/// /summary/// param named/param/// returns/returnsprivate static double Rad(double d){return (double)d * Math.PI / 180d;} 3、JavaScript //计算2个坐标点的距离返回千米function GetDistance(lat1, lng1, lat2, lng2){var radLat1 lat1 * Math.PI / 180.0;var radLat2 lat2 * Math.PI / 180.0;var a radLat1 - radLat2;var b lng1 * Math.PI / 180.0 - lng2 * Math.PI / 180.0;var 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 * 6378.137;// EARTH_RADIUS;s Math.round(s * 10000) / 10000;return s;}// 调用 return的距离单位为km//GetDistance(23.03057,113.75213,23.03102000,113.75212000) 扩展 大量频繁的计算消耗过多的服务器资源。特别在数据库比如计算10W条数据再按距离排序这性能可想而知。那问题来了如何优化呢 技术上加服务器加缓存前端分摊计算 业务上添加条件嘛缩写范围比如添加地区条件 有一种情况获取距离用户10公里范围内的服务场所。 sql 可能这样写 SELECT *FROM ( SELECT ID ,Store ,CAST(6378137.0 * ACOS(SIN(lat / 180 * PI())* SIN(CAST([Latitude] AS DECIMAL(18,8)) / 180 * PI()) COS(lat / 180 * PI())* COS(CAST([Latitude] AS DECIMAL(18,8)) / 180 * PI())* COS(( lng- CAST([Longitude] AS DECIMAL(18,8)) ) / 180* PI())) AS INT) AS DistanceFROM Store WITH ( NOLOCK )) TWHERE T.Distance 10 * 1000ORDER BY Distance ASC 这样不就计算了全部记录行后再排序嘛既然已经限定了10公里范围想想如果可以得到中心点用户坐标10公里范围的最大、最小坐标不就能作为筛选条件了吗。 在平面中以用户坐标位原点根据距离取得四个顶点的坐标。 获取最大、最小经纬度坐标值 1、JavaScript //经度、纬度、多少米 内的最大最小坐标点function FindMaxMinPoint(longitude, latitude, distance){var r 6378137; //地球半径米var dis distance; //米 var dlng 2 * Math.asin(Math.sin(dis / (2 * r)) / Math.cos(latitude * Math.PI / 180));dlng dlng * 180 / Math.PI;//角度转为弧度var dlat dis / r;dlat dlat * 180 / Math.PI;//角度转为弧度var minlat latitude - dlat;var maxlat latitude dlat;var minlng longitude - dlng;var maxlng longitude dlng;console.log(minlat);console.log(maxlat);console.log(minlng);console.log(maxlng);}FindMaxMinPoint(113.75213, 23.03057, 10*1000); 2、C# /// summary/// 获取坐标点多少米内最大、最小坐标值/// /summary/// param namelongitude/param/// param namelatitude/param/// param namedistance多少米/param/// returns/returnspublic static dynamic FindMaxMinPoint(double longitude, double latitude, double distance){//先计算查询点的经纬度范围 double r 6378137;//地球半径米 double dis distance;//米距离 double dlng 2 * Math.Asin(Math.Sin(dis / (2 * r)) / Math.Cos(latitude * Math.PI / 180));dlng dlng * 180 / Math.PI;//角度转为弧度 double dlat dis / r;dlat dlat * 180 / Math.PI;//角度转为弧度 double minlat latitude - dlat;double maxlat latitude dlat;double minlng longitude - dlng;double maxlng longitude dlng;return new{MinLat minlat,MaxLat maxlat,MinLng minlng,MaxLng maxlng};} 得到这四个值后就可以在sql中添加条件了 WHERE [Latitude] BETWEEN minLatitude AND maxLatitude AND [Longitude] BETWEEN minLongitude AND maxLongitude 配合索引将大大提升效率。 LBS的服务场景随处可见对应小型的应用基于有限的资源这种优化设计很大作用。
http://www.pierceye.com/news/43579/

相关文章:

  • 3yx这个网站做刷单安徽城乡与建设部网站
  • 做手机网站要注意进销存软件排行榜前十名
  • 湖北网站推广策略网站开发实训报告
  • 企业网站建设系统彩票网站开发彩票网站搭建
  • 如何制作产品网站模板下载国内wordpress主题商
  • 如何申请深圳设计公司网站电商平台如何推广运营
  • 网站空间 支持什么程序支付宝手机网站支付
  • 视频付费网站建设网页设计基础的课程介绍
  • 广州模板建站哪家好手机网站管理系统
  • 网站是怎么做出来的网页制作图片显示不出来
  • 凡科建站官网电脑版wordpress huancun
  • 网站建设合作协议文本android应用开发框架
  • 郑州外贸网站建设公司排名中国人做外贸生意的网站
  • 网站突然打不开是什么原因分类信息网站怎么做流量
  • 博物馆网站做的最好的浏览器在线打开
  • 如何通过html做网站怎么做黑彩黑彩网站
  • 学网站建设要多久百度提交网站地图
  • 攸县网站定制建设网站赚钱
  • 做网站有软件吗网页和站点的区别
  • 东莞网站建设制作价格网站建设员工技能要求
  • 本地网站源码广州网络营销服务公司
  • 企业网站推广费用网络规划设计师考试通过率
  • 南宁网站建设找哪家公司视频 主题 wordpress
  • 百度网站排名seo西双版纳注册公司流程和费用
  • 肇庆做网站建设网站seo运营
  • 2015百度推广网站遭到攻击怎么增加网站的权重
  • 网站建设 温州aws安装wordpress
  • 手机网站建设价钱是多少重庆市工程安全建设信息网官网
  • 营销网站定位西安网站制作首页
  • 怎么搭建自己的网站后台平面设计作品欣赏