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

相关文章

GO语言短变量声明的实现示例

《GO语言短变量声明的实现示例》在Go语言中,短变量声明是一种简洁的变量声明方式,使用:=运算符,可以自动推断变量类型,下面就来具体介绍一下如何使用,感兴趣的可以了解一下... 目录基本语法功能特点与var的区别适用场景注意事项基本语法variableName := value功能特点1、自动类型推

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.

mybatisplus的逻辑删除过程

《mybatisplus的逻辑删除过程》:本文主要介绍mybatisplus的逻辑删除过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录myBATisplus的逻辑删除1、在配置文件中添加逻辑删除的字段2、在实体类上加上@TableLogic3、业务层正常删除即

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

MySQL逻辑删除与唯一索引冲突解决方案

《MySQL逻辑删除与唯一索引冲突解决方案》本文探讨MySQL逻辑删除与唯一索引冲突问题,提出四种解决方案:复合索引+时间戳、修改唯一字段、历史表、业务层校验,推荐方案1和方案3,适用于不同场景,感兴... 目录问题背景问题复现解决方案解决方案1.复合唯一索引 + 时间戳删除字段解决方案2:删除后修改唯一字

Spring Boot中的路径变量示例详解

《SpringBoot中的路径变量示例详解》SpringBoot中PathVariable通过@PathVariable注解实现URL参数与方法参数绑定,支持多参数接收、类型转换、可选参数、默认值及... 目录一. 基本用法与参数映射1.路径定义2.参数绑定&nhttp://www.chinasem.cnbs

浅析Spring如何控制Bean的加载顺序

《浅析Spring如何控制Bean的加载顺序》在大多数情况下,我们不需要手动控制Bean的加载顺序,因为Spring的IoC容器足够智能,但在某些特殊场景下,这种隐式的依赖关系可能不存在,下面我们就来... 目录核心原则:依赖驱动加载手动控制 Bean 加载顺序的方法方法 1:使用@DependsOn(最直

c++ 类成员变量默认初始值的实现

《c++类成员变量默认初始值的实现》本文主要介绍了c++类成员变量默认初始值,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录C++类成员变量初始化c++类的变量的初始化在C++中,如果使用类成员变量时未给定其初始值,那么它将被

Spring如何使用注解@DependsOn控制Bean加载顺序

《Spring如何使用注解@DependsOn控制Bean加载顺序》:本文主要介绍Spring如何使用注解@DependsOn控制Bean加载顺序,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录1.javascript 前言2. 代码实现总结1. 前言默认情况下,Spring加载Bean的顺