二次封装创建地图方法


前言

二次封装创建地图方法


一、创建步骤

1.引入库

import Map from 'ol/Map';
import View from 'ol/View';
import { transform} from 'ol/proj';
import * as olControl from 'ol/control';

2.封装创建地图方法(ol-map.js)

/**创建地图
 * @param target {string} dom容器id
 * @param centerPoint {Array} 中心点坐标
 * @param dataCrs {Array} 数据坐标
 * @param sysCrs {Array} 系统坐标
 * @param zoom {Number} 层级
 * @returns {Map}
 */
export function crtMap ({
	target,
	centerPoint,
	dataCrs = 'EPSG:4326',
	sysCrs = 'EPSG:3857',
	zoom = 8
} = {}) {
	const _map = new Map({
		target: target,
		view: new View({
			projection: sysCrs,
			center: transform(centerPoint, dataCrs, sysCrs),//必须要有
			zoom: zoom
		}),
		controls: olControl.defaults({
			attribution: false,//地图版权信息控件
			zoom: false,//放大缩小控件
			rotate: false//旋转控件
		}),
		interactions: new defaults({
			doubleClickZoom: false//禁用双击交互时事件
		})
	});
	return _map;
}

2.实例化地图方法

import { crtMap } from "./ol-map.js";
const mapParms = {
	target: 'ol-map',
	centerPoint: [104.03895139819457, 29.05014046749801],
	dataCrs:'EPSG:4326',
	sysCrs:'EPSG:3857',
	zoom: 6
}
let olMap = crtMap(mapParms )

二、注意

1.地图dom容器必须设置宽度和高度
2.设置中心点坐标。

  • 10
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
公交查询系统(易语言2005年大赛特等奖) 曾劲松 2005/6/5 《武汉人·公交查询系统》是一款基于武汉市电子地图的公交线路查询系统,它允许你非常方便地搜寻武汉市从甲地到乙地的行车线路并将行车线路在地图上绘制出来,快速准确地查找离某地最近的公交站,查找某公交站的位置,查看某公交线路所经过的站名并绘制于地图之上,在后续版本中将增加搜索其他地理位置(公司、企业、医院、学校、商场等等……)。 本程序核心技术: 1.       完全采用面向对象的编程方法。因为本程序设计到很多矢量图绘制,所以最适合采用面向对象的方法来开发了。有几个重要的类说明如下: 1>     交通图元类。这是所有交通元素类的基类,包含了名称、颜色、描述、是否被选中等几个属性和绘制到内存位图、绘制到画板等几个方法。 2>     点图元类。该类用来描述仅仅用于定位的交通元素,比如公交站、学校、企业等,该类继承自交通图元类,新增加有 取横坐标,取纵坐标,置横坐标,置纵坐标,取边界矩形等方法。 3>     公交站类。该类用来描述公交站,继承自点图元类。增加了 从字符串创建、取点半径、置点半径、取字体大小、置字体大小、绘制到画板、绘制到内存位图等方法。 4>     公交线路类。本类用来描述公交线路,提供了以下方法:查询公交站在公交线路中的索引、从数字字符串创建、绘制到内存位图、取边界矩形、取公交线路号、取公交站编号、取经过的公交站名、取数字化的线路文本、是否经过某公交站等。 5>     连通线路类。本类用来描述两个公交站之间的连通线路,提供了 绘制到内存位图、取边界矩形、取详细信息、是否要专车、检验索引、置公交线路一、置公交线路二、置线路一起止索引、置线路二起止索引、重置等方法。 6>     视图历史类。本来用来记录视图书签,提供以下方法:清除视图历史、取当前视图、取当前索引、取视图、取视图名称、取视图总数、删除当前视图、上一视图、是否可删除视图、是否有上一视图、是否有下一视图、跳到视图、下一视图、显示于列表框、置视图名称、追加视图等。 7>     内存位图类。本来用来增强易语言自身的画板,因为易语言自身的画板未提供绘制EMF文件和EMF字节集的方法,所以专门写了这个类。这个类很多方法跟易语言自身的画板差不多,扩展的方法有 创建位图、复制到画板、复制到画布、洪水填充、画EMF文件、画EMF字节集、画多边形点数组、画多义线点数组、画多边形横纵坐标数组、画多义线横纵坐标数组、画曲线点数组、画曲线横纵坐标数组、绘制文本在矩形内、拉伸复制到画板、拉伸复制到画布、取高度、取宽度、取画布句柄、取位图句柄、实色填充、置画笔属性、置交叉线画刷、置实色画刷、置文本属性等。主要增加了两个画EMF的方法和画曲线的方法。 8>     图层类。本类用来组织各种交通图元,只可惜易语言目前尚不支持方法覆盖和强制类型转换,不得已采用全局数组来替换它了。 2.       矢量图形绘制技术。在程序中要绘制地图,显然地图不能直接使用位图,因为要无限放大,要分层叠加,而且始终清晰,这样就必然要使用矢量图形技术。幸好Windows 已经为我们提供了操作矢量图形 EMF文件的相关函数,这里我已将其封装到内存位图中去了。 3.       快速的路径寻找。在实际乘坐公交的过程中,难免会有转车的现象发生。本程序通过建立公交站索引的方法,能够快速搜索出所有的直达车或一次转车线路,通常这已经能够满足需求,能够搜索出可行的乘车方案。对于两次或两次以上的转车方案,本程序没有实现,一方面实现起来难度大,另一方面也没有必要,因为在实际乘车的过程中,极少有要转两次车的情况。 4.       方便的数据库维护。对于一个公交查询(或曰电子地图)系统来说,数据量之大是可想而知的。偌大一个城市,一个人不可能完全了解其公交站和公交线路的分布情况,况且公交线路也经常处于变化之中,所以本程序提供了灵活的方法允许用户自己来维护数据库的方便方法。具体操作方法请查看本软件帮助。 源代码总共3600行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

鲤鱼跳龙门的鱼

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值