vue2安装cesium并使用

一、安装

1.安装cesium

javascript 复制代码
npm install cesium@1.95.0 -S

2.安装所需

javascript 复制代码
npm install copy-webpack-plugin@10.2.4 -D

二、配置

1.配置vue.config.js

vue 中引入cesium 需要用copy-webpack-plugin 把一些文件拷贝到打包目录

javascript 复制代码
// vue.config.js
const CopyWebpackPlugin = require("copy-webpack-plugin");
const webpack = require("webpack");


const path = require("path"); //引入path模块
function resolve(dir) {
  return path.join(__dirname, dir); //path.join(__dirname)设置绝对路径
}
module.exports = {
  lintOnSave: false,
  // publicPath: '/xayw_jc',
  productionSourceMap: false, //关闭 SourceMap,webpack://
  // publicPath:
  //   process.env.NODE_ENV === "production" ? "/\n" + "vue-cesium-example/" : "/",
  configureWebpack: {
    resolve: {
      alias: {
        "@": resolve("src"),
      },
    },
    plugins: [
      // Copy Cesium Assets, Widgets, and Workers to a static directory
      new CopyWebpackPlugin({
        patterns: [{
          from: "node_modules/cesium/Build/Cesium/Workers",
          to: "Workers"
        },
        {
          from: "node_modules/cesium/Build/Cesium/ThirdParty",
          to: "ThirdParty",
        },
        {
          from: "node_modules/cesium/Build/Cesium/Assets",
          to: "Assets"
        },
        {
          from: "node_modules/cesium/Build/Cesium/Widgets",
          to: "Widgets"
        },
        ],
      }),
      new webpack.DefinePlugin({
        // Define relative base path in cesium for loading assets
        CESIUM_BASE_URL: JSON.stringify(""),
      }),

      // new BundleAnalyzerPlugin() //解开可查看项目打包分布情况
    ],
    module: {
      // Removes these errors: "Critical dependency: require function is used in a way in which dependencies cannot be statically extracted"
      // https://github.com/AnalyticalGraphicsInc/cesium-webpack-example/issues/6
      unknownContextCritical: false,
      unknownContextRegExp: /\/cesium\/cesium\/Source\/Core\/buildModuleUrl\.js/,
      rules: [
        {
          test: /\.mjs$/,
          include: /node_modules/,
          type: "javascript/auto"
        },
      ]
    },
  },
  chainWebpack: (config) => {
    config.module.rule("svg").exclude.add(resolve("src/icons")).end();
    config.module
      .rule("icons")
      .test(/\.svg$/)
      .include.add(resolve("src/icons"))
      .end()
      .use("svg-sprite-loader")
      .loader("svg-sprite-loader")
      .options({
        symbolId: "icon-[name]",
      })
      .end();
  },
};

2.配置css

①高版本的cesium引入widgets.css会报错,需要到node_modules/cesium/package.json添加

javascript 复制代码
 "./widgets.css":"./Source/Widgets/widgets.css",

②main.js引入

javascript 复制代码
import 'cesium/widgets.css';

3.获取Access Tokens

cesium 网站获取token,并复制到项目中

三、开发

cesium页面代码如下

javascript 复制代码
<template>
  <div id="cesiumContainer">
  </div>
</template>
<script>
import * as Cesium from 'cesium'
export default {
  name: 'HelloWorld',
  mounted(){
  this.initCesium()
  },
  methods:{
    initCesium (){
      Cesium.Ion.defaultAccessToken = "网站复制的token"
      let viewer = new Cesium.Viewer('cesiumContainer')
    }
  }
}
</script>
<style scoped>
 
</style>

运行效果如下

相关推荐
用你的胜利博我一笑吧8 天前
supermap iclient3d for cesium中entity使用
前端·javascript·vue.js·3d·cesium·supermap
敲敲敲敲暴你脑袋8 天前
【cesium】绘制贴地线面和自定义Primitive
javascript·webgl·cesium
用你的胜利博我一笑吧13 天前
vue3+ts+supermap iclient3d for cesium功能集合
前端·javascript·vue.js·3d·cesium·supermap
涛涛英语学不进去1 个月前
3D Tiles的4x4的仿射变换矩阵
线性代数·3d·矩阵·cesium·3d tiles
GIS瞧葩菜1 个月前
Cesium.ScreenSpaceEventHandler是 CesiumJS 中用于处理屏幕空间事件(如鼠标点击、移动、滚轮等)的工具
前端·javascript·cesium
BJ-Giser1 个月前
cesium 水波纹扩散圆材质
前端·javascript·cesium
激动的兔子1 个月前
使用Vue创建cesium项目模版该如何选择?
vue.js·cesium
BJ-Giser1 个月前
Cesium 视频纹理
前端·javascript·cesium
BJ-Giser1 个月前
Cesium 视频投射
前端·javascript·cesium
柳晓黑胡椒1 个月前
cesium 实现批量divpoint气泡,及气泡碰撞测试与自动避让
cesium·divpoint·碰撞测试