🌏【cesium系列】01.vue3+vite集成Cesium

版本:

  • cesium: ^1.128.
  • vite-plugin-cesium:^1.2.23
  • vue:^3.5.13
  • node:v22.13.0
  • pnpm:10.5.0

前言

有开发过web gis项目的同学,对于cesium应该不陌生,本文主要介绍如何在vue3项目中使用cesium,并且进行一些初始化的设置。

最终效果如下:

安装依赖

shell 复制代码
pnpm add  cesium
pnpm add vite-plugin-cesium

vite-plugin-cesium:这个插件是专门为vite定制的cesium插件。辅助我们在vite中使用cesium

可以不安装,但是不安装你就要额外配置很多东西,建议安装。

修改vite.coinfig.ts

js 复制代码
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import cesium from 'vite-plugin-cesium'
import path from 'path'
export default defineConfig({
  plugins: [vue(), cesium()],
  resolve: {
    alias: {
      '@': path.resolve(__dirname, 'src')
    }
  }
})

vite.config.js配置vite-plugin-cesium插件

创建场景

上面的步骤中,已经成功将cesium集成到我们的vue项目中了,接下来就可以使用了。

vue 复制代码
<template>
  <div class="cesium">
    <div class="cesium-container" id="cesiumMap"></div>
  </div>
</template>

<script setup lang="ts">
import { onMounted } from 'vue'
import { Viewer } from 'cesium'

onMounted(() => {
  const viewer: Viewer = new Viewer('cesiumMap')
  console.log('👉 ~ onMounted ~ viewer:', viewer)
})
</script>

<style lang="scss" scoped>
.cesium {
  position: relative;
  height: 100%;
  width: 100%;
  display: flex;
}
.cesium-container {
  position: relative;
  height: calc(100vh - 64px);
  width: 100%;
  :deep(.cesium-viewer-bottom) {
    display: none;
  }
}
</style>

这里就成功创建了三维场景

删除多余控件

ts 复制代码
const optons: { [x: string]: boolean } = {
    geocoder: false, // 地理编码控件不显示
    homeButton: false, // 默认相机位置控件不显示
    sceneModePicker: false, // 场景模式控件不显示
    baseLayerPicker: false, // 基础图层控件不显示
    navigationHelpButton: false, // 导航帮助控件不显示
    animation: false, // 动画控件不显示
    timeline: false, // 时间线控件不显示
    fullscreenButton: false, // 全屏控件不显示
    vrButton: false, // vr控件不显示
    infoBox: false, // 信息框控件不显示,点击要素后不弹出信息栏
    selectionIndicator: false // 选择跟踪控件不显示,点击要素后不弹出锁定框
  }
  const viewer: Viewer = new Viewer('cesiumMap', optons)
  console.log('👉 ~ onMounted ~ viewer:', viewer)

关闭不需要的控件之后整个场景就干净了。

结尾

操作很简单,只需要几步,我们就能成功创建一个cesium的三维场景。其他的设置视角、坐标系、中心点等更加定制化的功能就没有介绍了。

相关推荐
Nan_Shu_61411 分钟前
学习:uniapp全栈微信小程序vue3后台(28)
前端·学习·微信小程序·小程序·uni-app
珍宝商店21 分钟前
原生 JavaScript 方法实战指南
开发语言·前端·javascript
蓝莓味的口香糖32 分钟前
【企业微信】VUE项目在企微中自定义转发内容
前端·vue.js·企业微信
IT_陈寒32 分钟前
告别低效!用这5个Python技巧让你的数据处理速度提升300% 🚀
前端·人工智能·后端
—Qeyser34 分钟前
Laravel + UniApp AES加密/解密
前端·uni-app·laravel
C++chaofan36 分钟前
游标查询在对话历史场景下的独特优势
java·前端·javascript·数据库·spring boot
cg.family38 分钟前
Vue3 v-slot 详解与示例
前端·javascript·vue.js
FreeBuf_1 小时前
新型域名前置攻击利用Google Meet、YouTube、Chrome及GCP构建流量隧道
前端·chrome
c0detrend1 小时前
技术架构设计:如何打造一个高性能的Chrome截图插件
前端·chrome
幽络源小助理1 小时前
8、幽络源微服务项目实战:前端登录跨域同源策略处理+axios封装+权限的递归查询增删改+鉴权测试
前端·微服务·架构