【WebGis开发 - Cesium】三维可视化项目教程---视点管理

news2024/10/6 11:20:52

目录

  • 引言
  • 一、基础功能探索
    • 1. 镜头视角获取
    • 2. 镜头视角移动
  • 二、进一步封装代码
    • 1. 封装hooks函数
    • 2. 看下效果
    • 3. 如何使用该hooks函数
  • 三、总结

引言

本教程主要是围绕Cesium这一开源三维框架开展的可视化项目教程。总结一下相关从业经验,如果有什么疑问或更好的见解,欢迎评论、私聊探讨,共同进步。

本篇主要讨论如何完成视点管理功能。视点(有的地方也叫收藏点)信息存储了特定视角的相机数据,可以将镜头移动至最佳视角观察三维场景。通常会有以下应用场景:

  • 三维场景的初始化视角,通常情况下三维可视化项目都是针对一个园区、片区、城市等多种范围而立项的。所以针对这些范围设置并保存一个最佳视角是非常重要的。
  • POI点保存视点信息,在一个范围内可能有多个亮点项目或独特建筑,设置POI点时绑定视点信息,通过点选POI点将镜头移动至最佳观察点。
  • 纯收藏功能,把一些项目好看的角度都保存下来并截图,提供汇报工作时演示。

一、基础功能探索

1. 镜头视角获取

在初始化Cesium场景后,通常会设置全局变量 viewer。我们通过 viewer.camera 来获取镜头信息。主要获取 positionheadingpitchroll 这四个属性:

  • position,笛卡尔坐标系下的相机位置坐标。
  • heading,表示左右摇头。
  • pitch,表示上下点头。
  • roll,表示左右歪头。一般情况下,为了减少用户眩晕感,将roll值默认为0。
{
	position:{
    	"x": -2392730.83864336,
    	"y": 5412946.353618708,
    	"z": 2439801.3235747567
	},
	heading: 6.283185307179586,
	pitch: -1.5695637657002988,
	roll: 0,
	// 其他信息
}

2. 镜头视角移动

这里使用 viewer.cameraflyTo 方法,控制视角移动至特定视角。

主要使用到两个参数:

  • destination,接收一个笛卡尔坐标系的x、y、z三参数对象。表示镜头目标坐标点。
  • orientation,偏航角(heading)、俯仰角(pitch)和倾斜角(roll)属性的对象,或包含方向(direction )和向上(up)属性的对象。一般使用前者。
  • 其他属性通过查阅cesium api示例研究。
  viewer.camera.flyTo({
    destination: {
      x: -2392668.884812449,
      y: 5404950.676815235,
      z: 2436590.0523108398,
    },
    orientation: {
      heading: 6.283185307179586,
      pitch: -1.5695637656997583,
      roll: 0,
    },
  });

至此你已经可以获取镜头数据以及控制镜头移动了。


二、进一步封装代码

先理清楚使用场景,需要一个获取视角的方法,一个设置视角的方法,最好可以告诉用户视角移动完成。

1. 封装hooks函数

解释下封装函数的内容

  • 设置 currentView 变量 ,用作响应式的赋值当前选中视点信息。
  • 设置 isFlying 变量,用于给定视角移动的标识。利用这一标识,可以规避一些误操作。
  • getView 函数,获取当前视角的镜头信息。只保留需要的部分,并返回字符串形式数据,用于业务存储数据
  • setView 函数,设置视角,返回promise对象。使用链式调用或者await,可以更方便的获得移动完成的时间点,方便进行下一步操作。同时支持自定义移动周期以及运动的缓动函数。
  • 其他参数在后续的深入研究后,结合业务场景判断是否需要集成到当前hooks函数中。

src/hooks 目录下添加 useViewManager.js 文件

import { ref } from "vue";

export const useViewManager = () => {
  // 当前获取的视点信息
  const currentView = ref(null);
  // 是否在视角移动过程中
  const isFlying = ref(false);
  /**
   * @description: 获取当前视点信息
   * @return { string } 返回当前视点信息,使用JSON.stringify转换为字符串
   */
  const getView = () => {
    const cameraData = viewer.camera;
    currentView.value = JSON.stringify({
      destination: cameraData.position.clone(),
      orientation: {
        heading: cameraData.heading,
        pitch: cameraData.pitch,
        roll: cameraData.roll,
      },
    });
    return currentView.value;
  };
  /**
   * @description: 设置视角
   * @param {*} view 视点信息,由getView方法获取的字符串
   * @param {*} duration 移动时间
   * @param {*} easingFunction 缓动函数
   * @return {*}
   */
  const setView = (view, duration = 1.5, easingFunction) => {
    return new Promise((resolve, reject) => {
      isFlying.value = true;
      const cameraData = JSON.parse(view);
      viewer.camera.flyTo({
        ...cameraData,
        duration,
        complete: () => {
          isFlying.value = false;
          resolve(true);
        },
        cancel: () => {
          isFlying.value = false;
          reject(false);
        },
        // 缓动函数枚举值参考链接: https://cesium.com/learn/cesiumjs/ref-doc/EasingFunction.html?classFilter=EasingFunction
        // 你也可以自己编写缓动函数,注意函数返回值在[0,1]区间内即可。
        easingFunction: easingFunction || Cesium.EasingFunction.LINEAR_NONE,
      });
    });
  };
  return {
    currentView,
    isFlying,
    getView,
    setView,
  };
};

