简介:在非游戏环境中将游戏的思维和游戏的机制进行整合运用,以引导用户互动和使用

本文作者:淘系前端团队-Eva.js作者-明非

CodeDay#7 北京站报名ing,欢迎点击免费报名。

背景

现在越来越多的公司和 App 开始使用游戏化的方式去做产品了,所谓游戏化,是指在非游戏环境中将游戏的思维和游戏的机制进行整合运用,以引导用户互动和使用的方法。

支付宝里面的蚂蚁庄园、蚂蚁森林,通过游戏和公益的结合实现用户的留存和活跃。淘宝支付宝的芭芭农场、京东的东东果园、拼多多的多多果园、美团的小美果园...无一不是通过游戏化的方式去提升用户留存的方案。

本篇文章,我们会列出一些游戏化互动类的游戏,然后对一个案例进行拆分,带大家学习一些2D互动最基础的知识,让大家能够快速上手写互动游戏。

能做什么

我们来看几个2D互动项目,目前,大多数的互动都是以游戏的形式展现,通过游戏的玩法和精致的效果,让用户有更好的互动体验,我们通过养成,采集,塔防,抓娃娃等类似游戏的形式,结合业务属性,达到更好的业务效果。

基础学习

2D互动常用能力

首先,我们看一下2D互动游戏所用到的常用能力,第一部分是前端知识,主要包括渲染所需的绘制工具,游戏循环,资源加载的能力。

然后是基础的绘制和动画能力,也就是前面提到的一些游戏基础元素。在游戏开发中,会涉及到很多数学相关的知识,比如让游戏中的物体模拟真实的物理效果,或者像一些游戏中的人机对战中的机器人,是使用游戏 AI 来实现的,在本文中不会过多讲解数学类知识。

互动游戏是如何运行起来的

互动游戏是如何运行起来的呢?

首先,我们知道,目前很多前端项目都是通过数据带动视图的,游戏也是这样的,比如说,我们在游戏里面有一个飞机,那么,我们需要定义飞机的尺寸,以及他在游戏中的位置,和他对应的飞机图片,这些属于游戏数据,我们将数据提交给渲染引擎,渲染引擎根据这些数据内容将对应的内容渲染到画布上。

游戏是动态运行的,为了实现一些动画/真实物理效果效果,我们通过动画,AI,物理引擎等工具控制数据的变化,然后通过循环来持续修改数据,并且渲染到画布实现游戏的运行。

循环

我们知道,通过循环来实现游戏的运行效果,接下来我们来看一下在前端浏览器环境下,游戏循环是如何实现的。

浏览器提供了 requestAnimationFrame 方法,要求浏览器在下一次绘制之前,调用制定的回调函数,这个方法一般是用于更新动画的。

浏览器在的每一次重绘我们叫做1帧,浏览器默认的绘制频率是60帧,也就是说,正常情况下,浏览器一秒会刷新60次。

通过下面的方法,我们可以保证每一帧渲染之前,我们可以进行数据的计算以及调用渲染方法:

const loop = () => {requestAnimationFrame(loop)// 计算数据// 绘制图形
}
requestAnimationFrame(loop)

因为requestAnimationFrame方法只会在下一次绘制前被调用,所以,我们需要在每次调用方法的时候去调用一次这个方法保证游戏继续运行,所以在loop方法里面会重复调用这个方法。

一般情况下,我们会把这个方法放在函数的最前面,因为,如果在计算数据和绘制图形的过程中报错了,会导致程序无法执行到这个方法,游戏也就停掉了。

画布

在 html 中,我们一般使用 canvas 标签来绘制图像,它本身没有绘制能力,使用 getContext 获取绘制上下文,调用上下文上面的方法进行绘制。

常用的绘制上下文有 Canvas API 和 WebGL,一般 CanvasAPI 来绘制2D图像,WebGL 可绘制 2D 和 3D 图像,他的性能更高。

canvas 提供了一些比较基础的 API,但是在互动游戏中的元素是比较复杂的,所以一般都会有渲染引擎和游戏引擎来承接这些元素。

本文不会详细讲解 Canvas,可以到 MDN 等平台学习。

基础渲染

接下来我会介绍一下,在2D游戏化互动游戏中,我们经常用到几种渲染方案。

  • 图片
  • 文本
  • 图形
  • 精灵
  • 九宫格
  • 遮罩

图片和文本就不用说了,是视图开发中最常用到的。我们从图形开始说

