Pixi.js学习 (五)动画效果与变量逻辑控制

2024-06-12 03:28

本文主要是介绍Pixi.js学习 (五)动画效果与变量逻辑控制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

前言

一、动画效果

1.1 帧频

1.2 帧频函数

二、变量逻辑控制

2.1 定义变量的语法

2.2 使用变量控制逻辑

2.3 使用变量控制追加效果

三、实战

例题一:完成天天酷跑

例题一代码:

总结


前言

为了提高作者的代码编辑水品,作者在使用博客的时候使用的集成工具为 HBuilderX。

下文所有截图使用此集成工具,读者随意。

此系列文章需要:HTML ,JavaScript 基础知识

操作系统:

版本    Windows 11 家庭中文版
版本    23H2
安装日期    ‎2024/‎5/‎28
操作系统版本    22631.3593
体验    Windows Feature Experience Pack 1000.22700.1003.0


一、动画效果

动画效果的实现原理:动画是由多张连续的图片以超快的速度(人类肉眼无法察觉)切换看到的视觉效果

1.1 帧频

就是影像动画中最小单位的单幅影像画面,相当于电影胶卷的每一格镜头

一帧就是一副静止的画面,练习的帧就形成了动画,如电视图像。

帧频:每秒钟放映或者显示的图片的数量。

FPS:每秒传输的帧数,FPS值越高,画面越流畅

刷新率:单位Hz,60Hz表示每秒可以扫描刷新60次,最高播放60帧。

运行效果:如果能够做到手动快速点击,移动效果就是动画。 可将手动点击改为自动控制。就可以实现真正的动画效果了。

1.2 帧频函数

帧频函数:被程序自动反复调用,每秒钟被调用60次。

			//当函数每执行一次,飞机上升十个单位function move(){plane.y -= 10;//如果飞机超过边界返回原点if(plane.y<-100){plane.y=600;}}//添加函数app.ticker.add(move);

运行效果:


二、变量逻辑控制

变量:可以保存数据,变量中存储的数据可以变化 常量:程序中出现的固定的数值,例如某个元素的x坐标为200,某个元素每次移动1px的距离 使用变量替换常量,达到通过改变变量的值控制元素的变化。

2.1 定义变量的语法

//在javascript中的变量可以存储任意类型的数据【弱类型】var 变量名;var 变量名;//定义变量
变量名 = 值;//为变量赋值 3
//定义变量同时赋值
var 变量名 = 值 ;var a = 10;// a表示整数10
var b =  new PIXI.Text();//b表示文本元素

使用变量时的注意事项

1、先定义再使用

2、javascript中的var变量为全局变量,作用范围在整个应用中   

3、变量可以重复定义但新的变量会替换旧变量(旧变量将无法使用)

2.2 使用变量控制逻辑

使用变量替换常量,通过改变变量的值让元素产生变化

根据变量所存储的值不同,执行不同的逻辑代码

下面的代码就是使用变量控制常量,改变飞机速度。

//设置飞机速度var planespeed=2;function planemove(){plane.y += planespeed;if (plane.y > 500 ) {plane.y = 0;}else if (plane.y < 0) {plane.y = 500;}}var speed=new PIXI.Text("速度:"+0);speed.x=280;speed.y=410;app.stage.addChild(speed);//点击上键增加速度			shang.on("click",speedup);function speedup(){planespeed += 1speed.text="速度:"+planespeed;}//点击下键减少速度			xia.on("click",speeddown);function speeddown(){if(planespeed>0){planespeed -= 1			    }speed.text="速度:"+planespeed;}

在这串代码中,我们先定义了速度这个变量

//设置飞机速度

var planespeed=2;

又在后面函数中通过对变量的增减分别实现了速度的增加和减少。

没有使用具体的数值,而是使用变量作为中转,这种思想就是使用变量控制逻辑。

2.3 使用变量控制追加效果

接下来我们先实现以下代码:

  • 1.创建应用,穿800,高500
  • 2,创建并添加相对应元素
  • 3.小鸟一直向右运动,超出屏幕右边界,重新回到屏幕左边界,继续向右运动
  • 4.背景图片中按下鼠标,小鸟向上飞,松开鼠标,小鸟向下飞
  • 5.当小鸟超出窗口边界时,游戏结束

