热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

SuperMapiClient3DforWebGL教程:深入解析影像图层(ImageryLayer)的应用与优化

本文详细探讨了SuperMapiClient3DforWebGL中影像图层(ImageryLayer)的应用与优化技巧。通过多个实际案例,作者深入解析了不同类型的ImageryProvider的使用方法,并提供了实用的性能优化建议,帮助开发者更好地在三维场景中展示和管理影像数据。

作者:为梦齐舞

本文同步更新于简书文章https://www.jianshu.com/p/cc38d1cc2d7e

上诉文章中介绍了很多关于ImageryProvider的例子,接下来我们一起了解下ImageryLayer。
一、ImageryProvider与ImageryLayer的区别
通常我们创建一个ImageryProvider是为了创建一个ImageryLayer显示数据,ImageryProvider类似于超图中数据集的概念,他设定了显示何种类型的数据,或者说是去请求某种特定服务的切片,是数据的提供者;ImageryLayer类似于超图中的图层的概念,他只是ImageryProvider的一个容器,用于展示数据。这样也就是说,一个ImageryProvider可以对应多个ImageryLayer;而一个ImageryLayer对应一个ImageryProvider,是一对多的关系。
二、ImageryLayer参数介绍
参数介绍
1、我们可以通过修改属性值alpha(图层透明度值)、brightness(图层亮度值)、contrast(图层对比度)、hue(图层色调)、saturation(图层饱和度)、gamma(图层伽马校正)等属性可以修改可视化效果
2、通过show参数控制图层是否显示
3、当我们需要将影像中某种颜色进行透明化时,我们可以设置transperantBackColor 透明色参数;并且配合transperantBackColorTolerance 透明色容限一起使用, 取值范围为0.0~1.0。0.0表示完全透明,1.0表示完全不透明。达到需要的透明效果
4、当我们需要使用到卷帘对比时,可以使用splitDirection 设置分割条方向,并且通过viewer.scene.imagerySplitPosition设置分隔条的位置参数。
三、ImageryLayer获取方式
1、我们可以通过ImageryProvider创建图层,获取ImageryLayer

///定义图层
var imageryLayer = new Cesium.ImageryLayer( new Cesium.SuperMapImageryProvider({url : ‘http://localhost:8090/iserver/services/datas/China’}));
///添加到场景中
viewer.imageryLayers.add(imageryLayer);

2、通过addImageryProvider方法直接添加获取

var imageryLayer = viewer.imageryLayers.addImageryProvider(new Cesium.SingleTileImageryProvider({url : './images/xxxxxx.jpg'}));

3、通过viewer.imageryLayers 获取

var imageryLayer =viewer.imageryLayers.get(索引值);

四、调整参数后的影像效果
影像效果


推荐阅读
  • Startup 类配置服务和应用的请求管道。Startup类ASP.NETCore应用使用 Startup 类,按照约定命名为 Startup。 Startup 类:可选择性地包括 ... [详细]
  • 本文详细介绍了如何准备和安装 Eclipse 开发环境及其相关插件,包括 JDK、Tomcat、Struts 等组件的安装步骤及配置方法。 ... [详细]
  • 通过Web界面管理Linux日志的解决方案
    本指南介绍了一种利用rsyslog、MariaDB和LogAnalyzer搭建集中式日志管理平台的方法,使用户可以通过Web界面查看和分析Linux系统的日志记录。此方案不仅适用于服务器环境,还提供了详细的步骤来确保系统的稳定性和安全性。 ... [详细]
  • 深入理解Redis的数据结构与对象系统
    本文详细探讨了Redis中的数据结构和对象系统的实现,包括字符串、列表、集合、哈希表和有序集合等五种核心对象类型,以及它们所使用的底层数据结构。通过分析源码和相关文献,帮助读者更好地理解Redis的设计原理。 ... [详细]
  • 本文将深入探讨如何在不依赖第三方库的情况下,使用 React 处理表单输入和验证。我们将介绍一种高效且灵活的方法,涵盖表单提交、输入验证及错误处理等关键功能。 ... [详细]
  • 使用 GitHub、JSDelivr、PicGo 和 Typora 构建高效的图床解决方案
    本文详细介绍了如何利用 GitHub 仓库、JSDelivr CDN、PicGo 图床工具和 Typora 编辑器,搭建一个高效且免费的图床系统。通过此方案,用户可以轻松管理和上传图片,并在 Markdown 文档中快速插入高质量的图片链接。 ... [详细]
  • 本文详细介绍了 Flink 和 YARN 的交互机制。YARN 是 Hadoop 生态系统中的资源管理组件,类似于 Spark on YARN 的配置方式。我们将基于官方文档,深入探讨如何在 YARN 上部署和运行 Flink 任务。 ... [详细]
  • 本文详细介绍了网络存储技术的基本概念、分类及应用场景。通过分析直连式存储(DAS)、网络附加存储(NAS)和存储区域网络(SAN)的特点,帮助读者理解不同存储方式的优势与局限性。 ... [详细]
  • 本文介绍了一种在 MySQL 客户端执行 NOW() 函数时出现时间偏差的问题,并详细描述了如何通过配置文件调整时区设置来解决该问题。演示场景中,假设当前北京时间为2023年2月17日19:31:37,而查询结果显示的时间比实际时间晚8小时。 ... [详细]
  • 本文详细介绍了如何通过RPM包在Linux系统(如CentOS)上安装MySQL 5.6。涵盖了检查现有安装、下载和安装RPM包、配置MySQL以及设置远程访问和开机自启动等步骤。 ... [详细]
  • Kubernetes 持久化存储与数据卷详解
    本文深入探讨 Kubernetes 中持久化存储的使用场景、PV/PVC/StorageClass 的基本操作及其实现原理,旨在帮助读者理解如何高效管理容器化应用的数据持久化需求。 ... [详细]
  • 本文介绍了如何利用 Spring Boot 和 Groovy 构建一个灵活且可扩展的动态计算引擎,以满足钱包应用中类似余额宝功能的推广需求。我们将探讨不同的设计方案,并最终选择最适合的技术栈来实现这一目标。 ... [详细]
  • 基于Node.js、Express、MongoDB和Socket.io的实时聊天应用开发
    本文详细介绍了使用Node.js、Express、MongoDB和Socket.io构建的实时聊天应用程序。涵盖项目结构、技术栈选择及关键依赖项的配置。 ... [详细]
  • 利用Selenium与ChromeDriver实现豆瓣网页全屏截图
    本文介绍了一种使用Selenium和ChromeDriver结合Python代码,轻松实现对豆瓣网站进行完整页面截图的方法。该方法不仅简单易行,而且解决了新版Selenium不再支持PhantomJS的问题。 ... [详细]
  • 深入解析Serverless架构模式
    本文将详细介绍Serverless架构模式的核心概念、工作原理及其优势。通过对比传统架构,探讨Serverless如何简化应用开发与运维流程,并介绍当前主流的Serverless平台。 ... [详细]
author-avatar
在路上的老兵
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有