图形

一般在开发中会经常使用一些简单的图形,图片不仅会用在直接展示内容,也会用在对渲染内容的遮罩,例如一张图片只显示图形内的内容,也会用在按钮区域判断、物理引擎碰撞的形状等等地方。

精灵

精灵图也是我们在 CSS 中接触的精灵图,就是将多张图片合成在一张大图中,在使用时渲染其中某个位置,通过精灵图的方式,我们可以提高网络加载效率以及渲染效率。一般精灵资源是由两个文件组成,一个是图片文件,另外一个是位置信息文件。一般使用引擎进行渲染时,只需要关心对应小图的名称。

九宫格

我们经常会遇到一些尺寸不固定,但是周围或四遍样式不变形的图片,也就是 .9 图,例如消息气泡,如果直接设置宽高会将整个气泡图片拉变形。

使用九宫格的原理进行解决:

一般渲染引擎也会提供方便的方式实现。

遮罩

通过遮罩可以实现渲染内容的遮罩效果,是不是很像给div设置 overflow:hidden 呢

基础动画

过渡动画

例如一个物体经过3秒,从100px的地方移动到500px。我们可以通过以下方法计算。
startTime 是动画开始的时间。

如果一个物体向右做匀速运动,我们可以使用公式 s = v * t

一般情况下,我们都会使用现成的动画库,类似 Tween.js 实现,当然在实现复杂的动画逻辑时,还可以使用一些工具,类似 Lottie,我们还是需要手写动画的。

逐帧动画

骨骼动画

骨骼动画可以模拟实现一些比较复杂有一定关节逻辑的动画,比起帧动画而言,所使用的图片更少,占用内存更小。

骨骼动画主要以下几部分组成:

骨骼动画贴图

骨骼设计以及动画

贴图+骨骼+动画

所以骨骼动画资源一般由三个文件组成,常用的骨骼动画设计软件是 Spine 和 Dragonbones,一般是由设计师或者动画设计师进行设计。开发者只需要使用软件导出的资源即可。

项目实战

了解到以上的内容,我们就可以开发互动项目了,工欲善其事,必先利其器,这里我们推荐由淘系技术部开源的 Eva.js,它是专门给前端开发者提供的开发游戏化互动项目所设计的。目前淘宝、天猫、支付宝、优酷、阿里妈妈、AliExpress、Lazada、考拉等很多产品都在使用,2020年双11养猫猫项目也是使用 Eva.js 实现的。

接下来我们拿一个最简单的 Demo 来学习使用 Eva.js。

这是一颗心做左右移动动画,点击后弹出一个alert。

Eva.js 的游戏是由游戏对象和组件构成,游戏对象代表游戏中的一个物体,组件代表物体的能力,在这个例子中,只有一个物体,他的能力有三个:

  • 显示成一个心的图片
  • 有一个左右的过渡动画
  • 点击事件

我们刚刚分析了这个 Demo 所需要的能力,接下来我们要做 Eva.js 开发游戏的四步操作

Step1 添加资源&创建游戏
import { resource, Game } from '@eva/eva.js'
import { RendererSystem } from '@eva/plugin-renderer'
import { ImgSystem } from '@eva/plugin-renderer-img'
import { EventSystem } from '@eva/plugin-renderer-event'
import { TransitionSystem } from '@eva/plugin-transition'resource.addResource([{name: 'imageName',type: RESOURCE_TYPE.IMAGE,src: {image: {type: 'png',url:'//gw.alicdn.com/bao/uploaded/TB1lVHuaET1gK0jSZFhXXaAtVXa-200-200.png',},},preload: true,},
]);const game = new Game({systems: [new RendererSystem({canvas: document.querySelector('#canvas'),width: 750,height: 1000,}),new ImgSystem(),new EventSystem(),new TransitionSystem()],
});

addResource 传入了一个资源的里面,这里不一定只有图片资源,还可以有帧动画、骨骼动画等等资源,这里以图片资源举例子。更多Demo可以进入 Eva.js 官网 中查看。

在添加资源之后,我们也创建了一个游戏实例,这是运行游戏的主要运行时, 因为 Eva.js 只有一个最核心的游戏运行时,所以我们所有的功能都是要自己安装的哦~所以我们要安装这个游戏所需要的系统,图片、事件、动画。

  • RendererSystem 是用来将游戏渲染出来的系统,所有渲染的能力都依赖这个系统,里面设置了宽高以及所要渲染的canvas对象。
  • ImgSystem 是用来画图片的系统
  • EventSystem 是用来触发点击事件的系统
  • TransitionSystem 是用来做位移动画的系统
