简约版3D地球实现,多框架支持

上午UI丢了个动画给我让我实现在官网3.0上

但是大锅,这玩意是React库,咋们是vue2项目呀!!!

在网上搜索下后发现底层用的cobe这个库

那么一切就简单了起来直接参考官方给出的示例,下面是我封装的组件

下面是我安装的版本 "cobe": "^0.6.5" 注意我的项目是SSR,这个库esm格式的,所以需要在浏览器环境运行 这点要注意

js 复制代码
<template>
    <div
        ref="container"
        style="width: 400px; height: 400px; position: relative; overflow: hidden"
    ></div>
</template>

<script>
export default {
    name: 'Globe',
    data() {
        return {
            globe: null,
            width: 400,
            height: 400,
            phi: 0 // 用于控制旋转角度
        };
    },
    async mounted() {
        // 动态导入 cobe,仅在客户端执行
        // eslint-disable-next-line nuxt/no-env-in-hooks
        if (process.client) {
            const createGlobe = (await import('cobe')).default;
            
            // 创建 canvas
            const canvas = document.createElement('canvas');
            canvas.width = this.width * 2; // 高分辨率支持
            canvas.height = this.height * 2;
            canvas.style.width = this.width + 'px';
            canvas.style.height = this.height + 'px';
            this.$refs.container.appendChild(canvas);

            // 初始化 cobe 地球
            this.globe = createGlobe(canvas, {
                width: 800,
                height: 800,
                onRender: (state) => {
                    // 自动旋转动画
                    state.phi = this.phi;
                    this.phi += 0.005; // 控制旋转速度,值越大旋转越快
                },
                devicePixelRatio: 2,
                phi: 0,
                theta: 0.3,
                dark: 0,
                diffuse: 0.4,
                mapSamples: 16000,
                mapBrightness: 1.2,
                baseColor: [1, 1, 1],
                markerColor: [251 / 255, 100 / 255, 21 / 255],
                glowColor: [1, 1, 1],
                markers: [
                    { location: [14.5995, 120.9842], size: 0.03 },
                    { location: [19.076, 72.8777], size: 0.1 },
                    { location: [23.8103, 90.4125], size: 0.05 },
                    { location: [30.0444, 31.2357], size: 0.07 },
                    { location: [39.9042, 116.4074], size: 0.08 },
                    { location: [-23.5505, -46.6333], size: 0.1 },
                    { location: [19.4326, -99.1332], size: 0.1 },
                    { location: [40.7128, -74.006], size: 0.1 },
                    { location: [34.6937, 135.5022], size: 0.05 },
                    { location: [41.0082, 28.9784], size: 0.06 }
                ]
            });
        }
    },
    beforeDestroy() {
        // 清理资源
        if (this.globe && this.globe.destroy) {
            this.globe.destroy();
        }
    }
};
</script>

<style scoped>
/* 可选:让背景更干净 */
div[ref='container'] {
    display: flex;
    justify-content: center;
    align-items: center;
    background: transparent;
}
</style>

我的是vue2版本,算是补充,效果如下

官网给出了其他的写法

相关推荐
摸鱼仙人~16 分钟前
Vue Todo 实战练习教程(简略版)
前端·javascript·vue.js
dzj88817 分钟前
云朵字生成器-html
前端·css·html·云朵字
FlyWIHTSKY22 分钟前
Vue 3 单文件组件加载顺序详解
前端·javascript·vue.js
霪霖笙箫29 分钟前
真授之以渔:我是怎么从"想给文章配几张图",一步步做出一个可发布 skill 的
前端·人工智能·开源
yzin32 分钟前
【源码】【react】useCallback、useMemo、memo 原理
前端·react.js
CHU72903532 分钟前
扭蛋机盲盒小程序前端功能设计及核心玩法介绍
前端·小程序
毛骗导演35 分钟前
OpenClaw Gateway RPC 运行时:一个 WebSocket 协议引擎的深度解剖
前端·架构
码路飞36 分钟前
不会 Rust 也能玩 WebAssembly:3 个 npm install 就能用的 WASM 神器
前端·javascript·webassembly
sudo_jin37 分钟前
从“输入网址”到“帧级控制”:我对事件循环与主线程管理的终极认知
前端·javascript
flyfox37 分钟前
Kiro AI IDE 深度使用指南:从入门到高效开发
前端·人工智能·ai编程