Planetary.js 是一款生成可交互地球模型的插件。 简介 Planetary.js 可以生成一个性能(UI)良好可交互的地球。...官网:http://planetaryjs.com/ Github:https://github.com/BinaryMuse/planetary.js 特点 完全可定制,包括颜色,旋转等等 在任何具有自定义颜色和大小的位置显示动画...支持鼠标拖动+缩放操作 可扩展的基于插件的架构 效果展示 先看效果吧 (function() { var canvas = document.getElementById('quakeCanvas.../dist 使用方法 拿到文件后可以放在静态网页的某个文件夹,也可以放到自己的图床里,也可以直接引用原始的 js 文件,总之可以访问到就可以 注意 :直接本地运行是不能显示地球的,需要在 web...planet.projection.rotate(rotation); lastTick = now; } }); }; };})(); 之后可以加入数据来让他展示指定地球上的位置
概述 许久未更新,这一篇是凑数的,用最新的mapboxGL2.10的版本实现一个旋转的地球的效果。...实现效果 实现 为效果好一点,添加了一个canvas的星空动画,实现代码如下: class Star { constructor(canvas, gradientImage, maxStars...100) { this.ctx = canvas.getContext('2d') this.gradientImage = gradientImage //星星移动的半径...this.orbitX = canvas.width / 2; this.orbitY = canvas.height / 2; //利用正弦余弦算出真正的x、y位置...ctx.beginPath(); ctx.arc(half, half, half, 0, Math.PI * 2); ctx.fill(); } } 旋转的地球的实现比较简单
查看旋转地球效果 主要用到几个知识点 (1)显示文字是使用了three.js 的精灵(Sprite),精灵的文字方向始终面向相机,文字是在canvas中画的,精灵的材质就是加载的带有文字的canvas...DOCTYPE html> 旋转地球 <style type="text...(-1, 1, 1); // scene.add(light); } // <em>地球</em> var earthMesh; function initEarth()
老 孟 一个 有态度 的程序员 ? No 图 No Code,上面旋转的地球是不是很酷炫,下面就让我们开始说说如何绘制旋转地球吧?绘制旋转地球需要3个步骤: 计算球体顶点数据。 地球纹理贴图。...通过MVP矩阵旋转地球。...最难的顶点坐标和纹理坐标已经获取,下面开始介绍如何绘制地球。...generateSphere方式就是开始介绍的顶点数据生成的方法。 地球纹理贴图 地球纹理图片如下: ?...,我们经常听说的天空穹、全景(VR)球体模式和地球的绘制基本一样,只不过是相机位置的不同而已。
经过前面几个章节的介绍,我们对Threejs已经有了一个相对深入的了解,下面我们通过Threejs来做一个旋转的地球效果。....拷贝资源,将Threejs源码中的three.module.js拷贝到js文件夹,将地图的贴图文件拷贝到images文件夹 3.用vscode打开earth文件夹,在根目录下新建index.html文件...水平分段数和垂直分段数参数const geometry = new THREE.SphereGeometry(150,32,32)创建材质 这里使用MeshPhongMaterial创建材质,并加载images中准备好的地球材质.../images/earth.js')})创建物体 创建网格对象并使用上面创建的几何体和材质作为参数传给对象,设置对象的坐标位置,并将其添加到场景中const earth = new THREE.Mesh...,并自动旋转 至此,旋转的地球已经创建完成,完整的代码和地球贴图材质可以通过以下地址下载:https://download.csdn.net/download/w137160164/87650456核心代码如下
大家好,又见面了,我是你们的朋友全栈君。 说明:这个不是GIS软件,是一个带地形的三维地球。...可在线加载全球地形,也可离线运行,运行流畅无卡顿,占用内存小,最大等级可达到地图20级 本数字地球全部由作者自由开发完成,未使用任何第三方插件,拥有完全知识产权。...视频Unity3d版数字地球、谷歌地球(google earth)_哔哩哔哩_bilibili 更新说明: 2021年12月15日更新:日出、日落、大气散射、蓝天效果。...另外,可用于数据可视化的地球见我的另一篇博客:Unity3d版数字地球、大数据可视化地球_zouxin_88的专栏-CSDN博客 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。...如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
前言 头一阵子B站,抖音都被 陶大宇大哥的倒转地球刷屏了,终于热度下去了,不用倒转头七了。 真的和地球扛上了,公司的大屏项目需要科技感的地球、飞线图。...目标设计样子: 实现步骤分解: ThreeJS环境初始化 星空背景 添加带纹理的地球 世界地图轮廓边界绘制 地球光晕 添加地球云层 城市位置标注和涟漪效果 添加飞线B样条 地球自转和镜头缩放动画 初始化...: 世界地图轮廓边界绘制 刚才光秃秃的地球,需要加上点轮廓。...材质对象 var line = new LineSegments(geometry, material); //间隔绘制直线 line.scale.set(R, R, R); //lineData.js...texture, //设置精灵纹理贴图 transparent: true, //开启透明 // opacity: 0.5,//可以通过透明度整体调节光圈 }); // 创建表示地球光圈的精灵模型
接上篇:一个基于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
当我们需要固定场景背景,固定摄像机的时候。移动旋转物体可以使用Three.js提供的OrbitControls.js,也可以手动写控制器。...原理:获取鼠标点击的位置与移动的距离,根据移动的距离计算出大概旋转的角度。 查看旋转效果 <script src=".....mouseXOnMouseDown = event.layerX - windowHalfX; //鼠标按下<em>的</em><em>旋转</em>角度 targetRotationOnMouseDown...= event.layerX - windowHalfX; //移动<em>的</em>时候<em>旋转</em><em>的</em>角度 = 刚按下鼠标的角度+移动<em>的</em>位置-鼠标按下时<em>的</em>位置 targetRotation
--从官网下载js文件--> 地球仪 </canvas...() { var globe = planetaryjs.planet(); // 导入自定义旋转插件 globe.loadPlugin(autorotate(10));...// 导入json文件 // 设置海洋,大地,轮廓的颜色 globe.loadPlugin(planetaryjs.plugins.earth({ topojson: {...var canvas = document.getElementById('globe'); globe.draw(canvas); // 自定义旋转插件 function
问题描述 3D旋转相册是通过perspective属性的盒子1产生向网页内部的延伸感,并让装有图片沿z轴平移后的盒子2在拥有perspective属性的盒子1内凭transform属性产生的3d效果沿盒子...2y轴旋转转动来实现的。...}/*此属性是实现旋转木马的要点,能产生空间上的距离/延伸感。...以数组的形式获取,并根据其数组长度length来计算图片的旋转角度。...这时候为装有图片的盒子加上transform:rotateX(-15deg);便能看到较为完整的3d效果了,此时实现盒子绕y轴转动便可实现旋转木马的效果。 ?
;我为了方便都写到一个html中了;请把这个script标签中的内容单独写在一个js文件里 //整个插件写在一个立即执行函数里;就是function(){}();函数自执行;保证里面的变量不会与外界互相影响...号(叹号)或者;(分号)这不是写错了,为了防止那个二货写的js结束没有分号;而可能发生报错 /* ;function(win,doc,$,undefined){ }(window...比如你要点击按钮 添加input的值到 div里 var addHtml = function(demo,btn){//插件名,调用的时候直接new一下插件名就行了并传参数或者传对象(一般这个函数名手写字母大写比较好...add-1");//这里是实例1调用插件的代码 new addHtml("demo-2","add-2"); //这里是实例2调用插件的代码 //是不是明白为什么要写插件了;要封装...--这里是最简单的插件写法;当然还有传对象参数的插件等等。。。。-->
分享一个js的拖拽框选插件 官网:https://dragselect.com/ 源码:https://github.com/ThibaultJanBeyer/DragSelect.git 使用: pnpm...i dragselect 有前端大佬翻译了部分,并编写了一个html的demo https://gitee.com/ovsexia/DragSelect-Doc-Cn 我在使用过程中发现反选有点问题,...所以如果是跟我一样pnpm i下载下的版本,应该也会有这个问题,因此反选自己实现即可,这是我按照上面链接中的demo在vue模块化项目中的组件: TagDragSelect.vue <!...element.querySelector('input[type="checkbox"]').checked = false; }, //鼠标抬起后返回所有选中的元素
1.Chart.js 官网地址:http://chartjs.cn/ 2.优秀的bootstrap模板推荐 官网地址:http://bootswatch.com 3.wow+animate+js插件库
今天介绍一款 jQuery 插件——jqueryrotate,它可以实现旋转效果。jqueryrotate 支持所有主流浏览器,包括 IE6。...如果你想在低版本的 IE 中实现旋转效果,那么 jqueryrotate 是一个很好的选择。 兼容性 jqueryrotate 支持所有主流浏览器,包括 IE6。...0 animateTo 数字 从当前的角度旋转到多少度 0 step 函数 每个动画步骤中执行的回调函数,当前角度值作为该函数的第一个参数 无 easing 函数 自定义旋转速度、旋转效果,需要使用...jQuery.easing.js 无 callback 函数 旋转完成后的回调函数 无 getRotateAngle 函数 返回旋转对象当前的角度 无 stopRotate 函数 停止旋转 无 演示虽然使用的是图片...同时,你可以发挥想象,制作出更多关于旋转的特效。
前言: 前端最重要的就是美感,图片的显示也需要,博主在此分享一款灯箱JS插件,非常简单的调用即可实现全局的图片灯箱。...优势介绍 无需其他JavaScript编码 没有其他HTML片段 没有额外的CSS资源 没有其他图标/资产 无需额外处理动态内容和事件侦听器 效果图 调用方法 将以下代码插入到HTML底部 --> $(function
周末闲来无事,反复查阅着维基百科,在一个个链接间跳转,总结出这篇博客,记述地球的起源与地质的变迁 地球诞生 — 46亿年前 138亿年前,宇宙从大爆炸中诞生,此时的宇宙充满了高密度、高温高压的物质...我们就将目光聚焦到宇宙中的地球上 46亿年前,地球伴随着太阳系的诞生而诞生,这之后的不久,一个名为“忒伊亚”的小行星飞速向地球飞来,在这个火星般大小的星球与地球撞击之后,月球形成了 后期重轰击期(41亿年前...~ 38.4亿年前) 起初,地球是一个岩浆球,炽热的岩浆不断聚合、冷却 然而,刚刚诞生的地球并非如同一个婴儿般享受着刚刚来到这世上的平静,与地球一起诞生的还有大量的小行星和彗星,由于引力的作用,他们在太阳系中四处飞射...公里的月球东方海形成后,太阳系中的撞击事件显著减少,地球形成稳定 总结 起初人们都认为,整个冥古宙地球都处于融化态,直到冥古宙末期,地球才被一层岩石外壳包裹,成为一个稳定的行星,现已知最早岩石的结构 —...) 成冰纪的得名就是著名的前寒武纪大冰期,这是十亿年来地球最严重的寒冷期,极地冰盖扩展到赤道,很多地质学家相信当时的地球成为了一个雪球,海洋也完全冻结 火山喷发的二氧化碳因地球生物不能光合作用而逐步累积
html,js,css轮播插件 2016-9-9 今天帮一人写了个简单的轮播,工作不紧张,就顺便传上来分享给大家吧。源码,带部分注释。。。 //html Title $(function(){ Carousel.init($(".carouselBody")); });.../img/btn_r.png") no-repeat center center;} 注意事项,设置carouselBody的宽高时一定要考虑到图片的宽高,最好是宽高都是图片相同
之前我在自己的博客里发表了一篇用angularJs自定义指令实现的分页插件,今天简单改造了一下,改成了原生JavaScript版本的分页插件,可以自定义一些简单配置,特此记录下来。...本插件可以自定义的功能: 1....自己实现的简单小插件,把分页部分的css样式写在了插件paging.js中,以动态创建style标签的方式,加入到页面中。...1、代码部分: 1.1、插件 - paging.js 分页的css样式写在插件中,动态创建style标签,加载到页面中。在该js中有一个Paging构造函数。...,传入设置项的js对象,然后在回调函数里发送ajax请求获取数据。
1)概念: 懒加载也叫延迟加载:JS图片延迟加载,延迟加载图片或符合某些条件时才加载某些图片。 预加载:提前加载图片,当用户需要查看时可直接从本地缓存中渲染。...2)区别: 两种技术的本质:两者的行为是相反的,一个是提前加载,一个是迟缓甚至不加载。懒加载对服务器前端有一定的缓解压力作用,预加载则会增加服务器前端压力。...服务器端区别:懒加载的主要目的是作为服务器前端的优化,减少请求数或延迟请求数。预加载可以说是牺牲服务器前端性能,换取更好的用户体验,这样可以使用户的操作得到最快的反映。 例子: <!...hide(); document.title = '1/' + len;//初始化第一张 } }); //未封装成插件的无序预加载...,因此用$.extend(object)挂载插件
领取专属 10元无门槛券
手把手带您无忧上云