Step2 创建对象,并设置定位
import { GameObject } from '@eva/eva.js'const heart = new GameObject('heart', {size: { width: 200, height: 200 },position: {x: 0,y: 0,},origin: { x: 0, y: 0 },anchor: {x: 0,y: 0,},
});

GameObject 的第一个参数为对象的名称,第二个参数为对象的位置信息,其中 size 设置对象大小, position 设置位置,其他的可以后续参考文档学习哦~

Step3 添加所需要的组件

刚刚我们在 new Game 的时候添加了实现视频功能所需要的系统,这些系统是为了读取组件上面的数值然后实现功能的,所以,我们需要给对象添加组件以后,才能够让对象实现对应的功能。

我们目前所需要的功能是图片渲染、点击事件、位移动画,所以我们要添加三个组件

图片渲染

import { Img } from '@eva/plugin-renderer-img'heart.addComponent(new Img({resource: 'imageName',}),
);

调用 heart 的 addComponent 方法既可添加组件,这里我们添加 Img 组件, Img 组件有个 resource 参数,该参数是图片资源的名称,其实对应了 Step1 中添加的图片资源的名称。当然雪碧图、骨骼动画也是同样的原理,需要在 resource 中添加资源,在添加组件的时候使用。

点击事件

import { Event } from '@eva/plugin-renderer-event'const evt = heart.addComponent(new Event())
evt.on('tap', () => {alert(1)
})

给游戏对象添加一个 Event 组件,并通过 on 方法绑定 tap 事件, on 的第二个参数为 tap 事件所触发的函数,当然,Event 组件还有其他事件,我们可以通过 Eva.js 文档查看。

位移动画

import { Transition } from '@eva/plugin-transition'const transition = heart.addComponent(new Transition())
transition.group = {idle: [{name: 'position.x',component: heart.transform,values: [{time: 0,value: 0,tween: 'ease',},{time: 1000,value: 400,tween: 'ease',},{time: 2000,value: 0}]}]
}
transition.play('idle', Infinity)

上面的代码中,我们创建了一个动画组,名字叫做 idle 当前动画组里面,我们对 heart.transform 组件的 position.x 属性进行数值变化,0->1000ms,数值从0->400,1000ms->2000ms,数值从400->0,然后使用 Transition 组件的 play 方法,让动画执行 Infinity 次。

Step4 运行

一般游戏都是自动运行的,所以做完以上工作后,游戏会自动开始运行。

总结

未来会有越来越多的游戏化产品,开发互动类游戏将成为前端工程师的必备技能,通过本篇文章,我们可以了解到一些基础的游戏化互动技术,也通过 Eva.js 学习了如何实现一个最简单的互动游戏。

如果想对游戏化、互动技术更加深入,我们需要去深入学习游戏引擎、渲染原理、动画、物理、音效等技术,对于互动业务开发来说 Eva.js 目前能满足大部分需求。

前端领域中游戏化方向刚刚起步, Eva.js 是专注于开发游戏化项目的游戏引擎,也处于刚刚起步的状态,未来 Eva.js 会继续专注于前端,专注于游戏化项目,让游戏化项目开发更简单。我们也希望大家能够参与到前端游戏化领域的建设中来,我们也会陆续分享相关的技术,输出游戏化项目开发能力。


CodeDay#7 北京站报名ing

7月17日,与移动开发行业技术大佬相聚中关村,探求前沿的移动端动态化跨端开发方案。

CodeDay#7 北京站报名ing,欢迎点击免费报名。

原文链接:https://developer.aliyun.com/article/785221?

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

