cesium 漫游

 

 token记得换成您自己的!!! 

申请cesium的token 官网【Cesium: The Platform for 3D Geospatial

 

<template><div id="cesiumContatiner"><!-- <div id="mapContainer1"></div> --></div></template>
<!-- 绘制面并且编辑 -->
<script setup lang="ts">
import * as Cesium from 'cesium';
import { ref, watch, reactive, toRefs, onMounted } from 'vue';
import * as turf from '@turf/turf';// 地图实例
let viewer: any;onMounted(() => {// 设置cesium tokenCesium.Ion.defaultAccessToken ='填写您自己的token';viewer = GetCesiumViewer('cesiumContatiner');GetMotionLine()
});function GetCesiumViewer(cesiumContatiner: string) {// // 创建自定义图层const esri = new Cesium.ArcGisMapServerImageryProvider({url: 'https://services.arcgisonline.com/ArcGIS/rest/services/World_Imagery/MapServer',// enablePickFeatures: false,});// 【控件】viewer = new Cesium.Viewer(cesiumContatiner, {timeline: false, // 时间轴animation: false, // 动画小组件geocoder: false, // 地理编码(搜索)组件homeButton: false, // 首页,点击之后将视图跳转到默认视角sceneModePicker: false, // 投影方式,切换2D、3D 和 Columbus View (CV) 模式。baseLayerPicker: false, // 底图组件,选择三维数字地球的底图(imagery and terrain)。navigationHelpButton: false, // 帮助按钮fullscreenButton: false, // 全屏按钮// vrButton: false, // VR模式selectionIndicator: false, //是否显示选取指示器组件// shouldAnimate: true, // 自动播放动画控件// shadows: true, // 是否显示光照投射的阴影// terrainShadows: Cesium.ShadowMode.RECEIVE_ONLY, // 地质接收阴影`infoBox: false, // 信息框//terrainProvider:new Cesium.CesiumTerrainProvider({url: 'http://data.marsgis.cn/terrain',}),imageryProvider: esri , //自定义图层,默认是谷歌的影响图层scene3DOnly: true, // 每个几何实例将只能以3D渲染以节省GPU内存sceneMode: 3, // 初始场景模式 1 2D模式 2 2D循环模式 3 3D模式  Cesium.SceneMode});// 隐藏logoviewer._cesiumWidget._creditContainer.style.display = 'none';let destination = Cesium.Cartesian3.fromDegrees(116.3974, 39.9087, 1000); // 北京天安门广场的经纬度坐标及高度// 116.3974, 39.9087// viewer.camera.flyTo({//   destination: destination,//   duration: 2, // 飞行动画持续时间(单位:秒)// });return viewer;
}function GetMotionLine(){viewer.clock.shouldAnimate = true;const startLatitude =  39.9087;
const startLongitude = 116.3974;
let endLongitude;
const startTime = Cesium.JulianDate.now();//将多段线添加到场景中。位置是动态的。
const isConstant = false;
const redLine = viewer.entities.add({polyline: {//此回调将更新每帧的位置。positions: new Cesium.CallbackProperty(function (time, result) {endLongitude =startLongitude +0.005 * Cesium.JulianDate.secondsDifference(time, startTime);return Cesium.Cartesian3.fromDegreesArray([startLongitude, startLatitude, endLongitude, startLatitude],Cesium.Ellipsoid.WGS84,result);}, isConstant),width: 10,// material: Cesium.Color.RED,material: new Cesium.PolylineArrowMaterialProperty(Cesium.Color.fromCssColorString('#FF0000') //transparent),// 是否贴地显示clampToGround: true,},});let destination = Cesium.Cartesian3.fromDegrees(116.3974, 39.9087, 10000); // 北京天安门广场的经纬度坐标及高度116.3974, 39.9087viewer.camera.flyTo({destination: destination,duration: 2, // 飞行动画持续时间(单位:秒)});
const startCartographic = Cesium.Cartographic.fromDegrees(startLongitude,startLatitude
);// 使用scrath对象来避免每帧都创建新的对象。
let endCartographic = new Cesium.Cartographic();
const scratch = new Cesium.Cartographic();
const geodesic = new Cesium.EllipsoidGeodesic();// 计算直线的长度
function getLength(time, result) {// 从polyLine的回调中获取结束位置。const endPoint = redLine.polyline.positions.getValue(time, result)[1];endCartographic = Cesium.Cartographic.fromCartesian(endPoint);geodesic.setEndPoints(startCartographic, endCartographic);const lengthInMeters = Math.round(geodesic.surfaceDistance);return `${(lengthInMeters / 1000).toFixed(1)} km`;
}function getMidpoint(time, result) {//从polyLine的回调中获取结束位置。const endPoint = redLine.polyline.positions.getValue(time, result)[1];endCartographic = Cesium.Cartographic.fromCartesian(endPoint);geodesic.setEndPoints(startCartographic, endCartographic);const midpointCartographic = geodesic.interpolateUsingFraction(0.8,scratch);return Cesium.Cartesian3.fromRadians(midpointCartographic.longitude,midpointCartographic.latitude);
}//用计算的长度标记多段线
const label = viewer.entities.add({position: new Cesium.CallbackProperty(getMidpoint, isConstant),label: {//此回调将更新打印每帧的长度。text: new Cesium.CallbackProperty(getLength, isConstant),//function(){ return ''}font: "20px sans-serif",pixelOffset: new Cesium.Cartesian2(0.0, 20),},
});//保持视图居中。
viewer.trackedEntity = label;}</script><style scoped lang="scss">
.container {display: flex;width: 100%;height: 100%;justify-content: space-between;flex-wrap: wrap;} /* #mapContainer1 {width: 50%;position: absolute;padding: 0;margin: 0;height: 100%;
}#mapContainer2 {width: 50%;left: 50%;position: absolute;padding: 0;margin: 0;height: 100%;
} *//* /deep/.cesium-widget{height: 911px
}*/
</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/23492.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何理解敏捷开发和瀑布模型的区别

敏捷开发和瀑布模型是两种不同的软件开发方法&#xff0c;它们在多个方面存在显著的差异。以下是它们之间的主要区别&#xff1a; 开发流程&#xff1a; 瀑布模型&#xff1a;采用线性的开发流程&#xff0c;按照预先规划的顺序依次进行需求分析、设计、编码、测试和维护等环节…

【蒙特卡洛仿真的corner】

蒙特卡洛仿真的corner global variation指的是不同晶圆之间的process的差别 local variation指的是同一个晶圆内的不同管子之间的mismatch smic40ll工艺中&#xff0c;ttg&#xff0c;ssg&#xff0c;sfg&#xff0c;fsg corner只包含mismatch ss&#xff0c;tt&#xff0c;sf&…

员工离职删除自己做的文件违法么?如何杜绝这种现象?

员工离职时删除自己做的文件是否违法&#xff0c;需要视情况而定&#xff1a; 如果删除的是个人自己的文件&#xff1a; 在这种情况下&#xff0c;员工删除的是自己制作的、不涉及公司机密或经营数据的个人文件&#xff0c;通常不会被视为违法行为。 如果删除的是公司的文件…

探索 CSV 模块:Python 中 CSV 数据持久化的最佳实践

&#x1f340; 前言 博客地址&#xff1a; CSDN&#xff1a;https://blog.csdn.net/powerbiubiu &#x1f44b; 简介 本章节介绍使用 CSV 文件来存储数据&#xff0c;CSV 文件是一种常见的数据格式&#xff0c;可以用来存储和交换表格数据。CSV 文件由一系列的行组成&#x…

SQL Developer管理RESTful 服务

RESTful 服务依赖于ORDS&#xff08;Oracle REST Data Services&#xff09;&#xff0c;所以在进行本实验前&#xff0c;请先确认数据库服务器上的ORDS服务已启动&#xff1a; $ systemctl status ords ● ords.service - Oracle REST Data ServicesLoaded: loaded (/etc/sys…

小程序canvas的同层渲染 这个属性不加,就不会生效!

做微信小程序的时候&#xff0c;发现vant-weapp的图表相关的vant再实机上怎么用都有问题&#xff08;同层渲染失败&#xff09;。 看了官方文档结果说了半天一点用都没有&#xff0c;官方原话是&#xff1a;当前所有原生组件&#xff08;除 input 组件 focus 状态&#xff09;均…

scripts/Makefile.host 分析【fixdep、conf】

文章目录 1. 目标 $(obj)/fixdep1.1 cmd_host-csingle函数分析&#xff1a; 2. 目标 $(obj)/conf2.1 cmd_host-cmulti函数分析&#xff1a;2.2 生成 $(obj)/conf.o 文件&#xff1a;2.3 生成 $(obj)/zconf.tab.o 文件&#xff1a; 1 # SPDX-License-Identifier: GPL-2.0 2 …

C++二级指针的指向与解引用

本文算是作者对于二级指针学习的一些总结或者说是刨根问底&#xff0c;如果有表述错误&#xff0c;还请各位大神指正。 我们首先定义一个整型a&#xff0c;令a 5&#xff0c;再分别定义指针p和二级指针ptr int a 5; int *p &a; int **ptr &p;我们不妨假设a的地址是…

云原生周刊:Gateway API v1.1 发布 | 2024.6.3

开源项目推荐 Grafana Tanka Tanka 是 Grafana 开发的一款用于 Kubernetes 的灵活、可重用和简洁的配置工具,是使用 YAML 进行 Kubernetes 配置的一种替代方案。 pv-migrate pv-migrate 是一个 CLI 工具/kubectl 插件&#xff0c;可以轻松地将一个 Kubernetes PersistentVo…

23中设计模式之一— — — —命令模式的详细介绍

命令模式 Command Pattern讲解 概念描述模式结构主要角色模式的UIM类图模式优点模式缺点应用场景实例演示类图代码演示运行结果 概念 命令模式&#xff08;别名&#xff1a;动作&#xff0c;事务&#xff09; 命令模式是一种行为设计模式&#xff0c;将一个请求封装为一个对象…

【qt】项目移植

项目移植 一.前言二.同名问题三.具体操作1.修改文件名2.修改类名3.修改一些不能自动改的名4.修改.ui文件5.删除原来自动生成的ui_xxx.h文件6.修改头文件 四.导入项目五.使用导入的项目六.项目建议 一.前言 终于概率论考完了,有时间了,接着上个项目,我们继续来完成我们的多窗口开…

【Leetcode Python】

偷某间房屋时&#xff0c;累积金额等于间隔前两间房的金额加上当前房的金额数&#xff1b;不偷时&#xff0c;累计金额就等于前一间房的金额数。 状态转移方程&#xff1a;dp[i] max(dp[i-2]nums[i], dp[i-1]) 并且注意错误点&#xff1a;dp[1]有两间房时&#xff0c;初始值为…

汽车soa架构介绍

SOA 架构的基本概念 面向服务的架构(Service-Oriented Architecture,简称 SOA)是一种软件设计和架构风格,近年来在软件开发领域得到了广泛的关注和应用。 SOA 的定义可以概括为:它是一种将应用程序分解为一组松散耦合的服务的架构模式。这些服务通过定义明确的接口进行通…

【Pycharm】功能介绍

1.Code Reformat Code 格式化代码&#xff0c;可以帮助我们去自动调整空格等&#xff0c;根据python语法规范自动调整 2.Settings 1.创建py文件默认填充模版 3.读写py文件编码格式一致性 顶部代码指定的编码方式作用&#xff1a; 可以保证python2/3解释器在读取文件的时候按…

jmeter并发测试

目录 常用的压测工具jmeter安装配置并执行新建测试计划 Test Plan添加线程组练习01&#xff1a;共10个线程&#xff0c;每秒钟启动一个线程&#xff08;需要10秒&#xff09;&#xff0c;每个线程发送两个请求练习02&#xff1a;共10个线程&#xff0c;1秒中内启动完毕&#xf…

03-3.2.2 队列的顺序存储实现

&#x1f44b; Hi, I’m Beast Cheng&#x1f440; I’m interested in photography, hiking, landscape…&#x1f331; I’m currently learning python, javascript, kotlin…&#x1f4eb; How to reach me --> 458290771qq.com 喜欢《数据结构》部分笔记的小伙伴可以订…

kali中安装、卸载程序教程

1、安装教程 ①、使用apt安装 apt update &#xff08;先更新apt&#xff09; apt-get install xxxx(xxx为需要安装的软件名)②、使用dpkg安装 dpkg –i deb的软件包名&#xff08;需要在软件包的目录下使用&#xff0c;不然就要把地址加上&#xff09;二、卸载教程 ①、使…

hudi开启了流读,read.streaming.enabled为true,还需要设置查询类型吗 如snapshot

在使用 Apache Hudi 时&#xff0c;尤其是开启了流式读取&#xff08;read.streaming.enabled 为 true&#xff09;&#xff0c;配置查询类型非常重要。查询类型决定了如何读取数据&#xff0c;尤其是在处理更新和删除操作时。 查询类型选项 在 Hudi 中&#xff0c;常见的查询…

ViewModel原理分析

认识 ViewModel ViewModel 是一种用来存储和管理UI相关数据的类。 ViewModel 的作用可以从两个方面去理解&#xff1a; UI界面控制器&#xff1a;在最初的MVC模式中&#xff0c;由于 Activity / Fragment 承担的职责过重&#xff0c;因此在后续的 MVP、MVVM 模式中&#xff…

基于JSP技术的人事管理系统

你好呀&#xff0c;我是计算机学长猫哥&#xff01;如果有相关需求&#xff0c;文末可以找到我的联系方式。 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;JSP技术 工具&#xff1a;浏览器&#xff08;如360浏览器、谷歌浏览器、QQ浏览器等&#xff…