SuperMap iClient3D for WebGL 场景美化之飞线

2024-02-25 08:38

本文主要是介绍SuperMap iClient3D for WebGL 场景美化之飞线,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

作者:Taco

前言

        之前有过一篇美化场景的文章,而那篇文章主要是通过添加各种各样的光源来实现的,先给整个场景一个环境光把场景的亮度调暗,再通过添加各式各样的光源(点光源,平行光源,聚光源)来使得场景看起来更加美观。但是这样的场景依然显得空落落的,空的区域还是占了很多。那么该加一些什么让场景看起来好看一些呢?

        在有些案例中会绘制一些向上移动的线条这里简称成飞线,用来添补上空荡的场景。从直观效果感觉,会比常规的场景更加的吸引一些眼球。显得更富有科技感,更加的炫酷!那么,这些飞线是如何实现的呢?

一,实现思路

        说到点线面的添加,其实第一个想法就是实体(entity),那么用实体能够实现这种效果么?当然!是可以的!官网的示例中有一个与我们最后想实现的效果是类似的,没错!它就是尾迹线!(http://support.supermap.com.cn:8090/webgl/examples/webgl/editor.html#airlinesTrailLines)只不过尾迹线是从一个地区向另一个地区的移动,而我们要实现的是从底部竖直向上的移动。实现的方法依然是类似的。

        那么具体实现的方法是什么呢?先来看下接口。

       需要使用到的接口就是 PolylineTrailMaterialProperty 尾迹线材质类。通过修改线条的材质信息让我们的线更加的美观。关于尾迹线的绘制之前有文章已经介绍过了可以通过这个链接去查看到(SuperMap iClient3D for WebGL教程(Entity)-PolylineGraphics_SuperMap技术控-CSDN博客)

二,实现代码

viewer.entities.add({ // 尾迹线polyline: {positions: Cesium.Cartesian3.fromDegreesArrayHeights([longitude, latitude, height, longitude, latitude,height + 500]),width: 4, // 线的宽度,像素为单位material: new Cesium.PolylineTrailMaterialProperty({ // 尾迹线材质color: Cesium.Color.fromCssColorString(rgbColor(1)), //给一个随机的颜色值trailLength: 0.18,period: 2.0})}});

这样我们就绘制除了一个尾迹线的效果,如果场景中需要的是单一的一种颜色,我们可以去修改它的color值,改成Cesium.Color.fromCssColorString("rgba(118, 233, 241, 1)")改成单色即可。而这里为了让场景更加的丰富多彩一些,给了随机的颜色值,rgbColor()。

function rgbColor(a) {var r = Math.floor(Math.random() * 256); //随机r的值var g = Math.floor(Math.random() * 256); //随机g的值var b = Math.floor(Math.random() * 256); //随机b的值if (a || a == 0) {return "rgba(" + r + "," + g + "," + b + "," + a + ")"} else {return "rgb(" + r + "," + g + "," + b + ")"}}

将随机的颜色值传回来就可以达到缤纷多彩的飞线效果啦。

三,实现效果

 

 

 

这篇关于SuperMap iClient3D for WebGL 场景美化之飞线的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

防止Linux rm命令误操作的多场景防护方案与实践

《防止Linuxrm命令误操作的多场景防护方案与实践》在Linux系统中,rm命令是删除文件和目录的高效工具,但一旦误操作,如执行rm-rf/或rm-rf/*,极易导致系统数据灾难,本文针对不同场景... 目录引言理解 rm 命令及误操作风险rm 命令基础常见误操作案例防护方案使用 rm编程 别名及安全删除

Spring Security 前后端分离场景下的会话并发管理

《SpringSecurity前后端分离场景下的会话并发管理》本文介绍了在前后端分离架构下实现SpringSecurity会话并发管理的问题,传统Web开发中只需简单配置sessionManage... 目录背景分析传统 web 开发中的 sessionManagement 入口ConcurrentSess

99%的人都选错了! 路由器WiFi双频合一还是分开好的专业解析与适用场景探讨

《99%的人都选错了!路由器WiFi双频合一还是分开好的专业解析与适用场景探讨》关于双频路由器的“双频合一”与“分开使用”两种模式,用户往往存在诸多疑问,本文将从多个维度深入探讨这两种模式的优缺点,... 在如今“没有WiFi就等于与世隔绝”的时代,越来越多家庭、办公室都开始配置双频无线路由器。但你有没有注

深入解析Java NIO在高并发场景下的性能优化实践指南

《深入解析JavaNIO在高并发场景下的性能优化实践指南》随着互联网业务不断演进,对高并发、低延时网络服务的需求日益增长,本文将深入解析JavaNIO在高并发场景下的性能优化方法,希望对大家有所帮助... 目录简介一、技术背景与应用场景二、核心原理深入分析2.1 Selector多路复用2.2 Buffer

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

Java Stream流之GroupBy的用法及应用场景

《JavaStream流之GroupBy的用法及应用场景》本教程将详细介绍如何在Java中使用Stream流的groupby方法,包括基本用法和一些常见的实际应用场景,感兴趣的朋友一起看看吧... 目录Java Stream流之GroupBy的用法1. 前言2. 基础概念什么是 GroupBy?Stream

java如何实现高并发场景下三级缓存的数据一致性

《java如何实现高并发场景下三级缓存的数据一致性》这篇文章主要为大家详细介绍了java如何实现高并发场景下三级缓存的数据一致性,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 下面代码是一个使用Java和Redisson实现的三级缓存服务,主要功能包括:1.缓存结构:本地缓存:使

C++中detach的作用、使用场景及注意事项

《C++中detach的作用、使用场景及注意事项》关于C++中的detach,它主要涉及多线程编程中的线程管理,理解detach的作用、使用场景以及注意事项,对于写出高效、安全的多线程程序至关重要,下... 目录一、什么是join()?它的作用是什么?类比一下:二、join()的作用总结三、join()怎么

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分

nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析(结合应用场景)

《nginx-t、nginx-sstop和nginx-sreload命令的详细解析(结合应用场景)》本文解析Nginx的-t、-sstop、-sreload命令,分别用于配置语法检... 以下是关于 nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析,结合实际应