前端必看 | 2D游戏化互动入门基础知识相关推荐

  1. 所有前端都要看的2D游戏化互动入门基础知识

    背景 现在越来越多的公司和APP开始使用游戏化的方式去做产品了,所谓游戏化,是指在非游戏环境中将游戏的思维和游戏的机制进行整合运用,以引导用户互动和使用的方法.支付宝里面的蚂蚁庄园.蚂蚁森林,通过游戏 ...

  2. mPaaS 月度小报|为采购而生,全新资源包上架;前端 2D 游戏化互动入门指南

    简介:文末福利大放送,速来~ 本月亮点速览 技术干货 所有前端都要看的 2D 游戏化互动入门基础 mPaaS 动态 资源包上新:除了折扣更是便捷 小程序市场开放公测,复刻超级 App 模型 开发者活动 ...

  3. 跳槽者、应届生必看JAVA面试题系列 - JAVA基础知识(四)

    一: 前言 莫等闲,白了少年头,空悲切. 二: 面试挑战   在文章开始前,首先安利下"面试挑战": 凡是满足下面的挑战条件的,如果一个月内没有拿到一个Offer的,免费提供简历封 ...

  4. K8S上车必看:亲身排雷,入门基础准备

    前言 久闻K8S大名,受限于docker知识的欠缺,所以对K8S的探索一直处于逡巡不前的状态,这一拖就是好久,最近这段时间公司准备上K8S集群了,我被安排来负责这件事情的推进.终于有幸可以真正学习下K ...

  5. Unity 2D游戏开发快速入门(内部资料)

    Unity 2D游戏开发快速入门(内部资料) 试读样张:http://pan.baidu.com/s/1hqh5oqw Unity 2D游戏开发快速入门4 前  言 Unity是一款综合的游戏开发工具 ...

  6. python新手入门代码-新手必看:手把手教你入门 Python

    原标题:新手必看:手把手教你入门 Python 本文为 AI 研习社编译的技术博客,原标题 : Learning Python: From Zero to Hero 翻译 |永恒如新的日常校对 | 酱 ...

  7. 游戏厂商必看:游戏音效验收标准

    游戏音效是提高游戏临场感的重要手段,验收是检验游戏音效是否合格的重要步骤,上篇文章介绍了游戏音乐的验收标准与游戏类型的音频占比(此处不再重复,感兴趣的小伙伴可以查阅<游戏研发必看:游戏音乐验收标 ...

  8. 【PMP考试扫盲】超详细的PMP项目管理入门基础知识,考证必看

    我今年 6 月刚考过 PMP,发现很多小伙伴都对 PMP 还不了解,这篇文章就是对 PMP 基础知识的一个全面解答,文章有点长,先给大家上个目录,方便大家直接查看对应内容~ 目录 [PMP考试扫盲]超 ...

  9. 好程序员web前端教程分享web前端入门基础知识

    好程序员web前端教程分享web前端入门基础知识,作为合格的Web前端工程师必须得掌握HTML.CSS和JavaScript.只懂其中一两个还不行,必须对这三门语言都要熟悉.下面我们一起来看一看吧! ...

最新文章

  1. 百所学校寒假时长排行,看看你的学校排多少名~
  2. 前端之Bootstrap框架
  3. C++ Primer 5th笔记(chap 14 重载运算和类型转换)类类型转换
  4. Python学习笔记之六:在VS中调用Python
  5. centos yum安装python2.7及常见报错处理
  6. 小程序 转义_为内存密集型应用程序转义JVM堆
  7. 数据决策成共识 大数据产业期待点“数”成金
  8. android解析布局树,Android Viewtreeobserver解析
  9. mysql的记录操作的日志文件_MySql 的操作日志 历史记录
  10. 触发事件_SAP 通过事件触发后台JOB
  11. webpack 4.0 学习笔记(一)
  12. mac ~/.bash_profile 重启失效
  13. android 腾讯 gt,源码解读腾讯 GT 的性能测试方案
  14. [转载] python中numpy库的使用
  15. 软件测试技术之: 白盒测试和黑盒测试
  16. 用摄动法证明fibs的一个公式(继续变形)
  17. 用于AB测试的减少方差方法总结和对比
  18. 重大噩耗:苹果账号无法付款!(11-20更新:账单地址和卡地址一样,信用卡名字和开发者名字一致,都无法付款)
  19. 360手机卫士linux版,360手机卫士极速版
  20. poi word设置页眉图片,控制首页不同

热门文章

  1. data的值 如何初始化vue_vue 创建一个基础实例【02】
  2. 微服务SpringCloud
  3. Apache Flink 零基础入门(二):使用docker快速搭建Flink
  4. 五、数据对象和属性类型
  5. 推荐一位资深 Python 大佬
  6. 真香!spaCy+Cython比Python快100倍.....
  7. 肝!Python 100 例
  8. python表单填写_Python3.4 splinter(模拟填写表单)使用方法
  9. mfc中嵌入python_Python 中的 Hook 钩子函数
  10. springboot集成mybatis源码分析-启动加载mybatis过程(二)