Commit c8f58eb5 by jlc

update:相机缩放案例代码的修改

parent f7c3057c
let viewer; export function zoomByBound(viewer, flag){
export function addCameraZoom() {
const script = document.createElement('script');
script.src = 'https://cesium.com/downloads/cesiumjs/releases/1.99/Build/Cesium/Cesium.js';
script.onload = () => {
window.Cesium.Ion.defaultAccessToken = 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJqdGkiOiI3Njg4ZWU5Yi1iZDhiLTRhYmUtOTRiYS04YjM5NmUwNjVmMDMiLCJpZCI6MjI3MzQ3LCJpYXQiOjE3MjA1MjA4Mjh9.E5XW4LnwgfVAaBC-znaYr61m4yK0-j2qEQhi9qwFFPE'
viewer = new window.Cesium.Viewer('cesiumContainer', {
infoBox: false,
});
};
document.head.appendChild(script);
const link = document.createElement('link');
link.rel = 'stylesheet';
link.href = 'https://cesium.com/downloads/cesiumjs/releases/1.119/Build/Cesium/Widgets/widgets.css';
document.head.appendChild(link);
}
// 获取视图中心点
function pickCenter() {
var ellipsoid = viewer.camera.pickEllipsoid(new Cesium.Cartesian2( var ellipsoid = viewer.camera.pickEllipsoid(new Cesium.Cartesian2(
viewer.canvas.clientWidth / 2, viewer.canvas.clientWidth / 2,
viewer.canvas.clientHeight / 2)); viewer.canvas.clientHeight / 2));
var curPosition = Cesium.Ellipsoid.WGS84.cartesianToCartographic(ellipsoid); var curPosition = Cesium.Ellipsoid.WGS84.cartesianToCartographic(ellipsoid);
var lon = curPosition.longitude * 180 / Math.PI; var lon = curPosition.longitude * 180 / Math.PI;
var lat = curPosition.latitude * 180 / Math.PI; var lat = curPosition.latitude * 180 / Math.PI;
return {
lon: lon,
lat: lat
};
}
export function zoomByBound(flag){
const center = pickCenter()
var height = viewer.camera.positionCartographic.height; var height = viewer.camera.positionCartographic.height;
const camera = viewer.camera; const camera = viewer.camera;
var boundingSph = new Cesium.BoundingSphere(Cesium.Cartesian3.fromDegrees(center.lon, center.lat, 1000), height); var boundingSph = new Cesium.BoundingSphere(Cesium.Cartesian3.fromDegrees(lon, lat, 1000), height);
var moveRate = 0; var moveRate = 0;
if(flag){ if(flag){
moveRate = 0.5 moveRate = 0.5
......
<template> <template>
<div id="cesiumContainer" class="cesium-container"></div> <div id="cesiumContainer" class="cesium-container"></div>
<div class="btn-class"> <div class="btn-class">
<button @click="zoomByBound(1)">放大相机视角</button> <button @click="zoomByBound(viewer, 1)">放大相机视角</button>
<button @click="zoomByBound(0)">缩小相机视角</button> <button @click="zoomByBound(viewer, 0)">缩小相机视角</button>
</div> </div>
</template> </template>
<script setup> <script setup>
import { onMounted } from 'vue'; import { onMounted } from 'vue';
import { addCameraZoom, zoomByBound } from './function'; import { zoomByBound } from './function';
let viewer;
onMounted(() => { onMounted(() => {
addCameraZoom() const script = document.createElement('script');
script.src = 'https://cesium.com/downloads/cesiumjs/releases/1.99/Build/Cesium/Cesium.js';
script.onload = () => {
window.Cesium.Ion.defaultAccessToken = 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJqdGkiOiI3Njg4ZWU5Yi1iZDhiLTRhYmUtOTRiYS04YjM5NmUwNjVmMDMiLCJpZCI6MjI3MzQ3LCJpYXQiOjE3MjA1MjA4Mjh9.E5XW4LnwgfVAaBC-znaYr61m4yK0-j2qEQhi9qwFFPE'
viewer = new window.Cesium.Viewer('cesiumContainer', {
infoBox: false,
});
};
document.head.appendChild(script);
const link = document.createElement('link');
link.rel = 'stylesheet';
link.href = 'https://cesium.com/downloads/cesiumjs/releases/1.119/Build/Cesium/Widgets/widgets.css';
document.head.appendChild(link);
}); });
</script> </script>
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment