电子地图一般可以使用Baidu api等其他的API来制作,优点功能强大,但缺点是需要连接官方服务器,且难以定制自己的内容.

 现制作简单的电子地图,不用依赖其他API,而且方便自己扩展,流程如下:

1选择开发语言as3 

 

2地图投影

 

为了电子地图影像无缝拼接起来,整个地球必须使用一个投影.一般选择墨卡托投影(Mercator projection),下图:

HarmonyOS地图开发 开发一个地图_电子地图

在墨卡托投影下,比例和面积明显扭曲了 (特别是在两极附近的地区).

为了简化计算,我们使用球面投影的形式,而不是椭圆形的形式。由于投影是仅用于地图显示,而不是显示数字坐标,我们不需要额外的椭圆投影的精度。使用球面投影的原因大约有0.33%规模扭曲在Y轴方向,视觉上不明显

                        

 

地面分辨率和地图比例尺

 

除了投影, 渲染地图还需要地面分辨率或地图比例尺。最低水平的缩放级别(1级),地图是512 x 512像素。在每个连续的缩放级别,地图宽度和高度增长的因素2:缩放级别  2级是1024 x 1024像素,三级为2048 x 2048像素,4级是4096 x 4096像素,等等。一般来说,地图的宽度和高度(以像素为单位)可以计算为:

地图宽度=地图高度= 256 * 2水平像素

地面分辨率:地图上一个像素表示的地面距离。例如,在地面分辨率10米/像素,每个像素代表一个地面10米的距离。地面分辨率取决于缩放级别和它的纬度。使用一个地球半径6378137米,地面分辨率(米/像素)可以计算为:

地面分辨率= cos(纬度* pi / 180)*地球周长/地图宽度

=(cos(纬度* pi / 180)* 2 * pi * 6378137米)/(256 * 2水平像素)

地图比例尺:在相同的单位下,地图距离和地面距离之间的比率。例如,地图比例尺为1:100000,地图上的每一英寸代表一个地面100000英寸的距离。类似地面分辨率,地图比例尺取决于纬度和缩放级别,它可以通过地面分辨率计算出来,比如给点每英寸的屏幕分辨率,通常96 dpi:

地图比例尺= 1:地面分辨率*屏幕dpi / 0.0254米/英寸

= 1:(cos(纬度* pi / 180)* 2 * pi * 6378137 *屏幕dpi)/(256 * 2 * 0.0254)

 

下表列出每个缩放级别(在赤道来衡量)。(注意,地面分辨率和地图比例尺也取决于纬度,上述方程所示,但不包括下表所示。)

 

缩放级别

地图宽度和高度(象素)

地面分辨率 (米 / 象素)

地图比例尺(96 dpi)

1

512

78,271.5170

1 : 295,829,355.45

2

1,024

39,135.7585

1 : 147,914,677.73

3

2,048

19,567.8792

1 : 73,957,338.86

4

4,096

9,783.9396

1 : 36,978,669.43

5

8,192

4,891.9698

1 : 18,489,334.72

6

16,384

2,445.9849

1 : 9,244,667.36

7

32,768

1,222.9925

1 : 4,622,333.68

8

65,536

611.4962

1 : 2,311,166.84

9

131,072

305.7481

1 : 1,155,583.42

10

262,144

152.8741

1 : 577,791.71

11

524,288

76.4370

1 : 288,895.85

12

1,048,576

38.2185

1 : 144,447.93

13

2,097,152

19.1093

1 : 72,223.96

14

4,194,304

9.5546

1 : 36,111.98

15

8,388,608

4.7773

1 : 18,055.99

16

16,777,216

2.3887

1 : 9,028.00

17

33,554,432

1.1943

1 : 4,514.00

18

67,108,864

0.5972

1 : 2,257.00

19

134,217,728

0.2986

1 : 1,128.50

20

268,435,456

0.1493

1 : 564.25

21

536,870,912

0.0746

1 : 282.12

22

1,073,741,824

0.0373

1 : 141.06

23

2,147,483,648

0.0187

1 : 70.53

 

像素坐标

已经在每个缩放级别的细节有了投影和比例尺,我们可以将地理坐标转换成像素坐标。由于地图宽度和高度是在不同的缩放级别,像素坐标也是如此。像素在地图的左上角像素坐标总是 (0,0)。像素在地图右下角的像素坐标是(width-1 height-1),或在前面的小节方程(256 * 2level–1, 256 * 2level–1)。例如,在3级,像素坐标范围从(0,0)到(2047、2047),如下:

 

HarmonyOS地图开发 开发一个地图_缩放_02

有了经度,纬度和缩放级别,像素XY坐标可以如下计算:

sinLatitude = sin(latitude * pi/180)

pixelX = ((longitude + 180) / 360) * 256 * 2 level

pixelY = (0.5 – log((1 + sinLatitude) / (1 – sinLatitude)) / (4 * pi)) * 256 * 2 level

纬度和经度使用WGS 84坐标系。虽然地图使用球面投影,重要的是将所有的地理坐标转换成一个共同的坐标系,都转成WGS 84坐标系。假设经度范围从-180 到 180度,纬度范围必须裁剪,从-85.05112878到85.05112878。 这避免了在两极出现异常,使投影地图为矩形。

 

Tile坐标和Quadkeys

为优化地图的检索和显示性能,地图每Tile被分割成256 x 256像素的块。像素的数量在每个缩放级别下都不同,瓷砖的数量:

地图宽度=地图高度= 2 level tiles

每个Tile的XY坐标系范围从左上角(0,0),到右下角(2level–1, 2level–1)。例如,在第三级的Tile坐标范围从(0,0)到(7,7)如下:

 

HarmonyOS地图开发 开发一个地图_缩放_03

给出一对像素XY坐标,可以很容易地确定TileY坐标:

tileX = floor(pixelX / 256)

tileY = floor(pixelY / 256)

为了优化Tiles的索引和存储, 组合二维TileXY坐标系进入一维的字符串被称为四叉树Key,或简称为“quadkeys”。在每个缩放级别,每个quadkey唯一标识一个tile。给定一个在缩放级别为3级的TileXY坐标系(3,5),quadkey确定如下:

tileX = 3 = 011 2

tileY = 5 = 101 2

quadkey = 100111 2 = 213 4 = " 213 "

 

 

HarmonyOS地图开发 开发一个地图_电子地图_04

3,下载地图数据

测试数据可从google地图下载。

 
4、显示结果如下

HarmonyOS地图开发 开发一个地图_缩放_05

5,应用显示GPS坐标

导入地名坐标数据入库,建webservice,查询结果如下

 

 

HarmonyOS地图开发 开发一个地图_API_06

 

6,应用,地形图划分,浏览。

 

HarmonyOS地图开发 开发一个地图_API_07