H5 游戏开发:决胜三分球

H5 游戏开发:决胜三分球

2017/11/18 · HTML5 ·
游戏

原文出处: 凹凸实验室   

原文出处: 凹凸实验室   

前言

本次是与腾讯手机充值合作推出的活动,用户通过氪金充值话费或者分享来获得更多的投篮机会,根据最终的进球数排名来发放奖品。

用户可以通过滑动拉出一条辅助线,根据辅助线长度和角度的不同将球投出,由于本次活动的开发周期短,在物理特性实现方面使用了物理引擎,所有本文的分享内容是如何结合物理引擎去实现一款投篮小游戏,如下图所示。

正规网赌平台 1

前言

本次是与腾讯手机充值合作推出的活动,用户通过氪金充值话费或者分享来获得更多的投篮机会,根据最终的进球数排名来发放奖品。

用户可以通过滑动拉出一条辅助线,根据辅助线长度和角度的不同将球投出,由于本次活动的开发周期短,在物理特性实现方面使用了物理引擎,所有本文的分享内容是如何结合物理引擎去实现一款投篮小游戏,如下图所示。

正规网赌平台 2

准备

正规网赌平台 3

此次我使用的游戏引擎是
LayaAir,你也可以根据你的爱好和实际需求选择合适的游戏引擎进行开发,为什么选择该引擎进行开发
,总的来说有以下几个原因:

  • LayaAir 官方文档、API、示例学习详细、友好,可快速上手
  • 除了支持 2D 开发,同时还支持 3D 和 VR 开发,支持 AS、TS、JS
    三种语言开发
  • 在开发者社区中提出的问题,官方能及时有效的回复
  • 提供 IDE 工具,内置功能有打包
    APP、骨骼动画转换、图集打包、SWF转换、3D 转换等等

正规网赌平台 4

物理引擎方面采用了
Matter.js,篮球、篮网的碰撞弹跳都使用它来实现,当然,还有其他的物理引擎如
planck.js、p2.js 等等,具体没有太深入的了解,Matter.js
相比其他引擎的优势在于:

  • 轻量级,性能不逊色于其他物理引擎
  • 官方文档、Demo 例子非常丰富,配色有爱
  • API 简单易用,轻松实现弹跳、碰撞、重力、滚动等物理效果
  • Github Star 数处于其他物理引擎之上,更新频率更高

准备

正规网赌平台 5

此次我使用的游戏引擎是
LayaAir,你也可以根据你的爱好和实际需求选择合适的游戏引擎进行开发,为什么选择该引擎进行开发
,总的来说有以下几个原因:

  • LayaAir 官方文档、API、示例学习详细、友好,可快速上手
  • 除了支持 2D 开发,同时还支持 3D 和 VR 开发,支持 AS、TS、JS
    三种语言开发
  • 在开发者社区中提出的问题,官方能及时有效的回复
  • 提供 IDE 工具,内置功能有打包
    APP、骨骼动画转换、图集打包、SWF转换、3D 转换等等

正规网赌平台 6

物理引擎方面采用了
Matter.js,篮球、篮网的碰撞弹跳都使用它来实现,当然,还有其他的物理引擎如
planck.js、p2.js 等等,具体没有太深入的了解,Matter.js
相比其他引擎的优势在于:

  • 轻量级,性能不逊色于其他物理引擎
  • 官方文档、Demo 例子非常丰富,配色有爱
  • API 简单易用,轻松实现弹跳、碰撞、重力、滚动等物理效果
  • Github Star 数处于其他物理引擎之上,更新频率更高

开始

开始

一、初始化游戏引擎

首先对 LayaAir 游戏引擎进行初始化设置,Laya.init 创建一个 1334×750
的画布以 WebGL 模式去渲染,渲染模式下有 WebGL 和 Canvas,使用 WebGL
模式下会出现锯齿的问题,使用 Config.isAntialias
抗锯齿可以解决此问题,并且使用引擎中自带的多种屏幕适配 screenMode

如果你使用的游戏引擎没有提供屏幕适配,欢迎阅读另一位同事所写的文章【H5游戏开发:横屏适配】

JavaScript

… Config.isAntialias = true; // 抗锯齿 Laya.init(1334, 750,
Laya.WebGL); // 初始化一个画布,使用 WebGL 渲染,不支持时会自动切换为
Canvas Laya.stage.alignV = ‘top’; // 适配垂直对齐方式 Laya.stage.alignH
= ‘middle’; // 适配水平对齐方式 Laya.stage.screenMode =
this.Stage.SCREEN_HORIZONTAL; // 始终以横屏展示 Laya.stage.scaleMode =
“fixedwidth”; // 宽度不变,高度根据屏幕比例缩放,还有
noscale、exactfit、showall、noborder、full、fixedheight 等适配模式 …

1
2
3
4
5
6
7
8
Config.isAntialias = true; // 抗锯齿
Laya.init(1334, 750, Laya.WebGL); // 初始化一个画布,使用 WebGL 渲染,不支持时会自动切换为 Canvas
Laya.stage.alignV = ‘top’; // 适配垂直对齐方式
Laya.stage.alignH = ‘middle’; // 适配水平对齐方式
Laya.stage.screenMode = this.Stage.SCREEN_HORIZONTAL; // 始终以横屏展示
Laya.stage.scaleMode = "fixedwidth"; // 宽度不变,高度根据屏幕比例缩放,还有 noscale、exactfit、showall、noborder、full、fixedheight 等适配模式

一、初始化游戏引擎

