SuperMap iClient3D for WebGL教程(空间分析)- Skyline天际线分析

2024-02-25 09:38

本文主要是介绍SuperMap iClient3D for WebGL教程(空间分析)- Skyline天际线分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

作者:刘大

天际线,天际线又称城市轮廓或全景,是指天空与观察点周围的表面以及要素相分离的界线。天际线分析功能可根据观察点,生成当前场景窗口中建筑物顶端边缘与天空的分离线,主要用于城市建筑规划等场景中
###iClient3D for WebGL提取天际线
1.创建天际线分析,可设定相关展示属性参数

// 创建天际线分析对象
var skyline = new Cesium.Skyline(scene);//设置颜色skyline.color =Cesium.Color.CYAN;
// 设置天际线的显示模式,DisplayMode.LINE表示天际线的线模式,DisplayMode.FACE表示天际线的面模式
//默认为线模式
skyline.displayStyle=Cesium.Skyline.displayMode.LINE

2.设置观测点参数并执行(以场景当前位置为例,可按照需求进行设定)

// 获取场景的当前相机位置
var cartographic = scene.camera.positionCartographic;
var longitude = Cesium.Math.toDegrees(cartographic.longitude);
var latitude = Cesium.Math.toDegrees(cartographic.latitude);
var height = cartographic.height;//天际线分析的视口位置设置成当前相机位置skyline.viewPosition = [longitude, latitude, height];
// 设置俯仰,单位:度,取值范围为0-90 
skyline.pitch = Cesium.Math.toDegrees(scene.camera.pitch);
// 获取或设置相机与正北方向的夹角。单位:度,取值范围0-360
skyline.direction = Cesium.Math.toDegrees(scene.camera.heading);
// 天际线分析半径设置为10000米,单位:米。默认值为-1.0,表示无穷远
skyline.radius = 10000; 
// 执行天际线分析
skyline.build(); 

这样我们就能在场景中看到一条天际线了

在这里插入图片描述

