Phaser 游戏实例(一)

phaser是一个基于pixi渲染引擎的开发框架,用其api文档里的一句话来形容就是:你所见的世界是一幅油画。Phaser里最基本的对象或者说是元素就是World,如果有兴趣,你也可以把你的canvas当做艺术品,做出你想要的东西。Phaser的API和教程介绍已经很多了,不做重复,本文重点分享一下如何使用 phaser,webpack, es6 系统的开发一款小游戏。

环境搭建

  • 通常开发一款H5的phaser游戏的时候,如果通过es5语法来实现一些函数操作或者继承框架的类函数比较复杂,下文中我会详细介绍。所以我们需要引入babel模块来使用es6进行代码开发。
  • phaser虽然提供了强大的API,减少了很多的代码量,但是做一款不复杂但是完整的游戏在一个JS文件中无论是阅读还是维护相当的不方便,所以按照场景或者功能分发成多个模块进行开发是有必要的
  • 相关package.json可以参考https://github.com/lean/phaser-es6-webpack
  • 核心需求主要是 1. babel全家桶,如果你需要代码里进行对象结构等es7新特性可以引入babel-preset-stage-2 2. webpack以及对应的本地服务器 3. phaser v2.6.2(如果你不需要新增特性的话,不推荐使用phaser-ce);

webpack.config配置

var path = require('path');
var webpack = require('webpack');
var HtmlWebpackPlugin = require("html-webpack-plugin");
var phaserModule = path.join(__dirname, '/node_modules/phaser/');
var phaser = path.join(phaserModule, 'build/custom/phaser-arcade-physics.js');
var pixi = path.join(phaserModule, 'build/custom/pixi.js');

配置相应的库文件路径,这里我们使用的是带有arcade物理引擎的phaser版本,这里如果你使用的是phaser-ce版本的话,默认的物理引擎是p2, 所以如果你不打算使用P2的话,代码运行会报p2对象未定义的错误。

    entry: {
        app: [
            path.resolve(__dirname, "./Parkour/main.js")
        ]
    }

在module 的export里,我们首先要定义入口文件路径.

接下来是配置webpack中重要的功能 -- Loaders

   module: {
        loaders: [
            {
                test: /\.json$/,
                loader: 'json-loader'
            },
            {
                test: /\.js$/,
                exclude: /node-modules/,
                loader: 'babel-loader'
            },
            {
                test: /\.(png|jpg)$/,
                loader: 'url-loader?limit=1024&name=[name].[ext]'
            },
            {
                test: /pixi\.js$/,
                loader: 'expose-loader?PIXI'
            },
            {
                test: /phaser-arcade-physics\.js$/,
                loader: 'expose-loader?Phaser'
            }
        ]
    }

上面是通过正则在配置文件中绑定loaders
test部分是一个匹配被处理文件后缀名的正则表达式,上面是针对几种不同格式的文件所用到相对应的loader:

  1. json-loader用来处理对应的json文件转为js文件,你可以直接在js代码中调用它
  2. babel-loader用来将es6, es7的js文件转为可供现代浏览器识别的es5格式的js文件。
  3. url-loader类似于file-loader,但是它添加了limit属性,如果文件大小<limit,会自动将其转为base64编码减少资源的请求数。
  4. 最后针对pixi和phaser的第三方js源码进行模块化,这里通过expose将模块添加到全局对象Phaser和PIXI, 使得phaser能够正常调用pixi文件中的PIXI对象 (webpack2 需要写全称expose-loader).
    entry: {
        app: [
            path.resolve(__dirname, "./Parkour/main.js")
        ],
        vendor: ['pixi', 'phaser']
    },
    plugins: [
        new webpack.optimize.CommonsChunkPlugin({
            name: 'vendor',
            filename: 'vendor.bundle.js'
        })
    ]

针对CommonsChunkPlugin的使用,首先在入口配置中添加vendor,写入要打包的第三方库,然后我们实例化webpack的公共代码提取插件,将配置名为vendor里的第三方代码库进行合并。这样就可以将phaser, pixi以及其他业务需要引入的库文件合并成vendor.bundle.js

  • webpack.config的详细配置见:点我
  • 生产环境下的webpack.config: 点我
下一章: phaser游戏制作的初始化设置。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • GitChat技术杂谈 前言 本文较长,为了节省你的阅读时间,在文前列写作思路如下: 什么是 webpack,它要...
    萧玄辞阅读 14,333评论 7 110
  • 无意中看到zhangwnag大佬分享的webpack教程感觉受益匪浅,特此分享以备自己日后查看,也希望更多的人看到...
    小小字符阅读 12,542评论 7 35
  • webpack 介绍 webpack 是什么 为什么引入新的打包工具 webpack 核心思想 webpack 安...
    yxsGert阅读 11,543评论 2 71
  • 写在开头 先说说为什么要写这篇文章, 最初的原因是组里的小朋友们看了webpack文档后, 表情都是这样的: (摘...
    Lefter阅读 10,676评论 4 31
  • “哎呀,旁边哪位啊,别撞我好吗”本来就挤,还撞来撞去的!不要活了! “……”气死我了,竟然一点都没有要挪一挪的意思...
    清风曦来阅读 1,560评论 1 1