查看旋转地球效果 主要用到几个知识点 (1)显示文字是使用了three.js 的精灵(Sprite),精灵的文字方向始终面向相机,文字是在canvas中画的,精灵的材质就是加载的带有文字的canvas...DOCTYPE html> 旋转地球 <script src="assets...THREE.DirectionalLight(0xffffbb, 1); // light.position.set(-1, 1, 1); // scene.add(light); } // <em>地球</em>...scene.remove(sprite) showSprite(); controls.update(); //stats.update(); // <em>地球</em>自转
说明:这个不是GIS软件,是一个带地形的三维地球。...可在线加载全球地形,也可离线运行,运行流畅无卡顿,占用内存小,最大等级可达到地图20级 本数字地球全部由作者自由开发完成,未使用任何第三方插件,拥有完全知识产权。...视频Unity3d版数字地球、谷歌地球(google earth)_哔哩哔哩_bilibili 更新说明: 2021年12月15日更新:日出、日落、大气散射、蓝天效果。...另外,可用于数据可视化的地球见我的另一篇博客:Unity3d版数字地球、大数据可视化地球_zouxin_88的专栏-CSDN博客 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。
概述 许久未更新,这一篇是凑数的,用最新的mapboxGL2.10的版本实现一个旋转的地球的效果。...ctx.beginPath(); ctx.arc(half, half, half, 0, Math.PI * 2); ctx.fill(); } } 旋转的地球的实现比较简单
移动旋转物体可以使用Three.js提供的OrbitControls.js,也可以手动写控制器。 原理:获取鼠标点击的位置与移动的距离,根据移动的距离计算出大概旋转的角度。...查看旋转效果 <script src=".....geometry = new THREE.PlaneBufferGeometry(200, 200); geometry.rotateX(-Math.PI / 2); //从右边看顺时针<em>旋转</em>...false); //按下去的时候鼠标相对位置 mouseXOnMouseDown = event.layerX - windowHalfX; //鼠标按下的<em>旋转</em>角度...onDocumentMouseMove(event) { //移动的时候鼠标相对位置 mouseX = event.layerX - windowHalfX; //移动的时候<em>旋转</em>的角度
No 图 No Code,上面旋转的地球是不是很酷炫,下面就让我们开始说说如何绘制旋转地球吧?绘制旋转地球需要3个步骤: 计算球体顶点数据。 地球纹理贴图。 通过MVP矩阵旋转地球。...最难的顶点坐标和纹理坐标已经获取,下面开始介绍如何绘制地球。...地球纹理贴图 地球纹理图片如下: ? 将地球图片转为纹理,代码如下: override fun onSurfaceCreated(p0: GL10?, p1: EGLConfig?)...Matrix.frustumM(projectionMatrix, 0, -ratio, ratio, -1f, 1f, 3f, 20f) } 绘制并通过MVP矩阵旋转地球...,我们经常听说的天空穹、全景(VR)球体模式和地球的绘制基本一样,只不过是相机位置的不同而已。
Planetary.js 是一款生成可交互地球模型的插件。 简介 Planetary.js 可以生成一个性能(UI)良好可交互的地球。...官网:http://planetaryjs.com/ Github:https://github.com/BinaryMuse/planetary.js 特点 完全可定制,包括颜色,旋转等等 在任何具有自定义颜色和大小的位置显示动画...tree/master/dist 使用方法 拿到文件后可以放在静态网页的某个文件夹,也可以放到自己的图床里,也可以直接引用原始的 js 文件,总之可以访问到就可以 注意 :直接本地运行是不能显示地球的...planet.projection.rotate(rotation); lastTick = now; } }); }; };})(); 之后可以加入数据来让他展示指定地球上的位置
经过前面几个章节的介绍,我们对Threejs已经有了一个相对深入的了解,下面我们通过Threejs来做一个旋转的地球效果。...水平分段数和垂直分段数参数const geometry = new THREE.SphereGeometry(150,32,32)创建材质 这里使用MeshPhongMaterial创建材质,并加载images中准备好的地球材质...webgl').appendChild(renderer.domElement)创建循环调用函数 创建animation函数,在函数里面调用earth.rotation.y += 0.01,使其每次渲染都旋转...requestAnimationFrame(animation) earth.rotation.y += 0.01 renderer.render(scene,camera)}animation()保存,刷新浏览器,可以看到一个漂亮的地球已经渲染到浏览器...,并自动旋转 至此,旋转的地球已经创建完成,完整的代码和地球贴图材质可以通过以下地址下载:https://download.csdn.net/download/w137160164/87650456核心代码如下
今天郭先生说说对象如何绕任意轴旋转。...说一说其中一种方法,也是比较容易理解的一种,它的原理就是将子对象放到一个盒子中,然后改变子对象相对于父对象的位置(因为子对象的原点默认还是在盒子的中心),最后转动盒子,这样子对象的旋转就不是绕盒子的中心了...在线案例点击模拟门旋转。 image.png 说到这里就不得不说THREE.Group对象了,除了isGroup和type这两个属性,它几乎和Object3D是相同的。
由于它作为 Geometry() 的容器,它还可以用于操纵位置、旋转等。 ...... 组件利用 Three.js Texture() 类,它让我们可以将逼真的纹理映射到引擎盖下的网格表面。 为了演示这个过程,我们将创建一个地球的 3D 模型。...使用此函数,我们可以通过在每一帧上为其旋转属性添加一个值来为我们的地球设置动画。...你可以通过将 x 和 z 属性添加到 ref、onBeforeRender 函数和地球的网格来添加更多旋转动画。...为了演示,我们将添加一个 click 事件,当它被触发时会暂停我们的地球动画。
本文是three.js系列博文的一篇,第一篇文章是【three.js基础知识】,如果你还没有阅读过,可以从这一篇开始,页面顶部可以切换为中文或英文。...three.js中最核心的部分可能就是scene graph(或称为场景节点图)。3D引擎中的scene graph是一个表示继承关系的节点图谱,图谱中的每个节点都表示了一个本地坐标空间。 ?...月亮绕着地球做圆周运动,从月球的视角来观察时,它是在地球的”本地坐标空间“中进行旋转的,然而如果相对于太阳的“本地坐标空间”来看,月球的运动轨迹就会变成非常复杂的螺旋线。...有时候我们需要一些辅助线以便可以更好地观察scene graph中的实体,three.js中提供了一些有用的工具。...我们将使用dat.GUI工具,它是一个非常流行的UI库,通常在three.js项目中使用。dat.GUI使用一个配置对象,将属性名和属性值的类型添加后,它将自动生成一个可以动态调整这些参数的UI。
前言 头一阵子B站,抖音都被 陶大宇大哥的倒转地球刷屏了,终于热度下去了,不用倒转头七了。 真的和地球扛上了,公司的大屏项目需要科技感的地球、飞线图。...目标设计样子: 实现步骤分解: ThreeJS环境初始化 星空背景 添加带纹理的地球 世界地图轮廓边界绘制 地球光晕 添加地球云层 城市位置标注和涟漪效果 添加飞线B样条 地球自转和镜头缩放动画 初始化...因为地球元素比较多,且需要转动,所以是一个3dobject对象,添加多个mesh。...地球光晕其实是一个精灵贴图,这里放了两层,下面放一张看下。...云层效果不是一个精灵,它是相当于在地球上又套了一个圆球,半径比地球大一点。
接上篇:一个基于ThreeJS 实现的漂亮的3D 地球制作过程详解(上篇) 3D 地球成果展示 github仓库地址:https://github.com/RainManGO/3d-earth npm...实现过程 实现步骤分解: ThreeJS环境初始化 星空背景 添加带纹理的地球 世界地图轮廓边界绘制 地球光晕 添加地球云层 城市位置标注和涟漪效果 添加飞线B样条 地球自转和镜头缩放动画 接上篇从第七步骤说起...(longitude * Math.PI) / 180; //转弧度值 var lat = (latitude * Math.PI) / 180; //转弧度值 lon = -lon; // three.js...旋转动画的原理主要是利用tween 动画,然后更新地球位置和轨道控制器的zoom 。...tween 动画控制旋转和缩放 旋转到中国的时候缩放 具体代码如下: //旋转地球动画 var rotateEarthStep = new TWEEN.Tween({ rotateY
图像的一个像素覆盖30平方米的地面区域,卫星的摄像头与地球垂直。现在,有些卫星的分辨率可以做到小于一米,但一般来说,它们的数据不能免费获得。...Three.js Three.js是一个优秀的JS库,使WebGL更易于使用WebGL。...不要忘记旋转对象,因为three.js采用右手坐标系,这意味着,默认情况下,Z轴不是朝上而是指向你。关于这一点的详细解释可以查看这里。...= -100; mountain.rotation.x = Math.PI / 2; this.scene.add(mountain); 你可以在开始时使用camera.up.set(0,0,1)旋转...x 轴或旋转相机,然后在上面放置山的模型,沿y 轴向下移动一点点,稍微调整下,就可以了。
先看一下实例 gif: tl;dr; 使用 three.js 实现全景技术 UV 映射原理简介 3D 坐标原理和移动控制 Web 陀螺仪简介 iv-panorama 简单库介绍 基于 Three.js...全景没有 VR 那种沉浸式体验,单单只涉及三个维度上的旋转而没有移动距离这个说法。...下面是最简代码: 这里主要模拟地球坐标: lat 代表维度(latitude): 用户上下滑动改变的值,或者手机上下旋转 lon 代表经度(lontitude): 用户左右滑动改变的值,或者手机左右旋转...简单来说,陀螺仪的参数在标准情况下,手机有两份坐标: 地球坐标 x/y/z:在任何情况下,都是恒定方向 手机平面坐标 x/y/z:相当于手机屏幕定义的方向 以手机本身为坐标点,地球坐标如图所示: x:...其主要特性为: 依赖于 Three.js,需要预先挂载到 window 对象上 灵活配置,内置支持陀螺仪和 touch 控制。
tl;dr; 使用 three.js 实现全景技术 UV 映射原理简介 3D 坐标原理和移动控制 Web 陀螺仪简介 iv-panorama 简单库介绍 基于 Three.js 全景视频是基于 3D 空间...全景没有 VR 那种沉浸式体验,单单只涉及三个维度上的旋转而没有移动距离这个说法。...: lat 代表维度(latitude): 用户上下滑动改变的值,或者手机上下旋转 lon 代表经度(lontitude): 用户左右滑动改变的值,或者手机左右旋转 具体内容为: ?...简单来说,陀螺仪的参数在标准情况下,手机有两份坐标: 地球坐标 x/y/z:在任何情况下,都是恒定方向 手机平面坐标 x/y/z:相当于手机屏幕定义的方向 以手机本身为坐标点,地球坐标如图所示: ?...其主要特性为: 依赖于 Three.js,需要预先挂载到 window 对象上 灵活配置,内置支持陀螺仪和 touch 控制。
---- 为什么要使用three.js 要回答为什么要使用three.js?首先我们想想什么是three.js?...而three.js直接支持前3种渲染方式,可以看出three.js的强大。 大多情况下如果是为了展示3D的效果,那么直接用图片就可以了,如果要动起来的话,视频往往可以胜任。...别急,正因为原生的WebGL这么晦涩难懂,所以才有了我们的主角three.js。...现在你可以忘掉上面的内容,因为three.js封装的特别好,根本看不到任何WebGL的影子,你再也不需要去了解什么着色器,更不用写GLSL ES,我们先来看一个更高级且更简单的three.js的例子。...初识three.js three.js可以使用模块化引入,当然也可以直接用script标签来引入。
阿谀奉承而无所图的人极少;爱奉承的话,就免不了要付出代价——佚名 一个js的3D库 git仓库:https://github.com/mrdoob/three.js 官网:https://threejs.org
Gio.js 是一个基于Three.js的web 3D地球数据可视化的开源组件库。...Github 链接: https://github.com/syt123450/giojs/blob/master/README_zh.md 为什么要使用Gio.js Gio.js 是一个基于Three.js...的web 3D地球数据可视化的开源组件库。...3D前端应用 开始使用 安装 途径1: 标签 在HTML页面的部分引入 Three.js 依赖: 在HTML...-- 引入three.js --> <!
Three.js 是一款运行在浏览器中的 3D 引擎,你可以用它创建各种三维场景,包括了摄影机、光影、材质等各种对象。你可以在它的主页上看到许多精采的演示。...Three.js是一个伟大的开源WebGL库,WebGL允许JavaScript操作GPU,在浏览器端实现真正意义的3D。...Three.js的核心五步就是: 1.设置three.js渲染器 2.设置摄像机camera 3.设置场景scene 4.设置光源light 5.设置物体object 1.设置three.js渲染器 三维空间里的物体映射到二维平面的过程被称为三维渲染...//设置Three.js渲染器 var renderer; function initThree(){ width = document.getElementById...在Three.js也能够指定透视投影和正投影两种方式的相机。 本文按照以下的步骤设置透视投影方式。
前言 笔者认为Three.js是一个伟大的框架,为什么这样说,因为它可以让我们轻易创造三维世界,甚至好像笔者写这遍教程,可以创造一个太阳系,在这个三维世界里你就是创世主。哈哈!好像说得有点夸!!...] 了解Three框架 Three的一些基本概念我在用最简单方式打造Three.js 3D汽车展示厅一文也粗略介绍一下,为了让同学们加深理解,笔者就相对于太阳系来比如一下 场景 Sence 相当于太阳系...:实现旋转功能有三种方式 旋转照相机 旋转整个场景(Scene) 旋转单个元素 因为我们这里每个行星的自转速度,公转速度都不一样。...所以设置整体旋转并不可行,所以要给每个元素设置不同的旋转属性。 行星需要让它们围绕着太阳转,就要先给它们自身设置一个位置偏移。...也会绕着初始的默认Y轴旋转。
领取专属 10元无门槛券
手把手带您无忧上云