正规网赌平台,首先对 LayaAir 游戏引擎进行初始化设置,Laya.init 创建一个 1334×750
的画布以 WebGL 模式去渲染,渲染模式下有 WebGL 和 Canvas,使用 WebGL
模式下会出现锯齿的问题,使用 Config.isAntialias
抗锯齿可以解决此问题,并且使用引擎中自带的多种屏幕适配 screenMode

如果你使用的游戏引擎没有提供屏幕适配,欢迎阅读另一位同事所写的文章【H5游戏开发:横屏适配】

JavaScript

… Config.isAntialias = true; // 抗锯齿 Laya.init(1334, 750,
Laya.WebGL); // 初始化一个画布,使用 WebGL 渲染,不支持时会自动切换为
Canvas Laya.stage.alignV = ‘top’; // 适配垂直对齐方式 Laya.stage.alignH
= ‘middle’; // 适配水平对齐方式 Laya.stage.screenMode =
this.Stage.SCREEN_HORIZONTAL; // 始终以横屏展示 Laya.stage.scaleMode =
“fixedwidth”; // 宽度不变,高度根据屏幕比例缩放,还有
noscale、exactfit、showall、noborder、full、fixedheight 等适配模式 …

1
2
3
4
5
6
7
8
Config.isAntialias = true; // 抗锯齿
Laya.init(1334, 750, Laya.WebGL); // 初始化一个画布,使用 WebGL 渲染,不支持时会自动切换为 Canvas
Laya.stage.alignV = ‘top’; // 适配垂直对齐方式
Laya.stage.alignH = ‘middle’; // 适配水平对齐方式
Laya.stage.screenMode = this.Stage.SCREEN_HORIZONTAL; // 始终以横屏展示
Laya.stage.scaleMode = "fixedwidth"; // 宽度不变,高度根据屏幕比例缩放,还有 noscale、exactfit、showall、noborder、full、fixedheight 等适配模式

二、初始化物理引擎、加入场景

然后对 Matter.js 物理引擎进行初始化,Matter.Engine
模块包含了创建和处理引擎的方法,由引擎运行这个世界,engine.world
则包含了用于创建和操作世界的方法,所有的物体都需要加入到这个世界中,Matter.Render
是将实例渲染到 Canvas 中的渲染器。

enableSleeping
是开启刚体处于静止状态时切换为睡眠状态,减少物理运算提升性能,wireframes
关闭用于调试时的线框模式,再使用 LayaAir 提供的
Laya.loadingnew Sprite 加载、绘制已简化的场景元素。

JavaScript

… this.engine; var world; this.engine = Matter.Engine.create({
enableSleeping: true // 开启睡眠 }); world = this.engine.world;
Matter.Engine.run(this.engine); // Engine 启动 var render =
LayaRender.create({ engine: this.engine, options: { wireframes: false,
background: “#000” } }); LayaRender.run(render); // Render 启动 …

1
2
3
4
5
6
7
8
9
10
11
12
13
14
this.engine;
var world;
this.engine = Matter.Engine.create({
    enableSleeping: true // 开启睡眠
});
world = this.engine.world;
Matter.Engine.run(this.engine); // Engine 启动
var render = LayaRender.create({
    engine: this.engine,
    options: { wireframes: false, background: "#000" }
});
LayaRender.run(render); // Render 启动

正规网赌平台 7

正规网赌平台 8

JavaScript

… // 加入背景、篮架、篮框 var bg = new this.Sprite();
Laya.stage.addChild(bg); bg.pos(0, 0); bg.loadImage(‘images/bg.jpg’);

1
2
3
4
5
6
7
// 加入背景、篮架、篮框
var bg = new this.Sprite();
Laya.stage.addChild(bg);
bg.pos(0, 0);
bg.loadImage(‘images/bg.jpg’);

二、初始化物理引擎、加入场景

然后对 Matter.js 物理引擎进行初始化,Matter.Engine
模块包含了创建和处理引擎的方法,由引擎运行这个世界,engine.world
则包含了用于创建和操作世界的方法,所有的物体都需要加入到这个世界中,Matter.Render
是将实例渲染到 Canvas 中的渲染器。

enableSleeping
是开启刚体处于静止状态时切换为睡眠状态,减少物理运算提升性能,wireframes
关闭用于调试时的线框模式,再使用 LayaAir 提供的
Laya.loadingnew Sprite 加载、绘制已简化的场景元素。

JavaScript

… this.engine; var world; this.engine = Matter.Engine.create({
enableSleeping: true // 开启睡眠 }); world = this.engine.world;
Matter.Engine.run(this.engine); // Engine 启动 var render =
LayaRender.create({ engine: this.engine, options: { wireframes: false,
background: “#000” } }); LayaRender.run(render); // Render 启动 …

1
2
3
4
5
6
7
8
9
10
11
12
13
14
this.engine;
var world;
this.engine = Matter.Engine.create({
    enableSleeping: true // 开启睡眠
});
world = this.engine.world;
Matter.Engine.run(this.engine); // Engine 启动
var render = LayaRender.create({
    engine: this.engine,
    options: { wireframes: false, background: "#000" }
});
LayaRender.run(render); // Render 启动

正规网赌平台 9

正规网赌平台 10

JavaScript

… // 加入背景、篮架、篮框 var bg = new this.Sprite();
Laya.stage.addChild(bg); bg.pos(0, 0); bg.loadImage(‘images/bg.jpg’);

1
2
3
4
5
6
7
// 加入背景、篮架、篮框
var bg = new this.Sprite();
Laya.stage.addChild(bg);
bg.pos(0, 0);
bg.loadImage(‘images/bg.jpg’);

相关文章