Versão, eu uso cli4.5 e Cesium1.74
1. Crie um projeto vue
vue create 项目名
2. Instale o césio
Insira o diretório do projeto, insira o seguinte código
npm install cesium
3. Crie o arquivo vue.config.js
Crie um arquivo vue.config.js no diretório raiz do projeto e copie o código a seguir para o arquivo
const CopyWebpackPlugin = require('copy-webpack-plugin')
module.exports = {
configureWebpack: {
plugins: [
new CopyWebpackPlugin([{
from: 'node_modules/cesium/Build/Cesium/Workers', to: 'Workers' }]),
new CopyWebpackPlugin([{
from: 'node_modules/cesium/Build/Cesium/ThirdParty', to: 'ThirdParty' }]),
new CopyWebpackPlugin([{
from: 'node_modules/cesium/Build/Cesium/Assets', to: 'Assets' }]),
new CopyWebpackPlugin([{
from: 'node_modules/cesium/Build/Cesium/Widgets', to: 'Widgets' }])
]
}
}
- Criar arquivo CesiumDemo.vue
Observação: você precisa registrar uma conta em https://cesium.com/ion/tokens com antecedência, obter o token e modificar o token em Cesium.Ion.defaultAccessToken.
Crie o arquivo CesiumDemo.vue no diretório de componentes e insira o seguinte código
<template>
<div id="cesiumContainer"></div>
</template>
<script>
window.CESIUM_BASE_URL = '/'
import * as Cesium from 'cesium'
import 'cesium/Build/Cesium/Widgets/widgets.css'
export default {
name: 'CesiumDemo',
mounted() {
// Your access token can be found at: https://cesium.com/ion/tokens.
Cesium.Ion.defaultAccessToken = '自己的token'
// Initialize the Cesium Viewer in the HTML element with the "cesiumContainer" ID.
const viewer = new Cesium.Viewer('cesiumContainer', {
terrainProvider: Cesium.createWorldTerrain()
})
// Add Cesium OSM Buildings, a global 3D buildings layer.
// const buildingTileset = viewer.scene.primitives.add(Cesium.createOsmBuildings())
// Fly the camera to San Francisco at the given longitude, latitude, and height.
viewer.camera.flyTo({
destination: Cesium.Cartesian3.fromDegrees(-122.4175, 37.655, 400),
orientation: {
heading: Cesium.Math.toRadians(0.0),
pitch: Cesium.Math.toRadians(-15.0)
}
})
}
}
</script>
<style></style>
- Execute o projeto
npm run serve