使用JS实现图片的飘浮运动

2023-10-12 18:30

本文主要是介绍使用JS实现图片的飘浮运动,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先贴上准备飘浮的图片镇楼:PUBG

下面准备让这张图片在屏幕里面进行飘浮运动,先贴上HTML和CSS代码和运行图:

<html><head><meta charset="UTF-8"><title></title><style type="text/css">/*悬浮框  */#float {position: absolute;z-index: 1;}/*图片大小*/#floatImg {width: 250px;height: 150px;}</style></head><body><div id="float"><img id="floatImg" alt="图片未找到" src="img/pubg.jpg"></div></body>
</html>

介绍一下我的思路,设置6个全局变量,分别记录图片在X轴、Y轴上的移动距离、方向以及速度,接着进行图片的位置改变方法,在方法中, 我们首先得到屏幕的大小和照片的大小,设置图片的起始位置,接着进行位置的移动,移动过后再判断图片是否遇到四周墙壁,如果遇到,使其移动方向进行改变,并且移动距离根据其位置的不同设置其为0或者最大移动数(屏幕大小-图片大小),最后设置一个定时器使其相隔50毫秒进行一次方法执行。这样,飘浮的图片效果就做出来了。

下面附上JS代码进行参考学习:

            //定义全局变量var moveX = 0; //X轴方向上移动的距离var moveY = 0; //Y轴方向上移动的距离var stepX = 5; //图片X轴移动的速度var stepY = 6; //图片Y轴移动的速度var directionX = 0; //设置图片在X轴方向上的移动方向   0:向右  1:向左var directionY = 0; //设置图片在Y轴方向上的移动方向   0:向下  1:向上function changePos() {var img = document.getElementById("float"); //获得图片所在层的IDvar height = document.documentElement.clientHeight; //浏览器的高度var width = document.documentElement.clientWidth; //浏览器的宽度var imgHeight = document.getElementById("floatImg").height; //飘浮图片的高度var imgWidth = document.getElementById("floatImg").width; //瓢浮图片的宽度//设置飘浮图片距离浏览器左侧位置img.style.left = parseInt(moveX + document.documentElement.scrollLeft) + "px";//设置飘浮图片距离浏览器右侧位置img.style.top = parseInt(moveY + document.documentElement.scrollTop) + "px";//设置图片在Y轴上的移动规律if(directionY == 0) {//飘浮图片在Y轴方向上向下移动moveY += stepY;} else {//飘浮图片在Y轴方向上向上移动moveY -= stepY;}if(moveY < 0) {//如果飘浮图片飘浮到顶端的时候,设置图片在Y轴方向上向下移动directionY = 0;moveY = 0;}if(moveY > (height - imgHeight)) {//如果飘浮图片飘浮到浏览器底端的时候,设置图片在Y轴方向上向上移动directionY = 1;moveY = (height - imgHeight);}//设置图片在X轴上的移动规律if(directionX == 0) {moveX += stepX;} else {moveX -= stepX;}if(moveX < 0) {//如果飘浮图片飘浮到浏览器左侧的时候,设置图片在X轴方向上向右移动directionX = 0;moveX = 0;}if(moveX > (width - imgWidth)) {//如果飘浮图片飘浮到浏览器右侧的时候,设置图片在X轴方向上向左移动directionX = 1;moveX = (width - imgWidth);}}setInterval("changePos()", 50);

 

这篇关于使用JS实现图片的飘浮运动的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Flutter实现文字镂空效果的详细步骤

《Flutter实现文字镂空效果的详细步骤》:本文主要介绍如何使用Flutter实现文字镂空效果,包括创建基础应用结构、实现自定义绘制器、构建UI界面以及实现颜色选择按钮等步骤,并详细解析了混合模... 目录引言实现原理开始实现步骤1:创建基础应用结构步骤2:创建主屏幕步骤3:实现自定义绘制器步骤4:构建U

使用Python创建一个功能完整的Windows风格计算器程序

《使用Python创建一个功能完整的Windows风格计算器程序》:本文主要介绍如何使用Python和Tkinter创建一个功能完整的Windows风格计算器程序,包括基本运算、高级科学计算(如三... 目录python实现Windows系统计算器程序(含高级功能)1. 使用Tkinter实现基础计算器2.

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

Android实现定时任务的几种方式汇总(附源码)

《Android实现定时任务的几种方式汇总(附源码)》在Android应用中,定时任务(ScheduledTask)的需求几乎无处不在:从定时刷新数据、定时备份、定时推送通知,到夜间静默下载、循环执行... 目录一、项目介绍1. 背景与意义二、相关基础知识与系统约束三、方案一:Handler.postDel

在.NET平台使用C#为PDF添加各种类型的表单域的方法

《在.NET平台使用C#为PDF添加各种类型的表单域的方法》在日常办公系统开发中,涉及PDF处理相关的开发时,生成可填写的PDF表单是一种常见需求,与静态PDF不同,带有**表单域的文档支持用户直接在... 目录引言使用 PdfTextBoxField 添加文本输入域使用 PdfComboBoxField

Git可视化管理工具(SourceTree)使用操作大全经典

《Git可视化管理工具(SourceTree)使用操作大全经典》本文详细介绍了SourceTree作为Git可视化管理工具的常用操作,包括连接远程仓库、添加SSH密钥、克隆仓库、设置默认项目目录、代码... 目录前言:连接Gitee or github,获取代码:在SourceTree中添加SSH密钥:Cl

Python中模块graphviz使用入门

《Python中模块graphviz使用入门》graphviz是一个用于创建和操作图形的Python库,本文主要介绍了Python中模块graphviz使用入门,具有一定的参考价值,感兴趣的可以了解一... 目录1.安装2. 基本用法2.1 输出图像格式2.2 图像style设置2.3 属性2.4 子图和聚

windows和Linux使用命令行计算文件的MD5值

《windows和Linux使用命令行计算文件的MD5值》在Windows和Linux系统中,您可以使用命令行(终端或命令提示符)来计算文件的MD5值,文章介绍了在Windows和Linux/macO... 目录在Windows上:在linux或MACOS上:总结在Windows上:可以使用certuti

CentOS和Ubuntu系统使用shell脚本创建用户和设置密码

《CentOS和Ubuntu系统使用shell脚本创建用户和设置密码》在Linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设置密码,本文写了一个shell... 在linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设

Python使用Matplotlib绘制3D曲面图详解

《Python使用Matplotlib绘制3D曲面图详解》:本文主要介绍Python使用Matplotlib绘制3D曲面图,在Python中,使用Matplotlib库绘制3D曲面图可以通过mpl... 目录准备工作绘制简单的 3D 曲面图绘制 3D 曲面图添加线框和透明度控制图形视角Matplotlib