2. 看下效果

在这里插入图片描述

3. 如何使用该hooks函数

以下为最基础的使用方式,通过两个点击按钮去获取、设置视角。在业务中注意结合数据存储、获取等操作,灵活使用。

<script setup>
import { useViewManager } from "@/hooks/useViewManager.js";
const { getView, setView, currentView, isFlying } = useViewManager();
let viewData = "";
// 获取视角点击事件
const getCamera = () => {
  viewData = getView();
};
// 设置视角点击事件
const setCamera = () => {
  setView(viewData , 2).then((res) => {
    console.log("fly complete ", res);
    // 执行其他操作
  });
};

// 设置视角点击事件(同步)
const setCameraSync = async () => {
  await setView(viewData , 2);
  console.log("fly complete ");
  // 执行其他操作
};
</script>

三、总结

本篇主要介绍了如何利用 viewer.cameraflyTo 完成了视点管理模块必备功能的hooks函数封装。完整的视点管理还需结合后台数据存储,业务数据绑定等等复杂逻辑,这就需要你自行判断如何将本篇的hooks函数应用到业务中去。

视点管理或是视角控制,是三维可视化项目中的重点功能。这个功能优化好了,可以让项目操作起来更加丝滑令人舒适。有一些可以探索优化的点:

  • 飞行路径的修正,目前是由cesium框架默认计算的飞行路径,没有进行人为干预,可以尝试 maximumHeightpitchAdjustHeightflyOverLongitudeflyOverLongitudeWeight 这几个参数去优化路径。
  • 飞行缓动效果优化,通过尝试 easingFunction 自行编写缓动函数,优化飞行速度。
  • 感兴趣可以一起讨论研究下。

再接再厉~

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

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

相关文章

SQL自用小结

推荐一下这个知识点总结 《数据库系统概论》第五版 学习笔记总目录 1. SQL概述 SQL&#xff08;Structured Query Language&#xff0c;结构化查询语言&#xff09;是一种用于定义、查询、更新和控制关系数据库的标准化语言。 它包含了数据定义语言&#xff08;DDL&#xff0…

(19)MATLAB使用Nakagami 分布对象生成Nakagami-m分布

文章目录 前言一、生成Nakagami分布随机变量的MATLAB代码1.仿真代码2.运行结果 二、传输信号经过衰落信道 前言 MATLAB在R2013a版本中开始引入Nakagami分布对象&#xff0c;可以用来生成Nakagami随机变量。下面给出一个使用实例&#xff0c;用于生成服从Nakagami 分布的随机变…

实战五:模拟10086查询功能

问题描述&#xff1a; 输入1&#xff0c;显示当前余额;输入2&#xff0c;显示当前的剩余流量&#xff0c;单位为G;输入3&#xff0c;显示当前的剩余通话&#xff0c;单位为分钟;输入0,退出自助查询系统。 编程&#xff1a; 1.方法一&#xff1a; # (1)初始化变量 answer y…

Java.数据结构.HashMap

目录 1基本概念 2数据结构 3常用操作 3.1 put(K key, V value)&#xff1a;插入键值对。 3.2 get(Object key)&#xff1a;根据键获取值。 3.3 remove(Object key)&#xff1a;移除键值对。 3.4 containsKey(Object key)&#xff1a;判断Map中是否包含指定的键。 3.5 c…

【Orange Pi 5 嵌入式应用编程】-用户空间SPI通信

用户空间SPI通信 文章目录 用户空间SPI通信1、理解SPI通信协议1.1 什么是SPI通信协议1.2 SPI如何工作?1.3 SPI数据传输步骤1.4 SPI的优缺点2、嵌入式Linux系统中的SPI通信3、Orange Pi 5 配置与编程3.1 Orange Pi 5开发板配置SPI3.2 SPI编程实现3.2.1 SPI用户空间函数定义3.2.…

Kafka 快速入门

目录 介绍 KafKa 相关术语 ​编辑 Kafka的工作流程 生产者向kafka发送数据的流程 Kafka选择分区的模式 Kafka选择分区的模式 数据消费 kafka的文件存储机制 topic、partition和segment 存储和查找message的过程 数据写入过程 数据查找过程 注意事项 kafka管理UI …

基于Springboot+Vue的高校学术交流平台 (含源码数据库)

1.开发环境 开发系统:Windows10/11 架构模式:MVC/前后端分离 JDK版本: Java JDK1.8 开发工具:IDEA 数据库版本: mysql5.7或8.0 数据库可视化工具: navicat 服务器: SpringBoot自带 apache tomcat 主要技术: Java,Springboot,mybatis,mysql,vue 2.视频演示地址 3.功能 系统中…

论文阅读笔记-LogME: Practical Assessment of Pre-trained Models for Transfer Learning

