基于Vue的微信小游戏框架Gegjs

背景

相信做前端的朋友对Vuejs的双向绑定与组件化开发绝对印象深刻,笔者也为Vue的诸多特性颇为赞叹,它为前端的生态真的注入了太多力量,它的成功除了得益于Vue自身的健壮性之外,基于它的拓展性也满足了各个不同项目组特定的定制化的需求,也诞生了类似于针对微信小程序开发的mpvue,基于网页端开发的UI架构ElementUI等优秀项目。有些人可能会问,这些铺垫有什么用处,还不是想衬托目前还没有一个项目可以基于Vuejs开发微信小游戏的么?是的,所有的铺垫必然是有目的的,我觉得有必要介绍下这个项目诞生的原因。

首先,笔者从毕业后一直从事的是游戏与3D渲染方面的工作,对前端可以说是不同的领域,直到前两年接触了Webgl后,就慢慢的往Web渲染这块技术靠拢,用到Webgl的过程中也必然会跟前端的主流技术打交道,像jquery,jquery,jquery!有人会很惊叹,什么?这两年还有人用jquery做前端开发的么?很遗憾,当时转Webgl的我确实跟jquery打交道了大半年,主要原因也许是因为渲染层用到dom的机会不太多,也许是因为当时确实不太关注前端的新技术。好吧,主要原因还是因为我个人是个怀旧主义者,这么解释希望读者能接受。直到有一天我接触到了Vue,那一刻我发觉,糟了,大半年的jquery白用了,因为我一直觉得我在jquery领域真的是有见地,所以在此我还是把我这个教训与各位分享,技术千万不要闭门造车,也不要有怀旧的心态,拥抱新技术是技术人时刻应该关注的动向。还是说回接触到Vue后我的一些感触,我发现Vue真的是一个好东西,原本需要操作源数据才能改变的视图,只需要用对象进行管理,一旦数据改变,视图立马改变,通过这种方式很多功能需要繁杂的代码,现在只需要专注于数据层,而后我们的渲染规范就变成了经常与Vue打交道的过程,有些人可能会有疑问,用Vue开发的游戏,性能会有问题么?这个问题往往让人很难回答,开发效率的提升似乎总会带来性能的下降,理论上性能主要在Vue初始化过程会有影响,这取决于场景数据与复杂度,所以大型游戏不建议使用该方案,因为大型游戏要组织的数据过多,并且场景物体也过于复杂,但是实际开发中又会有些小惊喜,这里我们先不讨论这个话题,后面有机会我会专门对优化的问题开辟新的章节进行讨论。回到正题,开发后的游戏必然涉及到平台的问题,首先小游戏平台必须要首先考虑,于是就有了这个项目。

介绍

Gengine 是一个基于 Vue.js 核心开发的前端框架,与Vue采用Typescript不同,Geg采用的是Es6开发,并修改了 Vue.js 的底层实现,包括了compile与platforms,并新增gxml部分。框架通过xml组织视图层级,所以它与底层视图渲染的方式,如dom的渲染等并没有直接关系,也因为这个特点,虽然Gengine开发之初是为了使用Vue兼容微信小游戏而设计,但是理论上可以使用Geg.js开发任意特定平台的视图项目。

我们可以通过以下关系来描述Geg.js与MVVM的关系。


                              VIEW MODEL

┌----------┐                ┌---------------┐                          ┌----------┐

|          | ---------------| XMLNodeListen ├------------------------> |          |

|          |                |              |                           |          |

|  View    |                |              |                           |   Model  |

|          |                |              |                           |          |

|          | <------------- | Data Bindings ├<------------------------ |          |

└----------┘                └---------------┘                          └----------┘

    |           

    |                         

    |     ┌--------------------------┐

    └---->|  Geg.js Implementation   |

          └--------------------------┘

上面的关系图表明View视图的渲染逻辑需要用Geg.js针对特定平台实现


安装


# 克隆项目

git clone https://github.com/GengineJS/geg.git

# 进入项目目录

cd geg

# 安装依赖

yarn

# 本地开发 启动项目

yarn min


目录结构

本项目已经为你生成了一个完整的开发框架,提供了Geg.js开发过程中的源码结构,下面是整个项目的目录层级。


├── dist                      # rollup源码构建输出

├── src                      # 源代码

│   ├── compiler              # 编译相关

│   ├── core                  # 源码核心

│   ├── platforms            # 平台相关

│   ├── sfc                  # parser相关

│  └── index.js              # 源码入口

├── .babelrc                  # babel-loader 配置

├── config.js                # rollup配置

├── index.html                # 测试入口html

├── package.json              # package.json

├── test.xml                  # 测试xml模版相关

├── yarn-error.log            # 构建错误log

└── yarn.lock                # 构建依赖相关


初始化

Geg.js是以微信小游戏平台为开发初衷,那么我们以微信小游戏平台Geg-Babylonjs为例,可分为三种初始化方式

1. 加载xml文件。

由于Gengine不对dom进行直接操作,所以这里的el传递的是xml路径


import GegBabylon from './gegbabylon/index.js'

import Geg from './libs/geg.js'

Geg.use(GegBabylon)

let geg = new Geg({

  el: 'src/template.xml'

})

xml格式如下,外层必须通过template进行定义,说明其内部元素为解析模版


<template>

  <engine>

    <scene>

      <camera type="ArcRotateCamera"></camera>

      <light></light>

      <skybox></skybox>

      <mesh type="Sphere" :position="sPosition">

        <physics :mass="10"></physics>

      </mesh>

    </scene>

  </engine>

</template>

2. Geg对象内部定义template字符串。


import GegBabylon from './gegbabylon/index.js'

import Geg from './libs/geg.js'

Geg.use(GegBabylon)

let geg = new Geg({

  el: 'src/template.xml',

  template: "<engine><scene><camera type='ArcRotateCamera'></camera></scene></engine>"

})

3. 通过render与$mount方式。


import GegBabylon from './gegbabylon/index.js'

import Geg from './libs/geg.js'

Geg.use(GegBabylon)

let geg = new Geg({

    components: { App },

    render: (h) => h('App')

}).$mount()


官网地址

https://gegjs.com

其他语法

想了解更多语法指南,可参考Vuejs

生态圈

除了Vuejs对应插件外,还可以通过以下插件进行Gengine开发

  1. Geg-Babylonjs 通过Gengine实现对Babylonjs 3D引擎的操作。

  2. Geg-Threejs 通过Gengine实现对Threejs 3D引擎的操作。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,294评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,493评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,790评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,595评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,718评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,906评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,053评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,797评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,250评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,570评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,711评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,388评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,018评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,796评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,023评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,461评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,595评论 2 350

推荐阅读更多精彩内容

  • 基于Vue的一些资料 内容 UI组件 开发框架 实用库 服务端 辅助工具 应用实例 Demo示例 element★...
    尝了又尝阅读 1,142评论 0 1
  • UI组件 element - 饿了么出品的Vue2的web UI工具套件 Vux - 基于Vue和WeUI的组...
    鲁大师666阅读 43,372评论 5 97
  • UI组件 element - 饿了么出品的Vue2的web UI工具套件 Vux - 基于Vue和WeUI的组件库...
    卞卞村长L阅读 1,704评论 0 8
  • UI组件 element- 饿了么出品的Vue2的web UI工具套件 Vux- 基于Vue和WeUI的组件库 m...
    小姜先森o0O阅读 9,417评论 0 72
  • UI组件 element- 饿了么出品的Vue2的web UI工具套件 Vux- 基于Vue和WeUI的组件库 m...
    王喂马_阅读 6,452评论 1 77