vue3 three.js 实现动态云层登录页面

2023-11-01 10:20

本文主要是介绍vue3 three.js 实现动态云层登录页面,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 一、效果图
  • 二、使用的库
  • 三、实现
    • 思路
    • 开始
    • init()实现
    • animate()实现
  • 总结


一、效果图

在这里插入图片描述

二、使用的库

three.js v141
vue3

三、实现

思路

  1. 在Z轴上放一堆的64*64的平面图形,图形的X Y是随机的。
  2. 把所有的图形合成一个大的图形
  3. 把大的图形和贴片材质(云)生成网格,网格放进场景中
  4. 动效就是将相机从远处沿着Z轴缓慢移动,就会有了穿越云层的效果

开始

定义实现该效果的方法,参数是一个element实例

import * as THREE from 'three'
import * as BufferGeometryUtils from 'three/examples/jsm/utils/BufferGeometryUtils.js'
import cloud from '@/assets/cloud.png' // 云贴图
function cloudLoginBg(HTMLElement: HTMLElement | null) {...
}

cloudLoginBg方法内容

   let camera: THREE.Camera, // 相机scene: THREE.Scene, // 场景renderer: THREE.WebGLRenderer, // 渲染器mesh; //网格const StartTime = Date.now();const BackGroundColor = '#1e4877'; // 背景色const CloudCount = 8000; // 云数量const perCloudZ = 2; // 每个云所占z轴的长度const cameraPositionZ = CloudCount * perCloudZ;// 所有的云一共的Z轴长度// X轴和Y轴平移的随机参数const RandomPositionX = 500;const RandomPositionY = 120;init();animate();

init()实现

相机

camera = new THREE.PerspectiveCamera(30, window.innerWidth / window.innerHeight, 1, 1000);
camera.position.x = Math.floor(RandomPositionX / 2);
camera.position.z = cameraPositionZ;
camera.position.y = Math.floor(RandomPositionY / 10);

场景

scene = new THREE.Scene();
scene.background = new THREE.Color(BackGroundColor);

材质
用ShaderMaterial的材质必须使用WebGLRenderer来渲染

const texture = new THREE.TextureLoader().load(cloud); // 加载文件
let fog = new THREE.Fog(BackGroundColor, 1, 1000);
// GLSL(OpenGL着色语言OpenGL Shading Language)
const vs = `varying vec2 vUv;void main(){vUv = uv;gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );}`;
const fs = `uniform sampler2D map;uniform vec3 fogColor;uniform float fogNear;uniform float fogFar;varying vec2 vUv;void main(){float depth = gl_FragCoord.z / gl_FragCoord.w;float fogFactor = smoothstep( fogNear, fogFar, depth );gl_FragColor = texture2D( map, vUv );gl_FragColor.w *= pow( gl_FragCoord.z, 20.0 );gl_FragColor = mix( gl_FragColor, vec4( fogColor, gl_FragColor.w ), fogFactor );}`;//着色器材质 自定义材质const material = new THREE.ShaderMaterial({uniforms: {"map": {value: texture},"fogColor": {value: fog.color},"fogNear": {value: fog.near},"fogFar": {value: fog.far},},vertexShader: vs,fragmentShader: fs,transparent: true});

平面图形

const geometry = new THREE.PlaneGeometry(64, 64); // 64*64平面图形
const geometries = []; // 一堆图形
for (let i = 0; i < CloudCount; i++) {const plane = geometry.clone() // 克隆plane.translate(Math.random() * RandomPositionX, -Math.random() * RandomPositionY, i * perCloudZ)geometries.push(plane);
}
// 把一组图形合并一个
const mergedGeometry = BufferGeometryUtils.mergeBufferGeometries(geometries);
// 生成网格
mesh = new THREE.Mesh(mergedGeometry, material);
// 加入场景中
scene.add(mesh);

渲染

renderer = new THREE.WebGLRenderer({antialias: false
});
renderer.setSize(window.innerWidth, window.innerHeight);
HTMLElement!.appendChild(renderer.domElement);

animate()实现

requestAnimationFrame(animate);
camera.position.z = cameraPositionZ - (((Date.now() - StartTime) * 0.1) % cameraPositionZ);
renderer.render(scene, camera)

总结

动态云层的效果以上就是全部代码了哟,有什么不对的地方欢迎大家评论。
目前有一个bug:当相机穿越完云层后,会头开始,这之间衔接效果不好,有时间再处理。

谢谢大家阅读星海君的前端文章~~~

这篇关于vue3 three.js 实现动态云层登录页面的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/322275

相关文章

慢sql提前分析预警和动态sql替换-Mybatis-SQL

《慢sql提前分析预警和动态sql替换-Mybatis-SQL》为防止慢SQL问题而开发的MyBatis组件,该组件能够在开发、测试阶段自动分析SQL语句,并在出现慢SQL问题时通过Ducc配置实现动... 目录背景解决思路开源方案调研设计方案详细设计使用方法1、引入依赖jar包2、配置组件XML3、核心配

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

Python位移操作和位运算的实现示例

《Python位移操作和位运算的实现示例》本文主要介绍了Python位移操作和位运算的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 位移操作1.1 左移操作 (<<)1.2 右移操作 (>>)注意事项:2. 位运算2.1

如何在 Spring Boot 中实现 FreeMarker 模板

《如何在SpringBoot中实现FreeMarker模板》FreeMarker是一种功能强大、轻量级的模板引擎,用于在Java应用中生成动态文本输出(如HTML、XML、邮件内容等),本文... 目录什么是 FreeMarker 模板?在 Spring Boot 中实现 FreeMarker 模板1. 环

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

SpringMVC 通过ajax 前后端数据交互的实现方法

《SpringMVC通过ajax前后端数据交互的实现方法》:本文主要介绍SpringMVC通过ajax前后端数据交互的实现方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价... 在前端的开发过程中,经常在html页面通过AJAX进行前后端数据的交互,SpringMVC的controll

Spring Security自定义身份认证的实现方法

《SpringSecurity自定义身份认证的实现方法》:本文主要介绍SpringSecurity自定义身份认证的实现方法,下面对SpringSecurity的这三种自定义身份认证进行详细讲解,... 目录1.内存身份认证(1)创建配置类(2)验证内存身份认证2.JDBC身份认证(1)数据准备 (2)配置依