当前位置: 首页 > news >正文

cesium加载.tif格式文件

最近项目中有需要直接加载三方给的后缀名tif格式的文件

<script src="https://cdn.jsdelivr.net/npm/geotiff"></script>
或者
yarn add geotiff
npm install geotiff

新建tifs.js

import GeoTIFF, { fromBlob, fromUrl, fromArrayBuffer } from 'geotiff';
import GeoTIFFImage from 'geotiff/dist-node/geotiffimage';
var tiff;
var image;
var rectangle;
class GeoTiffUtil {constructor() {}async init(){this.tiff = await fromUrl('http://xxxx.tif');this.image = await this.tiff.getImage();let [west, south, east, north] = this.image.getBoundingBox();const code =this.image.geoKeys.ProjectedCSTypeGeoKey ||this.image.geoKeys.GeographicTypeGeoKey;let { x: w, y: n } = await (await fetch(`//epsgIo/trans?x=${west}&y=${north}&s_srs=${code}&t_srs=4326`)).json();let { x: e, y: s } = await (await fetch(`//epsgIo/trans?x=${east}&y=${south}&s_srs=${code}&t_srs=4326`)).json();const [red = [], green = [], blue = []] = await this.image.readRasters();// 将像素信息写入canvasconst canvas = document.createElement("canvas");let width = this.image.getWidth();let height = this.image.getHeight();canvas.width = width;canvas.height = height;let ctx = canvas.getContext("2d");let imageData = ctx.createImageData(width, height);for (var i = 0; i < imageData.data.length / 4; i += 1) {imageData.data[i * 4 + 0] = red[i];imageData.data[i * 4 + 1] = green[i] || 0;imageData.data[i * 4 + 2] = blue[i] || 0;imageData.data[i * 4 + 3] = red[i] === 0 ? 0 : 255;}ctx.putImageData(imageData, 0, 0);return {canvas:canvas,rectangle:[w, s, e, n]};}
}
export default new GeoTiffUtil();

index.vue

 import GeoTiffUtil from '@/utils/tifs.js';     GeoTiffUtil.init().then((res)=>{let rectangle = Cesium.Rectangle.fromDegrees(res.rectangle[0], res.rectangle[1],             res.rectangle[2],res.rectangle[3]);let du = res.canvas.toDataURL();viewer.imageryLayers.addImageryProvider(new Cesium.SingleTileImageryProvider({url: du,rectangle,}));viewer.camera.setView({destination: rectangle,});})

http://www.lryc.cn/news/332203.html

相关文章:

  • 分布式全闪占比剧增 152%,2023 年企业存储市场报告发布
  • LeetCode 707. 设计链表(单链表、(非循环)双链表 模板)
  • 深入了解Flutter中Overlay的介绍以及使用
  • 文本直接生成2分钟视频,即将开源模型StreamingT2V
  • 时序预测 | Matlab实现SOM-BP自组织映射结合BP神经网络时间序列预测
  • FPGA高端图像处理开发板-->鲲叔4EV:12G-SDI、4K HDMI2.0、MIPI等接口谁敢与我争锋?
  • linux练习-交互式传参
  • 【数据结构(一)】初识数据结构
  • 前端三剑客 —— CSS (第六节)
  • MyBatis 解决上篇的参数绑定问题以及XML方式交互
  • Rust语言之属性宏(Attribute Macro)derive
  • [技术闲聊]我对电路设计的理解(六)-原理图封装
  • 算法(滑动窗口四)
  • 学习记录:bazel和cmake运行终端指令
  • 蓝桥杯刷题--python-37-分解质因数
  • Delphi编写的图片查看器
  • Swing中的FlowLayout/WrapLayout在打横排列时候如何做到置顶对齐
  • C# MES通信从入门到精通(8)——C#调用Webservice服务进行数据交互
  • day04-MQ
  • 神经网络汇聚层
  • 2024.3.8力扣每日一题——找出美丽数组的最小和
  • 单例模式以及线程安全问题
  • 车载电子电器架构 —— 软件下载
  • 阿里云弹性计算通用算力型u1实例性能评测,性价比高
  • Jupyter IPython帮助文档及其魔法命令
  • 设计模式总结-面向对象设计原则
  • 绿联 安装zfile,创建属于自己的网盘,支持直链分享
  • KnowLog:基于知识增强的日志预训练语言模型|顶会ICSE 2024论文
  • 前端:用Sass简化媒体查询
  • 如何快速写出漂亮的Button按钮呢?