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

openlayers4获取一个图形的边界

由于项目需求问题,需要在地图上绘制多边形要素,由于这个要素可以是不规则的,然后在要素的内部填充文字信息,尽量在多边形的中心绘制,所以要获取多边形的边界,就用到了openlayers框架中的ol.extent.boundingExtent()

API中方法介绍如下:

ol.extent.boundingExtent(coordinates)  //coordinates类型属于Array.<ol.Coordinate>,返回值为[minx, miny, maxx, maxy]类型的

详细的代码如下所示:

$.ajax({
        type: "get",
        url: url,
        dataType: "json",
        contentType: "application/x-www-form-urlencoded;charset=utf-8",
        async: true,
        xhrFields: {
            widthCredentials: true
        },
        success: function (data) {
            var len = data.features.length;//获取要素数组的长度
            layer.getSource().clear();
            layer_text.getSource().clear();
            //设置查询后的图层缩放层级
            for (var m = 0; m < demo.list.length; m++) {
                for (var i = 0; i < len; i++) {
                    if (demo.list[m].gdcode == data.features[i].properties["name"]) {
                        //读取地图上的要素
                        var coordinate = data.features[i].geometry.coordinates;
                        //获取填充文字的坐标位置
                        var coor_bound = ol.extent.boundingExtent(coordinate[0]);//获取一个坐标数组的边界
                        // console.log(coor_bound);//获得图形的边界,各个点的坐标,横坐标点最大值,最小值,纵坐标的最大值最小值
                        var coor_date_x_min = coor_bound[0];
                        var coor_x_dis = (coor_bound[2] - coor_bound[0])/2;
                        var coor_date_y_min = coor_bound[1];
                        var coor_y_dis = (coor_bound[3] - coor_bound[1]) / 2;
                        var coor_num = [coor_date_x_min+coor_x_dis,coor_date_y_min+coor_y_dis];
                        // 添加监测值
                        var anchor_value = new ol.Feature({
                            geometry: new ol.geom.Point(coor_num)
                        });
                        // 设置文字style
                        anchor_value.setStyle(new ol.style.Style({
                            text: new ol.style.Text({
                                font: '15px Microsoft YaHei',
                                text: data.features[i].properties["Leq2013"] + 'dB(A)',
                                fill: new ol.style.Fill({
                                    color: '#222'
                                })
                            })
                        }));
                        layer_text.getSource().addFeature(anchor_value);
                    }
                }
            }
            data = JSON.stringify(data);
            var features = new ol.format.GeoJSON().readFeatures(data);
            layer.getSource().addFeatures(features);
        },
        error: function (data) {
            console.log(data); //输出错误信息
        }
    });

上段代码中的var coor_bound = ol.extent.boundingExtent(coordinate[0]); 其中的coordinate[0] 表示
(7) [Array(2), Array(2), Array(2), Array(2), Array(2), Array(2), Array(2)],字符串序列化为下面的格式:
[[120.61700857758387,31.26619926018776],[120.6084950447106,31.26619926018776],[120.6084950447106,31.273775421598486],[120.61731533453508,31.273775421598486],[120.61731533453508,31.270957736810146],[120.61642875228517,31.270112585427512],[120.61700857758387,31.26619926018776]] ,
然后输出coor_bound为
[120.56358934177479, 31.273710995965757, 120.56975389852369, 31.27600493358085]表示横坐标的最小值,纵坐标的最小值,横坐标的最大值,纵坐标的最大值。。

相关文章:

  • Vue.js小例子--tab选项卡切换
  • 使用openlayers3加载png格式图片
  • openalyers为自定义覆盖物overlay添加点击事件
  • absolute和float的区别
  • float定位对内联元素和块状元素的影响
  • javascript实现拖拽弹框高度,可调节弹框大小
  • vue中的template标签
  • SVN文件夹图标显示不正常的解决办法
  • 集中式开发和分布式开发的区别
  • SVN与GIT的优缺点对比
  • cesiumjs加载geojson+建筑物分层设色
  • js数组中关于filter()、map()、some()、every()、forEach()
  • 去除数组中的重复元素
  • --save-dev 和--save的区别
  • jquery解决input file控件中的onchange上传文件仅一次的bug
  • crontab执行失败的多种原因
  • ES6, React, Redux, Webpack写的一个爬 GitHub 的网页
  • Eureka 2.0 开源流产,真的对你影响很大吗?
  • Github访问慢解决办法
  • java中的hashCode
  • Linux学习笔记6-使用fdisk进行磁盘管理
  • Mac 鼠须管 Rime 输入法 安装五笔输入法 教程
  • mysql 5.6 原生Online DDL解析
  • Objective-C 中关联引用的概念
  • Redis 懒删除(lazy free)简史
  • Spring核心 Bean的高级装配
  • vue的全局变量和全局拦截请求器
  • 从0到1:PostCSS 插件开发最佳实践
  • 目录与文件属性:编写ls
  • 普通函数和构造函数的区别
  • 三分钟教你同步 Visual Studio Code 设置
  • 试着探索高并发下的系统架构面貌
  • #pragma once与条件编译
  • (2009.11版)《网络管理员考试 考前冲刺预测卷及考点解析》复习重点
  • (70min)字节暑假实习二面(已挂)
  • (Matalb时序预测)PSO-BP粒子群算法优化BP神经网络的多维时序回归预测
  • (Redis使用系列) Springboot 使用redis实现接口幂等性拦截 十一
  • (附源码)计算机毕业设计SSM智慧停车系统
  • (紀錄)[ASP.NET MVC][jQuery]-2 純手工打造屬於自己的 jQuery GridView (含完整程式碼下載)...
  • (七)c52学习之旅-中断
  • (十二)python网络爬虫(理论+实战)——实战:使用BeautfulSoup解析baidu热搜新闻数据
  • (四)搭建容器云管理平台笔记—安装ETCD(不使用证书)
  • (一)kafka实战——kafka源码编译启动
  • (一)Linux+Windows下安装ffmpeg
  • (一)u-boot-nand.bin的下载
  • (一)认识微服务
  • (转)C语言家族扩展收藏 (转)C语言家族扩展
  • . Flume面试题
  • .NET 同步与异步 之 原子操作和自旋锁(Interlocked、SpinLock)(九)
  • .NET/C# 推荐一个我设计的缓存类型(适合缓存反射等耗性能的操作,附用法)
  • .NET/C# 中你可以在代码中写多个 Main 函数,然后按需要随时切换
  • .NETCORE 开发登录接口MFA谷歌多因子身份验证
  • .NET多线程执行函数
  • @Autowired自动装配
  • @DependsOn:解析 Spring 中的依赖关系之艺术