使用代码如下:

		<script type="text/javascript">var app=new PIXI.Application(800,500);document.body.appendChild(app.view);																							function add(img,x,y){//创建图片元素var a=new PIXI.Sprite.fromImage(img);//将元素添加到页面中app.stage.addChild(a);//调整位置a.x=xa.y=y //对当前元素直接开启监听a.interactive=true;return a;}var bg = add("img/bj_01.png",0,0);bg.width=800;var bird=add("img/bird.png",100,200);var gameover=add("img/gameover.png",150,0);gameover.visible=false;//小鸟移动方向 上下方向不移动//不移动 0向上 1 向下var direction=2 function animate(){				// 	//小鸟移动bird.x +=2if(direction==1){bird.y-=5				    }else if(direction==0){bird.y+=5}//判断小鸟是否超出边界if(bird.x>800){bird.x=0;}if(bird.y < 0 || bird.y > 480){gameover.visible=true;//移除动画效果app.ticker.remove(animate)}}app.ticker.add(animate)bg.on('mousedown',moveup)function moveup(){				direction=1;}bg.on('mouseup',movedown)function movedown(){direction=0;}				</script>

实现效果:


三、实战

例题一:完成天天酷跑

  • 1.创建并添加应用,宽800,高500
  • 2.添加示例图片对应元素
  • 3.添加背景与道路向左移动的效果(道路要比背景移动速度快)
  • 4.按下起跳按钮,人物跳起,到达一定高度,下降到起始点,人物在空中,点击起跳,不能有效果。

结果图:

例题一代码:

		<script type="text/javascript">var app = new PIXI.Application(800,500);document.body.appendChild(app.view);//添加元素的函数function add(img,x,y){//创建图片元素var a = new PIXI.Sprite.fromImage(img);//将元素添加到页面中app.stage.addChild(a);//调整元素位置a.x = x;a.y = y;//对当前元素直接开启监听a.interactive = true;return a;}var bg1 = add("img/bg_back_02.png",0,0);var bg2 = add("img/bg_front_02.png",0,251);var bg11 = add("img/bg_back_02.png",bg1.x+800,0);var bg22 = add("img/bg_front_02.png",bg2.x+800,251);var ground1 = add("img/ground03_1.png",0,380);var ground11 = add("img/ground03_1.png",ground1.x+800,380);app.ticker.add(bgmove);function bgmove(){bg1.x -= 2;bg11.x -= 2;bg2.x -= 2;bg22.x -= 2;ground1.x -= 8;ground11.x -= 8;if(bg1.x < -800 ){bg1.x = 0;bg11.x = bg1.x+800;bg2.x = 0;bg22.x = bg2.x+800;}if(ground1.x < -800){ground1.x = 0;ground11.x = ground1.x+800;}}var player = add("img/player012.png",200,288);var jumpBtn = add("img/jumpBtn.png",600,288);jumpBtn.on("click",btnjump);function btnjump(){if(player.y == 288){app.ticker.add(playerup);}}function playerup(){player.y -= 1;if(player.y<188){app.ticker.remove(playerup);app.ticker.add(playerdown);}}function playerdown(){player.y+=1;if(player.y>288){player.y = 288;app.ticker.remove(playerdown);}}</script>

运行结果:

本文所用到的img图片以及源码地址:https://download.csdn.net/download/qq_56376552/89421558


总结

本文 动画效果与变量逻辑控制 就此结束,

如有错误或者网址更新,步骤更改,代码错误欢迎私信作者进行更正,

感谢您的观看。

这篇关于Pixi.js学习 (五)动画效果与变量逻辑控制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

一文全面详解Python变量作用域

《一文全面详解Python变量作用域》变量作用域是Python中非常重要的概念,它决定了在哪里可以访问变量,下面我将用通俗易懂的方式,结合代码示例和图表,带你全面了解Python变量作用域,需要的朋友... 目录一、什么是变量作用域?二、python的四种作用域作用域查找顺序图示三、各作用域详解1. 局部作

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

Python远程控制MySQL的完整指南

《Python远程控制MySQL的完整指南》MySQL是最流行的关系型数据库之一,Python通过多种方式可以与MySQL进行交互,下面小编就为大家详细介绍一下Python操作MySQL的常用方法和最... 目录1. 准备工作2. 连接mysql数据库使用mysql-connector使用PyMySQL3.

如何搭建并配置HTTPD文件服务及访问权限控制

《如何搭建并配置HTTPD文件服务及访问权限控制》:本文主要介绍如何搭建并配置HTTPD文件服务及访问权限控制的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、安装HTTPD服务二、HTTPD服务目录结构三、配置修改四、服务启动五、基于用户访问权限控制六、

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

使用Python获取JS加载的数据的多种实现方法

《使用Python获取JS加载的数据的多种实现方法》在当今的互联网时代,网页数据的动态加载已经成为一种常见的技术手段,许多现代网站通过JavaScript(JS)动态加载内容,这使得传统的静态网页爬取... 目录引言一、动态 网页与js加载数据的原理二、python爬取JS加载数据的方法(一)分析网络请求1

Kotlin Compose Button 实现长按监听并实现动画效果(完整代码)

《KotlinComposeButton实现长按监听并实现动画效果(完整代码)》想要实现长按按钮开始录音,松开发送的功能,因此为了实现这些功能就需要自己写一个Button来解决问题,下面小编给大... 目录Button 实现原理1. Surface 的作用(关键)2. InteractionSource3.

使用WPF实现窗口抖动动画效果

《使用WPF实现窗口抖动动画效果》在用户界面设计中,适当的动画反馈可以提升用户体验,尤其是在错误提示、操作失败等场景下,窗口抖动作为一种常见且直观的视觉反馈方式,常用于提醒用户注意当前状态,本文将详细... 目录前言实现思路概述核心代码实现1、 获取目标窗口2、初始化基础位置值3、创建抖动动画4、动画完成后

uniapp小程序中实现无缝衔接滚动效果代码示例

《uniapp小程序中实现无缝衔接滚动效果代码示例》:本文主要介绍uniapp小程序中实现无缝衔接滚动效果的相关资料,该方法可以实现滚动内容中字的不同的颜色更改,并且可以根据需要进行艺术化更改和自... 组件滚动通知只能实现简单的滚动效果,不能实现滚动内容中的字进行不同颜色的更改,下面实现一个无缝衔接的滚动

Java实现图片淡入淡出效果

《Java实现图片淡入淡出效果》在现代图形用户界面和游戏开发中,**图片淡入淡出(FadeIn/Out)**是一种常见且实用的视觉过渡效果,它可以用于启动画面、场景切换、轮播图、提示框弹出等场景,通过... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细