【Leafletjs】5.L.Control 自定义一个Control
L.Control
所有leaflet控制的基础类。继承自IControl接口。 你可以这样添加控件:
control.addTo(map);
// the same as
map.addControl(control);构造器
| 构造器 | 使用 | 描述 | 
|---|---|---|
| L.Control( <Control options> options? )  | new L.Control(…)L.control(…) | 通过给定的选项创建一个控制。 | 
Options
| 选项 | 类型 | 默认值 | 描述 | 
|---|---|---|---|
| position | String | 'topright' | 控制初始的位置(在地图的某一角)。参见 control positions. | 
Methods
| 方法 | 返回值 | 描述 | 
|---|---|---|
| setPosition( | this | 设置控制的位置。参见 control positions. | 
| getPosition() | String | 返回控制的当前位置。 | 
| addTo( | this | 将控制添加到地图上。 | 
| removeFrom( | this | 将控制从地图上移除。 | 
| getContainer() | HTMLElement | 返回 the HTML container of the control. | 
Control Positions(控制的位置)
Control positions (map corner to put a control to) are set using strings. Margins between controls and the map border are set with CSS, so that you can easily override them.
| Position | 描述 | 
|---|---|
| 'topleft' | 地图的左上角。 | 
| 'topright' | 地图的右上角。 | 
| 'bottomleft' | 地图的左下角。 | 
| 'bottomright' | 地图的右下角。 | 
下面讲下如何创建一个自定义控件
基本模板:
L.Control.XXX= L.Control.extend({
    //在此定义参数    
    options: {
    },
    //在此初始化
    initialize: function (options) {
        L.Util.extend(this.options, options);
    },
    onAdd: function (map) {
       //可在此添加控件内容
    }
});
以此模板创建一个简单图例控件
L.Control.Legend = L.Control.extend({
    options: {
        position: 'topright' //初始位置
    },
    initialize: function (options) {
        L.Util.extend(this.options, options);
    },
    onAdd: function (map) {
       //创建一个class为leaflet-control-clegend的div
        this._container = L.DomUtil.create('div', 'leaflet-control-clegend');
       //创建一个图片要素
        var legendimg = document.createElement('img');
        legendimg.id = 'leaflet-control-clegend';
        legendimg.type = 'img';
        legendimg.src = "../../Content/legend.png";
        this._legendimg = legendimg;
        //创建一个关闭控件的按钮
        var closebutton = document.createElement('a');
        closebutton.id = 'leaflet-control-geosearch-close';
        closebutton.className = 'glyphicon glyphicon-remove';
        this._closebutton = closebutton;
        this._container.appendChild(this._closebutton);
        this._container.appendChild(this._legendimg);
        //注册关闭事件
        L.DomEvent.addListener(this._closebutton, 'click', this._onCloseControl, this);
        return this._container;
    },
    _onCloseControl: function () {
        this._map.options.Legend = false;
        this.removeFrom(this._map);
    },
});
在定义一些样式后效果如下

高级一点可以定义如下扁平样式的:


【Leafletjs】5.L.Control 自定义一个Control的更多相关文章
- [WPF 自定义控件]自定义一个“传统”的 Validation.ErrorTemplate
		1. 什么是Validaion.ErrorTemplate 数据绑定模型允许您将与您Binding的对象相关联ValidationRules. 如果用户输入的值无效,你可能希望在应用程序 用户界面 ( ... 
- 自定义View(7)官方教程:自定义View(含onMeasure),自定义一个Layout(混合组件),重写一个现有组件
		Custom Components In this document The Basic Approach Fully Customized Components Compound Controls ... 
- Control.Invoke和Control.BeginInvoke
		问题的引入 下面有个简单的demo,大家一看代码就知道效果如何示例.我新建一个winform的程序,然后写入了如下代码: using System; using System.Windows.Form ... 
- Control.Refresh  Control.Invalidate 和 Control.OnPaint之间的联系和区别
		1.Control.Invalidate会放一个WM_PAINT消息到消息队列,当Control处理到该消息的时候,就调用OnPaint. 2.Control.Refresh相当于以下两行:Contr ... 
- 在String()构造器不存在的情况下自定义一个MyString()函数,实现如下内建String()方法和属性:
		在String()构造器不存在的情况下自定义一个MyString()函数,实现如下内建String()方法和属性: var s = new MyString("hello"); s ... 
- 千万别在UI线程上调用Control.Invoke和Control.BeginInvoke,因为这些是依然阻塞UI线程的,造成界面的假死
		原文地址:https://www.cnblogs.com/wangchuang/archive/2013/02/20/2918858.html .c# Invoke和BeginInvoke 区别 Co ... 
- SpringMVC   自定义一个拦截器
		自定义一个拦截器方法,实现HandlerInterceptor方法 public class FirstInterceptor implements HandlerInterceptor{ /** * ... 
- jQuery Validate 表单验证插件----自定义一个验证方法
		一.下载依赖包 网盘下载:https://yunpan.cn/cryvgGGAQ3DSW 访问密码 f224 二.引入依赖包 <script src="../../scripts/j ... 
- Spring自定义一个拦截器类SomeInterceptor,实现HandlerInterceptor接口及其方法的实例
		利用Spring的拦截器可以在处理器Controller方法执行前和后增加逻辑代码,了解拦截器中preHandle.postHandle和afterCompletion方法执行时机. 自定义一个拦截器 ... 
随机推荐
- 【知识积累】JavaMail实现发邮件功能
			一.前言 今天闲来没事,想着通过程序来给别人发邮件.于是,上网搜了一下,相应的资料也很多,刚开始完成了邮件的简单发送,后来想如何能发送附件,继续寻找 答案,但是遇到了一个问题是当我使用txt类型作为附 ... 
- 实现jquery.ajax及原生的XMLHttpRequest跨域调用WCF服务的方法
			关于ajax跨域调用WCF服务的方法很多,经过我反复的代码测试,认为如下方法是最为简便的,当然也不能说别人的方法是错误的,下面就来上代码,WCF服务定义还是延用上次的,如: namespace Wcf ... 
- CSS易混淆知识点总结与分享-定位与布局
			CSS定位有四种模式:static.relative.absolute.fixed,其它static是默认值,下面分别讲解下各自的特点: static:静态定位,处于动态布局流中,按照页面中的各元素先 ... 
- 【Swift学习】Swift编程之旅---集合类型之数组(六)
			swift提供了3种主要的集合类型,array,set,dictionary.本节介绍array. 数组是存储有序的相同类型的集合,相同的值可以多次出现在不同的位置. 注意: swift的Array类 ... 
- SQL Server时间粒度系列----第3节旬、月时间粒度详解
			本文目录列表: 1.SQL Server旬时间粒度2.SQL Server月有关时间粒度 3.SQL Server函数重构 4.总结语 5.参考清单列表 SQL Server旬时间粒度 ... 
- C#基础03
			学习集合的一些知识.集合:泛型集合,非泛型集合;ArrayList,Hashtable,List<T>,Dictionary<k,v>等,还有一些集合的常用方法. 一:集合的介 ... 
- JQuery对ASP.NET MVC数据进行更新删除
			以前学习ASP.NET MVC时,学习与应用,操作过数据显示,添加,编辑,更新和删除等功能. 很多方法是相通的,看自己是怎样来进行方便,快捷,高效率. 今天Insus.NET写的练习,是直接对绑定在T ... 
- 再谈ABC
			最近一直在看蒋老师那13篇<我的WCF之旅>,终于看完了,看得很慢,记得最初出来工作的时候那时的技术总监建议我去看的,可几个月前我才开始看,看了几个月才把13篇看完.第一篇WCF的博文是我 ... 
- Oracle Error -  "OCIEnvCreate failed with return code -1 but error message text was not available".
			ISSUE: When trying to connect to an Oracle database you receive the following error: "OCIEnvCre ... 
- SQLServer中游标是如何处理数据的?
			游标(Cursor)是处理数据的一种方法,为了查看或者处理结果集中的数据,游标提供了在结果集中一次以行或者多行前进或向后浏览数据的能力.我们可以把游标当作一个指针,它可以指定结果中的任何位置,然后允许 ... 
