百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

前端图形学(三十四)——别再说游戏开发难了,看它...

yuyutoo 2024-10-21 12:06 6 浏览 0 评论

欢迎来到【畅哥聊技术】前端图形学相关技术文章,更多精彩内容持续更新中,敬请关注。

上一小节我们讲到了phaser.js的基本使用方法,如何去创建一个游戏对象,大致了解了状态(State)的基本概念,通过源码分析state可以是一个Phaser.State类的对象,可以是一个类,也可以是一个json对象。

并且在state中,必须至少得有preload、create、update、render其中的一个。

本章目标

  1. phaser.js的适配
  2. 背景移动
  3. 精灵图片和动画

适配

在phaser.js中,它有自己的一套适配各种终端的方法,我们可以通过

game.scale.scaleMode = value ;

那么这个value有哪些值呢,找源码。

默认值为Phaser.ScaleManager.NO_SCALE。

主要说两个,一是 Phaser.ScaleManager.EXACT_FIT,一般来说移动端的游戏就需要用到它。

接下来我们就去看下它的内部原码实现的原理吧~

首先我们可以看到在ScaleManager 类里在有定义width,height的属性,用我这蹩脚的英文也翻译出来就是对应的Canvas的宽高了。接着往下找

找到了EXACT_FIT的判断条件下有一个setExactFit的方法,我们再去找它的定义。

清楚的看到它就是在给canvas设置大小,并且和浏览器大小一致。我们接下来看下设置完了之后的效果吧

可以看到,任我随意切换浏览器窗口大小,它都能完美适配。

背景移动

从上面的gif图可以看出来,我们的背景图和地面在不停的无缝滚动,这个设置我们仅需要在create方法中设置

bg.autoScroll(-20, 0);
ground.autoScroll(-100 ,0);

即可,一个游戏的简单雏形基本实现了。^_^

精灵图片

加载精灵图片

game.load.spritesheet('bird', '../img/phaser/bird.png', 34, 24, 3);

注意这里使用的是spritesheet去加载多帧的精灵图片

从bird.png图片可以看出来,它有3帧,每一帧的宽为34,高为24,所以创建上面的精灵对象的几个参数都不难理解

那怎么渲染呢?请接着往下看

var bird = game.add.sprite(100,100,'bird');

效果是这样的,bird被渲染出来了,一般来说,序列帧图片一般需要配合动画才能让其动起来。

动画

首先我们要来创建一个动画。

bird.animations.add('fly',[0,1,2]);

add方法的第一个参数为动画名称,第二个参数表示的是要执行的动画帧索引,bird.png有三帧,那就是[0,1,2],这个参数可省,默认就是从第一帧运动到最后一帧。

然后再来执行动画。

bird.animations.play('fly', 12, true);

play方法用来执行动画,第一个参数表示执行动画的名称,即刚才我们定义的“fly”,第二个参数表示的帧率,来用控制动画的快慢。最后一个参数表示的是是否循环执行。

最终的效果:

这样一个简单的动画就实现啦~~

完整的代码截图:

总结:

  1. 在phaser中,适配各种终端的方式
  2. tileSprite对象可以使用bg.autoScroll(-20, 0);来实现背景的无缝滚动。
  3. 创建精灵图片以及每一帧的大小的设置方法
  4. 动画的创建和调用。

以上是今天所有的分享内容。喜欢的请点赞关注,不喜欢的解散~~

这里是【畅哥聊技术】前端图形学相关技术文章,更多精彩内容持续更新中。。。

未完待续。。。

相关推荐

MATLAB实例讲解—求二元函数的极值

实例程序...

解析式大赛的获奖作品代码和公式公布啦!

上方超级数学建模可加关注传播数学干货,学会理性的方式去思考问题大家期待已久的运行代码终于新鲜出炉了!!!抱歉让各位粉丝久等了接下来就是揭秘奇迹的时刻1、emoji解析式:无代码:holdon...

基于MATLAB的ACC控制算法设计及仿真测试

作者...

MATLAB基础学习之坐标转换(matlab改坐标)

(一)平面坐标转换1.cart2pol:将笛卡尔坐标转换为极坐标;2.pol2cart:将极坐标转换为笛卡尔坐标;(二)立体坐标转换1.cart2sph:将笛卡尔坐标转换为极坐标;2.sph2cart...

Java NIO:从 Buffer、Channel、Selector 到 Zero-copy、I/O 多路复用

NIO...

「太极创客」零基础入门学用物联网 - MQTT篇 1-9 自我测试

到目前为止,我们已经掌握了MQTT通讯的基本流程以及如何使用ESP8266来发布和订阅MQTT消息。这节课我们来进行自我测试。...

用豆包改了一下午程序,感觉它聪明得超乎想象

之前低估了AI的聪明程度,AI持续学习下去,未来可以做的事情太多了,编程已经算是比较复杂的事情都能完成得这么好,那些项目计划、工作报告更是小儿科。今天用豆包改了几个程序,提出的BUG也能修改完成...

Node-Media-Server开源流行Nodejs流媒体服务器

简介Node-Media-Server一个Node.js实现的RTMP/HTTP/WebSocket/HLS/DASH流媒体服务器。开源github地址:https://github.com/il...

如何应对 RAG 开发挑战?12 个痛点逐一击破

受到论文《SevenFailurePointsWhenEngineeringaRetrievalAugmentedGenerationSystem》的启发,并结合实际开发RAG(检...

团队协作-代码格式化工具clang-format

环境:clang-format:10.0.0前言统一的代码规范对于整个团队来说十分重要,通过git/svn在提交前进行统一的ClangFormat格式化,可以有效避免由于人工操作带来的代码格式问题。C...

如何编写自己的Arduino库?(arduino怎么自己写库)

支持一对一答疑的购买地址...

Auto CAD 命令(A)(cad命令aaw)

ABOUT(命令)显示有关产品的信息。...

一文读懂设计模式,看这篇就够了(设计模式是干嘛的)

转载:javadoop.com/post/design-pattern一直想写一篇介绍设计模式的文章,让读者可以很快看完,而且一看就懂,看懂就会用,同时不会将各个模式搞混。自认为本文还是写得不错的,花...

ASL开发者指南:构建健壮高效的C++应用

1.库介绍AdobeSourceLibraries(ASL),现在由stlab维护,是一组专注于提供高质量、经过实战检验的C++组件的集合。它最初由Adobe公司开发,旨在解决构建...

linux下GDB使用方法(linux怎么用gdb调试)

gdb是GNU开源组织发布的一个强大的Linux下的程序调试工具。一般来说,GDB主要帮助你完成下面四个方面的功能:1、启动你的程序,可以按照你的自定义的要求随心所欲的运行程序。2、可让被调试的程...

取消回复欢迎 发表评论: