基于ES6模块标准通过webpack打包HTM5项目
本篇主要演示通过webpack打包phaser项目,webpack安装方法在此处就不一一赘述了
经常用phaser来写html5游戏的朋友可能会发现,当游戏场景比较多时,如果都写在一个js文件中那么将来会很难维护,如果分成多个JS分别来管理不同的场景将会很方便
1. 首先来到项目根目录
在该目录中打开命令行,然后启动webpack
2、在app目录中建立一个文件夹,主要用来放置打包前的文件
从图中可以很看到,分成了专门用来引导,预加载,游戏菜单,游戏主逻辑,等js文件,由于用的是ES6的模块语法,ES6的module是动态引用的,即对外暴露的是该模块的引用, 可以新建一个public.js专门用来存放共享的变量
//public.js 用来存放phaser对象,然后其他js文件都import该文件就可以使用phaser对象了
export default {
game: null, }
// main.js 是模块的入口,这里把需要打包的js文件引入进来,从上面的public文件代码中可以看到export了一个对象,在这里把phaser对象传递给public中的game属性。 import vars from './public.js';
import Boot from './boot.js';
import Preloader from './preloader.js';
import Menu from './menu.js';
import Game from './game.js'; var gameScore = 0;
var h = $(window).height();
var game = vars.game = new Phaser.Game(640, h, Phaser.CANVAS, 'game');//就是这里啦,
game.state.add('Boot',Boot);
game.state.add('Preloader',Preloader); game.state.add('Menu',Menu); game.state.add('Game',Game);
game.state.start('Boot');
//boot.js 用来添加加载条图片和启动加载页面 import vars from './public.js'; export default {
preload:function(){
vars.game.load.image('preloaderBar','assets/loading-bar.png');
},
create:function(){
vars.game.state.start('Preloader');
}
}
//preloader.js
import vars from './public.js'; export default {
preload : function(){
var preloadSprite = vars.game.add.sprite(vars.game.world.width/4,vars.game.world.height / 2 ,'preloaderBar');
var preloadText = vars.game.add.text(vars.game.width/2,vars.game.height/2+60,'0%',{font:'40px Arial',align:"center",color:"#fff"})
console.log(preloadSprite);
vars.game.load.setPreloadSprite(preloadSprite);
// vars.game.load.audio('drivin-home', 'assets/world.wav');
// vars.game.load.audio('ho-ho-ho', 'assets/bonbon.wav');
// vars.game.load.audio('hop', 'assets/bomb.wav');
vars.game.load.image('platform', 'assets/1.png');
vars.game.load.spritesheet('santa-running', 'assets/runman.png', 493/5, 174,5);
vars.game.load.image('snow-bg', 'assets/beijing1.png');
vars.game.load.image('snow-bg-2', 'assets/yuanjing1.jpg');
vars.game.load.image('snowflake', 'assets/xiaoshixiaoguo.png');
vars.game.load.image('logo', 'assets/name.png');
vars.game.load.image('startbtn', 'assets/bangzhujiantou.png'); vars.game.load.onFileComplete.add(function(){
var progress = vars.game.load.progress;
preloadText.text = progress+'%';
});
vars.game.load.onLoadComplete.add(function(){//所有资源加载完成
preloadText.kill();
vars.game.state.start('Menu');
})
},
create:function(){ }
}
//main.js
import vars from './public.js'; export default {
create : function(){
vars.game.add.tileSprite(0,0,vars.game.width,vars.game.height,'snow-bg-2').autoScroll(-50,0);
vars.game.add.tileSprite(0, 0, vars.game.width, vars.game.height, 'snow-bg').autoScroll(-100,0);
vars.logo = vars.game.add.sprite(vars.game.width / 2 - 158, 20, 'logo');
vars.logo.alpha = 0;
vars.game.add.tween(vars.logo).to({
alpha:1
},1000,Phaser.Easing.Linear.None,true,0);
vars.startBtn = vars.game.add.button(vars.game.width/2-89,vars.game.height -120,'startbtn',function(){ vars.game.state.start('Game');});
vars.startBtn.alpha = 0;
vars.game.add.tween(vars.startBtn).to({
alpha:1
},1000,Phaser.Easing.Linear.None,true,1000); }
}
//game.js 游戏主逻辑
import vars from './public.js'; export default {
create : function(){
vars.gameScore = 0;
vars.currentFrame = 0;
vars.particleInterval = 2*60;
vars.gameSpeed = 580;
vars.isGameOver = false;
vars.game.physics.startSystem(Phaser.Physics.ARCADE);
vars.bg_heaven = vars.game.add.tileSprite(0, 0, vars.game.width,vars.game.height, 'snow-bg-2').autoScroll(-50,0);
vars.bg = vars.game.add.tileSprite(0, 0, vars.game.width, vars.game.height, 'snow-bg');
vars.bg.fixedToCamera = true;
vars.bg.autoScroll(-vars.gameSpeed / 6, 0);
vars.platforms = vars.game.add.group();
vars.platforms.enableBody = true;
vars.platforms.createMultiple(5,'platform',0,false);
vars.platforms.setAll('anchor.x',0.5)
vars.platforms.setAll('anchor.y',0.5)
var plat;
for (var i = 0; i < 5; i++) {
plat = vars.platforms.getFirstExists(false);
plat.reset(i * 192, vars.game.world.height - 44);
plat.width = 300*0.6;
plat.height = 88*0.6;
vars.game.physics.arcade.enable(plat);
plat.body.immovable = true;
plat.body.bounce.set(0);
}
vars.lastPlatform = plat;
vars.man = vars.game.add.sprite(100,vars.game.height - 200,'santa-running');
vars.man.animations.add('run');
vars.man.animations.play('run',15,true);
vars.man.width = (493/5)*0.5;
vars.man.height = 174*0.5;
vars.game.physics.arcade.enable(vars.man);
vars.man.body.gravity.y = 1500;
vars.man.body.collideWorldBounds = true;
vars.game.camera.follow(vars.man);
vars.cursors = vars.game.input.keyboard.createCursorKeys();
vars.spacebar = vars.game.input.keyboard.addKey(Phaser.Keyboard.SPACEBAR);
vars.score = vars.game.add.text(20,20,'',{
font: '24px Arial',
fill: 'white'
});
},
update:function(){
if (!vars.isGameOver) {
vars.gameScore += 0.5;
vars.gameSpeed += 0.03;
vars.score.text = 'Score:' + Math.floor(vars.gameScore);
vars.currentFrame++;
var moveAmount = vars.gameSpeed / 100;
vars.game.physics.arcade.collide(vars.man,vars.platforms);
if (vars.man.body.bottom >= vars.game.world.bounds.bottom) {
vars.isGameOver = true;
vars.endGame();
}
if (vars.cursors.up.isDown && vars.man.body.touching.down || vars.spacebar.isDown && vars.man.body.touching.down|| vars.game.input.mousePointer.isDown && vars.man.body.touching.down || vars.game.input.pointer1.isDown && vars.man.body.touching.down) {
vars.man.body.velocity.y = -500;
}
vars.platforms.children.forEach(function(platform){
platform.body.position.x -= moveAmount;
if (platform.body.right <= 0) {
platform.kill();
var plat = vars.platforms.getFirstExists(false);//获得第一个不存在的子元素,参数为true则为获得第一个存在的子元素
plat.reset(vars.lastPlatform.body.right + 192,vars.game.world.height - Math.floor(Math.random() * 50) -24);
plat.body.immovable = true;
vars.lastPlatform = plat;
}
});
}
}
}
最后可以就可以通过webpack开始打包了
基于ES6模块标准通过webpack打包HTM5项目的更多相关文章
- webpack打包vue项目之后生成的dist文件该怎么启动运行
亲测,webpack打包vue项目之后生成的dist文件可以部署到 express 服务器上运行. 我的vue项目结构如下: 1. 进入该vue项目目录,打开git bash,执行:npm run b ...
- 如何使用webpack打包前端项目
webpack概述 随着前端体积越来越大,功能越来越丰富,这时候就需要将前端工程化,而 webpack就是用于将前端各种文件打包起来. 一个简单的webpack应该包含以下几个概念 · 入口起点 · ...
- 《你不知道的JavaScript -- 上卷》笔记 --- 基于ES6新标准
1.let A:let关键字:将变量绑定到所在的任意作用域 function process(){ //do something } //在这个块中定义的内容完事就可以销毁 { let someRea ...
- Webpack入门——使用Webpack打包Angular项目的一个例子
2016.1.22,对大多数人来说,这是一个非常平常的日子,但这却是我决定在博客园写博客的日子.虽然注册博客园的博客已有4年8个月,却一直没有动手写过一篇博客,原因是觉得自己水平不行,写不出好东西,所 ...
- 16.如何做到webpack打包vue项目后,可以修改配置文件
问题描述: 前端需要修改restful API的url,但是打包之后,配置文件找不到了,如果在npm run build 生成dist后,这个配置也被写死了,传到运行的前端服务器上后,假设某次,api ...
- Docker + webpack 打包前端项目
码云代码地址: https://gitee.com/caonimashi/docker_deployment_front_end 构建基础镜像: 1.下载一个 Apline Linux 操作系统 ...
- webpack打包nodejs项目(前端代码)
PS.若本文没有帮到你可以看看我的进阶版点此前往 适用情况 首先说明,此情况不具备普遍性.若你的情况与笔者类似那么希望这篇文章能够帮到你. 我的项目情况是这样的:用node.js做后台,ejs做模板引 ...
- webpack打包vue项目,资源路径如何从绝对路径改为相对路径?css中的图片资源如何修改配置?
资源相对引用路径 问题描述 一般情况下,通过webpack+vuecli默认打包的css.js等资源,路径都是绝对的. 但当部署到带有文件夹的项目中,这种绝对路径就会出现问题,因为把配置的static ...
- 如何做到在webpack打包vue项目后,在外部动态修改配置文件
在我们做完vue项目后,只需要执行 npm run dist 就可以轻松进行打包转测试,可是如果我们临时需要修改一些配置文件比如域名,这时候我们就有点懵逼了,那就修改了再重新打一次包? NO NO N ...
随机推荐
- JQuery中 json 和字符串直接相互转换
json字符串转json对象:jQuery.parseJSON(jsonStr); json对象转json字符串:JSON.stringify(jsonObj); IE中可能对unicode使用“ ...
- 可用于Windows Server 2008 R2的Xbox One手柄、接收器驱动
让客厅里的Gen8可以玩FC和PS1游戏,折腾了半天,终于将Xbox One手柄驱动弄好: http://www.drvsky.com/Microsoft/Xbox_One.htm http://ww ...
- 深入了解Bundle和Map
[转]http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2015/0402/2684.html 前言 因为往Bundle对象中放入Map实际上 ...
- 安卓 listview与arrayadapter
今天有感于群里讨论的一个问题,很简单,但是问题还真是需要仔细看一下 问题:定义了一个最简单的arrayadapter,和listview结合使用,灭个item就显示个最简单的textView,一共6个 ...
- UVa 10074 - Take the Land
题目大意:和UVa 836 - Largest Submatrix差不多,只需要修改一下数据就可以了. #include <cstdio> #include <cstring> ...
- Borda count
波达计数法(Borda Count)是较为简单的排序投票法,每个选项借由选票上的排序来取得积分,积分最高者获胜.另一个类似的方法则是位置投票制. 投票人按喜好排列候选者.如果候选者在选票的排第一位,它 ...
- SNPs & MAF
SNPs,全称是single nucleotide polymorphisms,SNPs等位基因频率的容易估计.采用混和样本估算等位基因的频率是种高效快速的策略.该策略的原理是:首先选择参考样本制作标 ...
- Memo 的当前行、当前列与当前字符
procedure TForm1.Memo1Click(Sender: TObject); begin Text := Format('当前列:%d, 当前行:%d', [Memo1.CaretP ...
- @dynamic、@synthesize
声明property属性后,有2种实现选择: @synthesize 编译器期间,让编译器自动生成getter/setter方法. 当有自定义的存或取方法时,自定义会屏蔽自动生成该方法 @dynami ...
- Jsoup后台解析html、jsp网页
在一些网络爬虫或者从第三方网站抓取信息的程序都面临1个问题,如何从网页中把所需的信息提取出来,Jsoup是个比较好的选择,它能把网站内容解析成Document,再从document中取element就 ...