快速入口

不读文章可以直接拐向这里:

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开门大吉的更多相关文章

  1. css学习_css3过渡

    1.css3过渡 注意:记住多属性设置的方式:若把过渡写在了hover里面的话鼠标移走时不会有过渡效果!:不同属性同时变时用  all 就可以实现了. 2.css3  transform属性 1.移动 ...

  2. 两分钟观看 nodejs、 iojs、 npmjs 之间的狗血剧情

    开门大吉,欢迎光临.这是 乐玩nodejs npm工具库 微信公众号的第一篇文章,那就先来说说 nodejs/npm 的小秘密,话不多说,赶快开始: 通过一个时间线简要描述下 2008 年 V8 引擎 ...

  3. AlloyRenderingEngine燃烧的进度条

    写在前面 Github: https://github.com/AlloyTeam/AlloyGameEngine HTML 5新增了progress标签,那么再去使用AlloyRenderingEn ...

  4. AlloyRenderingEngine文本框组件

    写在前面 Github: https://github.com/AlloyTeam/AlloyGameEngine 在dom元素里,自带了input标签,设置其type为text,它就是一个文本框. ...

  5. AlloyRenderingEngine继承

    写在前面 不读文章,只对代码感兴趣可以直接跳转到这里 https://github.com/AlloyTeam/AlloyGameEngine然后star一下,多谢支持:). 前几天发了篇向ES6靠齐 ...

  6. AlloyRenderingEngine之Shape

    写在前面 不读文章,只对代码感兴趣可以直接跳转到这里 https://github.com/AlloyTeam/AlloyGameEngine 然后star一下,多谢支持:). 游戏或者应用中,不是所 ...

  7. AlloyRenderingEngine入门

    写在前面 AlloyRenderingEngine是一款非常快速的渲染引擎,目前该项目已经合并至 https://github.com/AlloyTeam/AlloyGameEngine/ , 属于A ...

  8. CSS3实现开门动画

    <!DOCTYPE html> <html lang="en"> <head>  <meta charset="UTF-8&qu ...

  9. HDUOJ----1234 开门人和关门人(浙江大学考研题)

    开门人和关门人 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Sub ...

随机推荐

  1. Owin的URL编码怎么搞?以前都是HttpUtility.UrlEncode之类的,现在连system.web都没了,肿么办?

    Owin的URL编码怎么搞?以前都是HttpUtility.UrlEncode之类的,现在连system.web都没了,肿么办? 编码: Uri.EscapeDataString(name) 解码: ...

  2. OpenCascade Draw Test Harness

    OpenCascade Draw Test Harness eryar@163.com Abstract. Draw is a command interpreter based on Tcl/Tk ...

  3. JavaScript知识 一、JS的数据类型

    一.JS的数据类型 1.基本类型 JS共有5大基本类型,分别是: 1)Undefined.他只有一个值:undefined.如果一个变量被定义但是没有给他赋值,那么这个时候系统会默认给这个变量赋值为u ...

  4. Unity Shaders 第一个默认程序分析

    Unity Shaders 第一个默认程序 Shader "Custom/Shader" { Properties { _MainTex ("Base (RGB)&quo ...

  5. 【开源】OSharp3.3框架解说系列:开发计划与进度

    OSharp是什么? OSharp是个快速开发框架,但不是一个大而全的包罗万象的框架,严格的说,OSharp中什么都没有实现.与其他大而全的框架最大的不同点,就是OSharp只做抽象封装,不做实现.依 ...

  6. Mac OSX网络诊断命令

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 下面是一些Mac OSX下常用的网络诊断命令.它们能帮助我们发现网络问题.文中提到 ...

  7. ASP.NET:注销功能实现

    原理:清空Session 1.Web窗体:index.aspx <a href="logoutHandler.ashx">注销</a> 2.一般处理程序:L ...

  8. android UI 仿 win 8 模块化 标题,并实现 可长按拖动交换图片位置、可点击,且伴随动画特效

    转载请声明出处,谢谢!http://www.cnblogs.com/linguanh/ 先上效果图,给大家个直观效果,后上实现代码:  ->  ->->  ok,现在简单说下我上面的 ...

  9. [Data Structure & Algorithm] Hash那点事儿

    哈希表(Hash Table)是一种特殊的数据结构,它最大的特点就是可以快速实现查找.插入和删除.因为它独有的特点,Hash表经常被用来解决大数据问题,也因此被广大的程序员所青睐.为了能够更加灵活地使 ...

  10. PHP之call user func()函数

    在实际开发中通常会遇到这样的问题,决定调用某个函数是通过传入的参数决定的,例如: $functionName=$_post['functionName']; 接着我们需要访问一个叫$functionN ...