zoukankan      html  css  js  c++  java
  • Mapbar的基本算法

    mapbar的地图,在地标标注上是有优势的

    Mapbar基本算法

    因为我当初是用在PHP下的,所以用了php表示算法,基本差不多,应该看得懂:

    基础网址:"http://img.mapbar.com/maplite/mapbank/baidu/"

    每层地图切片存放在文件夹名称:

    $levelstr=array("W","0","1","2","3","4","5","6","7","8","9","10","11","12","15");

    即第0层地图切片放在"http://img.mapbar.com/maplite/mapbank/baidu/W/" 下

    每层地图切片所跨的经度数(纬度跨度需要*0.8这个系数):

    $clipnum=array(90,40,20,10,5,2,1,0.5,0.2,0.1,0.05,0.02,0.01,0.005,0.002);

    如第1层的每切片跨经度是90度,跨纬度是90*0.8=72度。即如经度-180~180,共360度,东西半球各需要180/90=2块切片,mapbar的每切片像素为300x300,所以完整地图长度像素应是300*4=1200像素。纬度是-90~90,共180度,南北半球各需要90/72=1.25,需要取大于此数的最小整数即2,所以南北半球加起来仍需要4块,而不是180/72=2.5取整后的3块。从中间0度赤道向两边平铺的,因此上下两块各有3/4块区域留有空白。

    哈哈,有点缺乏耐心啦,将就着结合一小段程序来理解吧

    //每层的最大横向像素数(除以2得到是纵向最大像素)

    function MaxPixel($zoom){

            return 256*pow(2,$zoom+2);

    }

    //经度换算

    function PixelToLng($x,$zoom){

            $c= MaxPixel($zoom);

            return ($x - $c / 2) / ($c / 360);

    }

    function LngToPixel($lng,$zoom){

            $c= MaxPixel($zoom);

            return (int)($c / 2 + $lng * $c / 360 + 0.5);

    }

    //纬度换算

    function PixelToLat($y,$zoom){

            $c= MaxPixel($zoom);

            $g = ($y - $c / 2) / (-$c / (2 * M_PI));

            return (2 * Atan(Exp($g)) - M_PI / 2) / (M_PI / 180);

    }

    function LatToPixel($lat,$zoom){

            $c= MaxPixel($zoom);

            $f = Sin($lat * (M_PI / 180));

            return (int)($c / 2 + 0.5 * Log((1 + $f) / (1 - $f)) * -$c / (2 * M_PI) + 0.5);

    }

    $blocksize=array(10,10,10,10,10,10,10,10,10,10,50,50,50,50,50);

    //$para['ClipXNo']是横向切片序号,注意这个序号不是从0开始的

    //横向切片序号运算公式,已知经度是$para['x1']计算所在切片序号:$para['ClipXNo']=floor($para['x1']/$clipnum[$level]);

    //纵向切片序号运算公司,已知纬度是$para['y1']计算所在切片序号:$para['ClipYNo']=floor($para['y1']/($clipnum[$level]*0.8));

    //所以倒如第一层第一块切片(经纬度分别为-180,90所在的切片)的序号是

    $para['ClipXNo']=floor(-180/90)=-2;$para['ClipYNo']=floor(90/72)=2;

    $para['FolderXNo']=(int)floor($para['ClipXNo']/$blocksize[$level]);//切片分文件夹存放位置

    $para['FolderYNo']=(int)floor($para['ClipYNo']/$blocksize[$level]);

    if($para['FolderXNo']<0){

            $para['FolderXNo']++;

    }

    if($para['FolderYNo']<0){

            $para['FolderYNo']++;

    }

    //计算文件序号

    $para['FileXNo']=$para['ClipXNo']-$para['FolderXNo']*$blocksize[$level];

    $para['FileYNo']=$para['ClipYNo']-$para['FolderYNo']*$blocksize[$level];

    //计算出完整切片位置

    $para['url']=

    "http://img.mapbar.com/maplite/mapbank/baidu/"

    .$levelstr[$level]."/".$para['FolderXNo']."_".$para['FolderYNo'].

    "/".$para['FileXNo']."_".$para['FileYNo'].".png";

  • 相关阅读:
    json web token 入门
    Mysql查询表注释和字段注释信息
    Nginx核心知识100讲学习笔记(陶辉):目录
    Kubernetes进阶实战读书笔记:网络存储
    Kubernetes进阶实战读书笔记:持久化存储卷(pv详解)
    Kubernetes进阶实战读书笔记:存储卷概述
    sybase
    Delphi 解决StrToDateTime()不是有效日期类型的问题
    delphi TStringList 用法详解
    看看Delphi中的列表(List)和泛型
  • 原文地址:https://www.cnblogs.com/liongis/p/1761245.html
Copyright © 2011-2022 走看看