轻松搞定 TIFF:基于 Three.js 和 Cesium 的渲染技巧分享

前言:

你是否需要在 Three.js 和 Cesium 中渲染 TIFF 文件 却不知从何下手?本文提供 零到一的全流程实现,涵盖 加载、解析、渲染 等核心步骤,并通过完整 Vue + Vite 项目 演示如何高效可视化 TIFF 数据。

示例代码位置: gitcode.com/fujie/three...

1. 准备工作

1.1. 什么是 TIFF 文件?

TIFF(Tagged Image File Format)是一种灵活的位图图像格式,广泛用于存储高质量的图像数据,尤其是地理空间数据、卫星图像、航拍照片等。它的特点是很能"装",支持多图层、多通道、无损压缩等特性。

1.2. 搭建本地服务

接下来,我们使用 Vite 初始化一个 Vue 项目,并清理掉不必要的样式和结构。同时,按照功能需求,创建两个组件:

  • ThreeTif.vue:专门用于通过 Three.js 渲染 TIFF 文件。
  • CesiumTif.vue:专门用于通过 Cesium 渲染 TIFF 文件。

这个过程非常简单,只需要几步就能完成。让我们开始吧!

1.3. 准备 TIFF 文件

我将准备好的 TIFF 文件放置在 public目录下, 这里我准备了三个tif文件

2. Three 渲染 TIFF 文件

在加载和渲染 TIFF 文件之前,我们需要确保项目已正确安装和配置 Three.js 及其必要的依赖。以下是具体的准备工作:

2.1. 安装 Three.js

通过 npm 或 yarn 安装 three 库,这是渲染 TIFF 文件的核心依赖。

2.2. 导入 Three.js 和 TIFF 加载器

在项目中导入 Three.js 以及适用于 TIFF 文件的加载器(如 tiffloader 或自定义的 TIFF 解析器),以便在代码中使用它们。

2.3. 渲染 TIFF 文件

Three 中,渲染之前,先创建场景(Scene)、相机(Camera) 和渲染器(Renderer)

使用 TTFLoader 或自定义加载器加载 TIFF 文件。

3. Cesium 中渲染 TIFF

在 Cesium 中渲染 TIFF 文件时,通常需要将 TIFF 文件转换为 Cesium 支持的格式,并将其作为影像图层加载到场景中。为了简化这一过程,可以使用 tiff-imagery-provider包。 通过 tiff-imagery-provider,可以轻松地将 TIFF 影像数据无缝集成到 Cesium 的三维地球场景中

3.1. 安装依赖

首先,安装 cesiumtiff-imagery-provider

3.2. 使用 tiff-imagery-provider

以下是使用 tiff-imagery-provider 在 Cesium 中渲染 TIFF 文件的完整代码:

3.3. 代码解析

TIFFImageryProvider:这是 tiff-imagery-provider 包提供的类,专门用于加载和处理 TIFF 文件。

url:指定 TIFF 文件的路径。

viewer.imageryLayers.addImageryProvider:将 TIFFImageryProvider 生成的影像图层添加到 Cesium 场景中。

4. 最终运行效果

页面左侧为Three 渲染效果, 右侧为Cesium 渲染效果

总结

本文详细介绍了如何使用 Three.jsCesium 渲染 TIFF 文件。通过 Three.js,我们利用 TTFLoader 加载 TIFF 文件并将其转换为纹理,最终在三维场景中渲染。而在 Cesium 中,通过 tiff-imagery-provider 简化了 TIFF 文件的加载和地理信息处理,使其能够无缝集成到三维地球场景中。

如果觉得本文对你有帮助,希望能够给我点赞支持一下哦 💪 也可以关注wx公众号:程序员付杰 ,一起学习编程技能

相关推荐
辻戋1 小时前
从零实现React Scheduler调度器
前端·react.js·前端框架
徐同保1 小时前
使用yarn@4.6.0装包,项目是react+vite搭建的,项目无法启动,报错:
前端·react.js·前端框架
Qrun2 小时前
Windows11安装nvm管理node多版本
前端·vscode·react.js·ajax·npm·html5
中国lanwp2 小时前
全局 npm config 与多环境配置
前端·npm·node.js
JELEE.3 小时前
Django登录注册完整代码(图片、邮箱验证、加密)
前端·javascript·后端·python·django·bootstrap·jquery
TeleostNaCl5 小时前
解决 Chrome 无法访问网页但无痕模式下可以访问该网页 的问题
前端·网络·chrome·windows·经验分享
前端大卫7 小时前
为什么 React 中的 key 不能用索引?
前端
你的人类朋友7 小时前
【Node】手动归还主线程控制权:解决 Node.js 阻塞的一个思路
前端·后端·node.js
小李小李不讲道理9 小时前
「Ant Design 组件库探索」五:Tabs组件
前端·react.js·ant design
毕设十刻9 小时前
基于Vue的学分预警系统98k51(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js