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

相关文章

IDEA下"File is read-only"可能原因分析及"找不到或无法加载主类"的问题

《IDEA下Fileisread-only可能原因分析及找不到或无法加载主类的问题》:本文主要介绍IDEA下Fileisread-only可能原因分析及找不到或无法加载主类的问题,具有很好的参... 目录1.File is read-only”可能原因2.“找不到或无法加载主类”问题的解决总结1.File

Kali Linux安装实现教程(亲测有效)

《KaliLinux安装实现教程(亲测有效)》:本文主要介绍KaliLinux安装实现教程(亲测有效),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、下载二、安装总结一、下载1、点http://www.chinasem.cn击链接 Get Kali | Kal

Web技术与Nginx网站环境部署教程

《Web技术与Nginx网站环境部署教程》:本文主要介绍Web技术与Nginx网站环境部署教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Web基础1.域名系统DNS2.Hosts文件3.DNS4.域名注册二.网页与html1.网页概述2.HTML概述3.

Dubbo之SPI机制的实现原理和优势分析

《Dubbo之SPI机制的实现原理和优势分析》:本文主要介绍Dubbo之SPI机制的实现原理和优势,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Dubbo中SPI机制的实现原理和优势JDK 中的 SPI 机制解析Dubbo 中的 SPI 机制解析总结Dubbo中

C#继承之里氏替换原则分析

《C#继承之里氏替换原则分析》:本文主要介绍C#继承之里氏替换原则,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#里氏替换原则一.概念二.语法表现三.类型检查与转换总结C#里氏替换原则一.概念里氏替换原则是面向对象设计的基本原则之一:核心思想:所有引py

spring security 超详细使用教程及如何接入springboot、前后端分离

《springsecurity超详细使用教程及如何接入springboot、前后端分离》SpringSecurity是一个强大且可扩展的框架,用于保护Java应用程序,尤其是基于Spring的应用... 目录1、准备工作1.1 引入依赖1.2 用户认证的配置1.3 基本的配置1.4 常用配置2、加密1. 密

WinForms中主要控件的详细使用教程

《WinForms中主要控件的详细使用教程》WinForms(WindowsForms)是Microsoft提供的用于构建Windows桌面应用程序的框架,它提供了丰富的控件集合,可以满足各种UI设计... 目录一、基础控件1. Button (按钮)2. Label (标签)3. TextBox (文本框

C#实现访问远程硬盘的图文教程

《C#实现访问远程硬盘的图文教程》在现实场景中,我们经常用到远程桌面功能,而在某些场景下,我们需要使用类似的远程硬盘功能,这样能非常方便地操作对方电脑磁盘的目录、以及传送文件,这次我们将给出一个完整的... 目录引言一. 远程硬盘功能展示二. 远程硬盘代码实现1. 底层业务通信实现2. UI 实现三. De

CentOS7增加Swap空间的两种方法

《CentOS7增加Swap空间的两种方法》当服务器物理内存不足时,增加Swap空间可以作为虚拟内存使用,帮助系统处理内存压力,本文给大家介绍了CentOS7增加Swap空间的两种方法:创建新的Swa... 目录在Centos 7上增加Swap空间的方法方法一:创建新的Swap文件(推荐)方法二:调整Sww

基于Go语言实现Base62编码的三种方式以及对比分析

《基于Go语言实现Base62编码的三种方式以及对比分析》Base62编码是一种在字符编码中使用62个字符的编码方式,在计算机科学中,,Go语言是一种静态类型、编译型语言,它由Google开发并开源,... 目录一、标准库现状与解决方案1. 标准库对比表2. 解决方案完整实现代码(含边界处理)二、关键实现细