AlloyRenderingEngine开门大吉
快速入口
不读文章可以直接拐向这里:
github:https://github.com/AlloyTeam/AlloyRenderingEngine
website:http://alloyteam.github.io/AlloyRenderingEngine/
api:http://alloyteam.github.io/AlloyRenderingEngine/doc/
开门大吉
每次输入kmdj输入法自动提示【开门大吉】,输入kmdjs提示【开幕倒计时】,所以说kmdjs不仅仅是满满的血腥味
(kill all module define lib/framework, kill amd and cmd),还有着美好的寓意。
一定要提kmdjs是因为AlloyRenderingEngine是基于kmdjs进行模块化开发(其实使用kmdjs已经没有模块的概念了),只要class和namespace。
kmdjs的核心的核心就是{},class全部挂在 {}上。{}属于namespace。所以很自然而然得轻松实现循环依赖。当然kmdjs还有很多优点,如:
- 支持依赖可视
- 支持循环依赖
- 支持命名重复
- 支持压缩打包
- 支持代码美化
- 支持远程加载
- 支持延迟加载
- 支持模块共享
- 支持平铺依赖
- 支持断点调试
- 支持独立打包
- 支持一键下载
github:https://github.com/kmdjs/kmdjs
再造轮子
看过一些flash团队的html5开源项目,也读了读很多opengl转webgl的工程师的游戏引擎教程,他们视野够广,图形方面经验也很丰富,
但是项目的组织架构千奇百怪,一个人一个花样,一个团队一个花样。所以,kmdjs要出手了(当然也可以认为又多了一个新花样,
当至少是我觉得很满意、很清晰简洁的花样),去组织每一行没有归宿感的js代码。
目录结构
先看顶级目录结构

再看build里的目录结构