前言 在NLP领域,预训练模型(准确的说应该是预训练语言模型)似乎已经成为各大任务必备的模块了,经常有看到文章称后BERT时代或后XXX时代,分析对比了许多主流模型的优缺点,这些相对而言有些停留在理论层面,可是有时候对于手上正在解决的任务,要用到预训练语言模型时,面…

Spring Boot项目的创建与使用

1.通过IDE创建Spring Boot项目 2.目录结构 3.新建TestController控制器 Controller public class TestController {RequestMapping("/test")public ModelAndView test(RequestParam(name "name", defaultValue "刘德华") String name){ModelA…

Pikachu-unsafe upfileupload-getimagesize

什么是getimagesize()&#xff1f; getimagesize()是PHP中用于获取图像的大小和格式的函数。它可以返回一个包含图像的宽度、高度、类型和MIME类型的数组。 由于返回的这个类型可以被伪造&#xff0c;如果用这个函数来获取图片类型&#xff0c;从而判断是否时图片的话&#xff…

matplotlib字体警告

import matplotlib.pyplot as plt plt.rcParams[font.sans-serif] "Arial" plt.rcParams["figure.figsize"] (3, 3) plt.rcParams[font.size] 12sc.pl.umap(adata_concat, color[batch_name, Ground Truth, mclust], ncols3, wspace0.5, showTrue)结果如…

谷歌 DeepMind 发布 AlphaChip:AI 加速芯片设计,效率提升惊人!

近日&#xff0c;谷歌 DeepMind 公布了其最新的 AI 系统 ——AlphaChip。这一系统致力于加速和优化计算机芯片的开发&#xff0c;AlphaChip 所设计的芯片布局已经在谷歌的 AI 加速器中得到应用。 AlphaChip 的工作原理类似于我们之前所听说的 AlphaGo 和 AlphaZero&#xff0c…

NASA:北极植被地块 ATLAS 项目 北坡和苏厄德半岛,明尼苏达州,1998-2000 年

目录 简介 摘要 代码 引用 网址推荐 0代码在线构建地图应用 机器学习 Arctic Vegetation Plots ATLAS Project North Slope and Seward Peninsula, AK, 1998-2000 简介 文档修订日期&#xff1a;2018-12-31 数据集版本&#xff1a;1 本数据集提供了在北极陆地-大气系统…

模拟算法(5)_数青蛙

个人主页&#xff1a;C忠实粉丝 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 C忠实粉丝 原创 模拟算法(5)_数青蛙 收录于专栏【经典算法练习】 本专栏旨在分享学习算法的一点学习笔记&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; 目录 1. 题目链接…

Java项目实战II基于Java+Spring Boot+MySQL的房产销售系统(源码+数据库+文档)

目录 一、前言 二、技术介绍 三、系统实现 四、文档参考 五、核心代码 六、源码获取 全栈码农以及毕业设计实战开发&#xff0c;CSDN平台Java领域新星创作者 一、前言 随着房地产市场的蓬勃发展&#xff0c;房产销售业务日益复杂&#xff0c;传统的手工管理方式已难以满…

旅游平台|智慧旅游平台|基于java的智慧旅游平台设计与实现(源码+数据库+文档)

智慧旅游平台 目录 基于java的智慧旅游平台设计与实现 一、前言 二、系统功能设计 三、系统实现 四、数据库设计 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 八、源码获取&#xff1a; 博主介绍&#xff1a;✌️大厂码农|毕设布道师&#xff0c;阿里云开发…

[C++]使用纯opencv部署yolov11-pose姿态估计onnx模型

【算法介绍】 使用纯OpenCV部署YOLOv11-Pose姿态估计ONNX模型是一项具有挑战性的任务&#xff0c;因为YOLOv11通常是用PyTorch等深度学习框架实现的&#xff0c;而OpenCV本身并不直接支持加载和运行PyTorch模型。然而&#xff0c;可以通过一些间接的方法来实现这一目标&#x…

打造银行智能营销助手:大模型助力精准营销

在金融科技快速发展的时代&#xff0c;银行的业务模式和客户需求都发生了巨大变化。为了应对日益激烈的市场竞争&#xff0c;银行必须依托先进技术&#xff0c;提升客户服务水平和营销效率。银行智能营销助手应运而生&#xff0c;它通过结合知识图谱和大模型&#xff08;LLM&am…

Ubuntu22.04 Docker 国内安装最靠谱教程

目前docker在国内安装常存在众所周知的网络问题&#xff0c;如果安装过程如果从官网地址安装以及安装之后从官网要拉取镜像都存在问题。这篇文章主要针对这两个问题总结最靠谱的docker安装教程。 1. docker安装 1.1 系统环境概述 Ubuntu 22.04linux内核版本 6.8&#xff08;…

红帽操作系统Linux基本命令2( Linux 网络操作系统 06)

本文接着上篇Linux常用命令-1继续往后学习其他常用命令。 2.3 目录操作类命令 1&#xff0e;mkdir命令 mkdir命令用于创建一个目录。该命令的语法为&#xff1a; 上述目录名可以为相对路径&#xff0c;也可以为绝对路径。 mkdir命令的常用参数选项如下。 -p&#xff1a;在创…