上面我们已经在场景中展示出了天际线,那除了这个,我们还能从天际线分析的结果里面做什么应用尼,接下来我们来看看吧,可结合webgl官方实例-天际线分析(‘http://support.supermap.com.cn:8090/webgl/examples/editor.html#skyline’)进行查看

天际线分析应用

#####1.提取限高体
addLimitbody()模拟新建建筑物在不影响天际线时的高度范围
positon:指定限高体位置信息,由经度、纬度的数组表示
name:指定限高体名称,用于移除限高体对象removeLimitbody(name) 的指定

//添加限高体对象skyline.addLimitbody({position: positionarray,name: "limitBody"});

#####2.获取障碍物对象
getObjectIds() ,返回一个k-v对象,key为S3M图层ID,value为对象IDS数组,你可以判定哪些建筑影响了城市的天际线,做相应的调整;
#####3.获取二三维天际线结果
getSkyline2D()&getSkyline3D()
在官方示例里面,提取二维天际线以及拉伸闭合体以及体现这两种,接下来我们看看通过echarts图表将两者结合使用的例子

//获取二维天际线对象  
var object = skyline.getSkyline2D();//获取三维天际线对象  
var locations=skyline.getSkyline3D();
//用echarts绘制二维天际线
var myChart = echarts.init(document.getElementById("map"));
var option = {backgroundColor: "rgba(73,139,156,0.9)",title: {text: "二维天际线"},tooltip: {trigger: "axis"},calculable: true,xAxis: [{type: "category",boundaryGap: false,data: object.x,show: false} ],yAxis: [{type: "value",min: 0,max: 1}],series: [{name: "",type: "line",data: object.y}]
};
myChart.setOption(option);
// 监听click事件,获取相应的点并绘制在场景中
myChart.on('click',function(params){viewer.entities.removeAll()viewer.entities.add({position:Cesium.Cartesian3.fromDegrees(locations.x[params.dataIndex], locations.y[params.dataIndex], locations.z[params.dataIndex]),billboard: {// horizontalOrigin:Cesium.HorizontalOrigin.LEFT,image: './images/map.png',pixelOffset: new Cesium.Cartesian2(0, -32),}})
})
}

在这里插入图片描述

这篇关于SuperMap iClient3D for WebGL教程(空间分析)- Skyline天际线分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/745094

相关文章

Springboot请求和响应相关注解及使用场景分析

《Springboot请求和响应相关注解及使用场景分析》本文介绍了SpringBoot中用于处理HTTP请求和构建HTTP响应的常用注解,包括@RequestMapping、@RequestParam... 目录1. 请求处理注解@RequestMapping@GetMapping, @PostMappin

Python中Request的安装以及简单的使用方法图文教程

《Python中Request的安装以及简单的使用方法图文教程》python里的request库经常被用于进行网络爬虫,想要学习网络爬虫的同学必须得安装request这个第三方库,:本文主要介绍P... 目录1.Requests 安装cmd 窗口安装为pycharm安装在pycharm设置中为项目安装req

Spring Boot Interceptor的原理、配置、顺序控制及与Filter的关键区别对比分析

《SpringBootInterceptor的原理、配置、顺序控制及与Filter的关键区别对比分析》本文主要介绍了SpringBoot中的拦截器(Interceptor)及其与过滤器(Filt... 目录前言一、核心功能二、拦截器的实现2.1 定义自定义拦截器2.2 注册拦截器三、多拦截器的执行顺序四、过

JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)

《JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)》:本文主要介绍如何在IntelliJIDEA2020.1中创建和部署一个JavaWeb项目,包括创建项目、配置Tomcat服务... 目录简介:一、创建项目二、tomcat部署1、将tomcat解压在一个自己找得到路径2、在idea中添加

Python + Streamlit项目部署方案超详细教程(非Docker版)

《Python+Streamlit项目部署方案超详细教程(非Docker版)》Streamlit是一款强大的Python框架,专为机器学习及数据可视化打造,:本文主要介绍Python+St... 目录一、针对 Alibaba Cloud linux/Centos 系统的完整部署方案1. 服务器基础配置(阿里

C++ scoped_ptr 和 unique_ptr对比分析

《C++scoped_ptr和unique_ptr对比分析》本文介绍了C++中的`scoped_ptr`和`unique_ptr`,详细比较了它们的特性、使用场景以及现代C++推荐的使用`uni... 目录1. scoped_ptr基本特性主要特点2. unique_ptr基本用法3. 主要区别对比4. u

Spring IOC核心原理详解与运用实战教程

《SpringIOC核心原理详解与运用实战教程》本文详细解析了SpringIOC容器的核心原理,包括BeanFactory体系、依赖注入机制、循环依赖解决和三级缓存机制,同时,介绍了SpringBo... 目录1. Spring IOC核心原理深度解析1.1 BeanFactory体系与内部结构1.1.1

SpringBoot集成iText快速生成PDF教程

《SpringBoot集成iText快速生成PDF教程》本文介绍了如何在SpringBoot项目中集成iText9.4.0生成PDF文档,包括新特性的介绍、环境准备、Service层实现、Contro... 目录SpringBoot集成iText 9.4.0生成PDF一、iText 9新特性与架构变革二、环

2025最新版Android Studio安装及组件配置教程(SDK、JDK、Gradle)

《2025最新版AndroidStudio安装及组件配置教程(SDK、JDK、Gradle)》:本文主要介绍2025最新版AndroidStudio安装及组件配置(SDK、JDK、Gradle... 目录原生 android 简介Android Studio必备组件一、Android Studio安装二、A

Nginx内置变量应用场景分析

《Nginx内置变量应用场景分析》Nginx内置变量速查表,涵盖请求URI、客户端信息、服务器信息、文件路径、响应与性能等类别,这篇文章给大家介绍Nginx内置变量应用场景分析,感兴趣的朋友跟随小编一... 目录1. Nginx 内置变量速查表2. 核心变量详解与应用场景3. 实际应用举例4. 注意事项Ng