其中main.js:
kmdjs.config({
name: "BuildARE",
baseUrl: "../src",
classes: [
{ name: "ARE.DisplayObject", url: "are/display" },
{ name: "ARE.Bitmap", url: "are/display" },
{ name: "ARE.Sprite", url: "are/display" },
{ name: "ARE.Stage", url: "are/display" },
{ name: "ARE.Shape", url: "are/display" },
{ name: "ARE.Container", url: "are/display" },
{ name: "ARE.Txt", url: "are/display" },
{ name: "ARE.Matrix2D", url: "are/util" },
{ name: "ARE.Loader", url: "are/util" },
{ name: "ARE.UID", url: "are/util" },
{ name: "ARE.CanvasRenderer", url: "are/renderer" },
{ name: "ARE.WebGLRenderer", url: "are/renderer" },
{ name: "ARE.GLMatrix", url: "are/util" },
{ name: "ARE.RAF", url: "are/util" },
{ name: "ARE.FPS", url: "are/util" },
{ name: "ARE.Particle", url: "are/display" },
{ name: "ARE.Util", url: "are/util" },
{ name: "ARE.Vector2", url: "are/util" },
{ name: "ARE.ParticleSystem", url: "are/display" }
]
});
define("Main", ["ARE"], {
ctor: function () {
this instanceof DisplayObject;
this instanceof Bitmap;
this instanceof Sprite;
this instanceof Stage;
this instanceof Shape;
this instanceof Container;
this instanceof Txt;
this instanceof Matrix2D;
this instanceof Loader;
this instanceof UID;
this instanceof CanvasRenderer;
this instanceof WebGLRenderer;
this instanceof GLMatrix;
this instanceof RAF;
this instanceof FPS;
this instanceof Particle;
this instanceof Util;
this instanceof Vector2;
this instanceof ParticleSystem;
}
})
ctor是Main的构造函数,也是唯一一个会自动去new的构造函数,其余文件里面difine的class都需要自行去new才能执行。
ctor里面的一大堆instanceof代码主要是为了产生依赖,所以需要合并提取的class都需要写进去。
最后直接打开index就能导出代码。
且看导出后的are.js的最后几行:
if (typeof module != 'undefined' && module.exports && this.module !== module) {
module.exports = ARE
}
else if (typeof define === 'function' && define.amd) {
define(ARE)
}
else {
win.ARE = ARE
};
这样的话,你就可以随意码了,比如:
var stage = new ARE.Stage("#ourCanvas", localStorage.webgl == "1");
var txt = new ARE.Txt({
txt: "Alloy Rendering Engine",
fontSize: 25,
fontFamily: "arial"
});
stage.add(txt);
为了避免打点,js工程师一般这么干:
with (ARE) {
var stage = new Stage("#ourCanvas");
var txt = new Txt({
txt: "Alloy Rendering Engine",
fontSize: 25,
fontFamily: "arial"
});
stage.add(txt);
}
(function (Stage, Txt) {
var stage = new Stage("#ourCanvas");
var txt = new Txt({
txt: "Alloy Rendering Engine",
fontSize: 25,
fontFamily: "arial"
});
stage.add(txt);
})(ARE.Stage, ARE.Txt)
(function (ARE) {
var Stage = ARE.Stage, Txt = ARE.Txt;
var stage = new Stage("#ourCanvas");
var txt = new Txt({
txt: "Alloy Rendering Engine",
fontSize: 25,
fontFamily: "arial"
});
stage.add(txt);
})(ARE)
require(["./ARE"], function (ARE) {
var Stage = ARE.Stage, Txt = ARE.Txt;
var stage = new Stage("#ourCanvas");
var txt = new Txt({
txt: "Alloy Rendering Engine",
fontSize: 25,
fontFamily: "arial"
});
stage.add(txt);
})
define(function (require) {
var ARE = require("./ARE");
var Stage = ARE.Stage, Txt = ARE.Txt;
var stage = new Stage("#ourCanvas");
var txt = new Txt({
txt: "Alloy Rendering Engine",
fontSize: 25,
fontFamily: "arial"
});
stage.add(txt);
})
终于知道js的世界有多混乱了吧?!
写一段程序需要频繁打点是不对的,一是慢,二是麻烦。js工程师为了避免打点几乎绞尽脑汁。
上面是避免打点的一些手段,如果使用kmdjs,妈妈再也不用担心打点了:
define("Main", ["ARE"], {
ctor: function () {
var stage = new Stage("#ourCanvas");
var txt = new Txt({
txt: "Alloy Rendering Engine",
fontSize: 25,
fontFamily: "arial"
});
stage.add(txt);
}
})
Next
这篇主要讲了下目录结构以及kmdjs在are中的作用,还有are的build工具的使用以及模块化的看法,确切说还没有进入主题,甚至跑题,
但是非常重要,待续。
AlloyRenderingEngine开门大吉的更多相关文章
- css学习_css3过渡
1.css3过渡 注意:记住多属性设置的方式:若把过渡写在了hover里面的话鼠标移走时不会有过渡效果!:不同属性同时变时用 all 就可以实现了. 2.css3 transform属性 1.移动 ...
- 两分钟观看 nodejs、 iojs、 npmjs 之间的狗血剧情
开门大吉,欢迎光临.这是 乐玩nodejs npm工具库 微信公众号的第一篇文章,那就先来说说 nodejs/npm 的小秘密,话不多说,赶快开始: 通过一个时间线简要描述下 2008 年 V8 引擎 ...
- AlloyRenderingEngine燃烧的进度条
写在前面 Github: https://github.com/AlloyTeam/AlloyGameEngine HTML 5新增了progress标签,那么再去使用AlloyRenderingEn ...
- AlloyRenderingEngine文本框组件
写在前面 Github: https://github.com/AlloyTeam/AlloyGameEngine 在dom元素里,自带了input标签,设置其type为text,它就是一个文本框. ...
- AlloyRenderingEngine继承
写在前面 不读文章,只对代码感兴趣可以直接跳转到这里 https://github.com/AlloyTeam/AlloyGameEngine然后star一下,多谢支持:). 前几天发了篇向ES6靠齐 ...
- AlloyRenderingEngine之Shape
写在前面 不读文章,只对代码感兴趣可以直接跳转到这里 https://github.com/AlloyTeam/AlloyGameEngine 然后star一下,多谢支持:). 游戏或者应用中,不是所 ...
- AlloyRenderingEngine入门
写在前面 AlloyRenderingEngine是一款非常快速的渲染引擎,目前该项目已经合并至 https://github.com/AlloyTeam/AlloyGameEngine/ , 属于A ...
- CSS3实现开门动画
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&qu ...
- HDUOJ----1234 开门人和关门人(浙江大学考研题)
开门人和关门人 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Sub ...
随机推荐
- js实现继承的方式总结
js实现继承的5种方式 以下 均为 ES5 的写法: js是门灵活的语言,实现一种功能往往有多种做法,ECMAScript没有明确的继承机制,而是通过模仿实现的,根据js语言的本身的特性,js实现继承 ...
- SVN-让项目不包括Bin和Obj
方案一: 方案二: 方法三: 添加自定义文件夹或者文件的过滤 eg:.svn .git .vs obj bin *.o *.lo *.la *.al .libs *.so *.so.[0-9]* * ...
- LINQ系列:Linq to Object联接操作符
联接是指将一个数据源对象与另一个数据源对象进行关联或联合的操作.这两个数据源对象通过一个共同的值或属性进行关联. LINQ的联接操作符将包含可匹配(或相同)关键字的两个或多个数据源中的值进行匹配. L ...
- MySQL 外键
在MySQL中 (1)MySQL 数据表主要支持六种类型 ,分别是:BDB.HEAP.ISAM.MERGE.MYISAM.InnoBDB.这六种又分为两类,一类是”事务安全型”(transaction ...
- Objective-C中的Block回调模式
在前面的博客中提到了Block的概念和使用方法,个人感觉Block最爽的用法莫过于在回调时用block.感觉比委托回调和目标方法回调用着要顺手,好不好用还得读者亲自用一下才知道.如果 读者之前用过SS ...
- 如何在Windows Server 2008 上添加RD (远程桌面)会话主机配置的远程桌面授权服务器
在Windows Server系列的现存活跃产品中都默认的会开放两个随机附送的远程控制的授权,而一些特殊条件下我们需要启用多个远程终端连接,在购买了相应的授权之后,我们如何将配置好的服务器添加到远程桌 ...
- ZOJ Problem Set - 1292 Integer Inquiry
题目本身属于简单题,但是注意在输出的时候,题目很变态的对格式做了很多要求: 1.输入的N与下面的block有一个空行 2.每次输出与下一个输入的block有一个空行 3.但是特别注意,当是最后一个输出 ...
- ZOJ Problem Set - 1045 HangOver
#include <stdio.h> int main() { float c; int i; while(scanf("%f",&c)!=EOF&&a ...
- 奇妙的NULL值,你知道多少
<NULL值的多义性分析> 谈到NULL值,很多人都是很熟悉,但是深入了解后,又感觉到陌生,对其含义和用法,都无法很准确的理解.NULL在数据库和编程语言中,存在的意义和附带的含义不同. ...
- Moon.Orm与其他Orm的技术对比
有时候在思考大家为什么喜欢EF,为什么又出现这么多的Orm,为什么Nhiberate被人许多人接收又被许多人拒绝 最后发现结论:萝卜白菜各有所爱.适合自己的就是最好的. EF 微软团队支持(可谓强大的 ...