mirror of https://github.com/axmolengine/axmol.git
364 lines
8.4 KiB
JavaScript
364 lines
8.4 KiB
JavaScript
// cocos2d Helper
|
|
|
|
cc.c3 = cc.c3 || function (r, g, b) {
|
|
return {r: r, g: g, b: b};
|
|
};
|
|
|
|
cc.c4 = cc.c4 || function (r, g, b, o) {
|
|
return {r: r, g: g, b: b, a: o};
|
|
};
|
|
|
|
cc.c4f = cc.c4f || function (r, g, b, o) {
|
|
return {r: r, g: g, b: b, a: o};
|
|
};
|
|
|
|
cc.p = cc.p || function( x, y )
|
|
{
|
|
return {x:x, y:y};
|
|
};
|
|
|
|
cc.g = cc.g || cc.p;
|
|
cc.log = cc.log || log;
|
|
|
|
//
|
|
// cocos2d constants
|
|
//
|
|
cc.TEXTURE_PIXELFORMAT_RGBA8888 = 0;
|
|
cc.TEXTURE_PIXELFORMAT_RGB888 = 1;
|
|
cc.TEXTURE_PIXELFORMAT_RGB565 = 2;
|
|
cc.TEXTURE_PIXELFORMAT_A8 = 3;
|
|
cc.TEXTURE_PIXELFORMAT_I8 = 4;
|
|
cc.TEXTURE_PIXELFORMAT_AI88 = 5;
|
|
cc.TEXTURE_PIXELFORMAT_RGBA4444 = 6;
|
|
cc.TEXTURE_PIXELFORMAT_RGB5A1 = 7;
|
|
cc.TEXTURE_PIXELFORMAT_PVRTC4 = 8;
|
|
cc.TEXTURE_PIXELFORMAT_PVRTC4 = 9;
|
|
cc.TEXTURE_PIXELFORMAT_DEFAULT = cc.TEXTURE_PIXELFORMAT_RGBA8888;
|
|
|
|
cc.TEXT_ALIGNMENT_LEFT = 0;
|
|
cc.TEXT_ALIGNMENT_CENTER = 1;
|
|
cc.TEXT_ALIGNMENT_RIGHT = 2;
|
|
|
|
cc.VERTICAL_TEXT_ALIGNMENT_TOP = 0;
|
|
cc.VERTICAL_TEXT_ALIGNMENT_CENTER = 1;
|
|
cc.VERTICAL_TEXT_ALIGNMENT_BOTTOM = 2;
|
|
|
|
cc.IMAGE_FORMAT_JPEG = 0;
|
|
cc.IMAGE_FORMAT_PNG = 0;
|
|
|
|
cc.PROGRESS_TIMER_TYPE_RADIAL = 0;
|
|
cc.PROGRESS_TIMER_TYPE_BAR = 1;
|
|
|
|
cc.PARTICLE_TYPE_FREE = 0;
|
|
cc.PARTICLE_TYPE_RELATIVE = 1;
|
|
cc.PARTICLE_TYPE_GROUPED = 2;
|
|
cc.PARTICLE_DURATION_INFINITY = -1;
|
|
cc.PARTICLE_MODE_GRAVITY = 0;
|
|
cc.PARTICLE_MODE_RADIUS = 1;
|
|
cc.PARTICLE_START_SIZE_EQUAL_TO_END_SIZE = -1;
|
|
cc.PARTICLE_START_RADIUS_EQUAL_TO_END_RADIUS = -1;
|
|
|
|
cc.RED = cc.c3(255,0,0);
|
|
cc.GREEN = cc.c3(0,255,0);
|
|
cc.BLUE = cc.c3(0,0,255);
|
|
cc.BLACK = cc.c3(0,0,0);
|
|
cc.WHITE = cc.c3(255,255,255);
|
|
|
|
cc.POINT_ZERO = {x:0, y:0};
|
|
|
|
cc._reuse_p0 = {x:0, y:0};
|
|
cc._reuse_p1 = {x:0, y:0};
|
|
cc._reuse_p_index = 0;
|
|
cc._reuse_color3b = cc.c3(255, 255, 255 );
|
|
cc._reuse_color4b = cc.c4(255, 255, 255, 255 );
|
|
cc._reuse_grid = cc.g(0,0);
|
|
|
|
// dump config info, but only in debug mode
|
|
cc.dumpConfig = function()
|
|
{
|
|
if( cc.config.debug ) {
|
|
for(var i in cc.config)
|
|
cc.log( i + " = " + cc.config[i] );
|
|
}
|
|
};
|
|
|
|
//
|
|
// Point
|
|
//
|
|
cc._p = function( x, y )
|
|
{
|
|
if( cc._reuse_p_index === 0 ) {
|
|
cc._reuse_p0.x = x;
|
|
cc._reuse_p0.y = y;
|
|
cc._reuse_p_index = 1;
|
|
return cc._reuse_p0;
|
|
} else {
|
|
cc._reuse_p1.x = x;
|
|
cc._reuse_p1.y = y;
|
|
cc._reuse_p_index = 0;
|
|
return cc._reuse_p1;
|
|
}
|
|
};
|
|
|
|
cc._to_p = function( point )
|
|
{
|
|
return point;
|
|
};
|
|
|
|
cc._from_p = function( size )
|
|
{
|
|
return size;
|
|
};
|
|
|
|
//
|
|
// Grid
|
|
//
|
|
cc._g = function( x, y )
|
|
{
|
|
cc._reuse_grid.x = x;
|
|
cc._reuse_grid.y = y;
|
|
return cc._reuse_grid;
|
|
}
|
|
|
|
//
|
|
// Color
|
|
//
|
|
cc._c3 = function( r, g, b )
|
|
{
|
|
cc._reuse_color3b[0] = r;
|
|
cc._reuse_color3b[1] = g;
|
|
cc._reuse_color3b[2] = b;
|
|
return cc._reuse_color3b;
|
|
}
|
|
|
|
cc._c4 = function( r, g, b, a )
|
|
{
|
|
cc._reuse_color4b[0] = r;
|
|
cc._reuse_color4b[1] = g;
|
|
cc._reuse_color4b[2] = b;
|
|
cc._reuse_color4b[3] = a;
|
|
return cc._reuse_color4b;
|
|
}
|
|
|
|
//
|
|
// Size
|
|
//
|
|
cc.size = function(w,h)
|
|
{
|
|
return {width:w, height:h};
|
|
}
|
|
|
|
cc._to_size = function( size )
|
|
{
|
|
return size;
|
|
}
|
|
|
|
cc._from_size = function( size )
|
|
{
|
|
return size;
|
|
}
|
|
|
|
//
|
|
// Rect
|
|
//
|
|
cc.rect = function(x,y,w,h)
|
|
{
|
|
return {x:x, y:y, width:w, height:h};
|
|
}
|
|
|
|
cc._to_rect = function( rect )
|
|
{
|
|
return rect;
|
|
}
|
|
|
|
cc._from_rect = function( rect )
|
|
{
|
|
return rect;
|
|
}
|
|
|
|
// XXX Should be done in native
|
|
cc.rectIntersectsRect = function( rectA, rectB )
|
|
{
|
|
var bool = ! ( rectA.x > rectB.x + rectB.width ||
|
|
rectA.x + rectA.width < rectB.x ||
|
|
rectA.y > rectB.y +rectB.height ||
|
|
rectA.y + rectA.height < rectB.y );
|
|
|
|
return bool;
|
|
}
|
|
|
|
// point functions
|
|
cc.pAdd = cc.pAdd || function (p1, p2) {
|
|
return {x: p1.x + p2.x, y: p1.y + p2.y};
|
|
};
|
|
|
|
cc.pSub = cc.pSub || function (p1, p2) {
|
|
return {x: p1.x - p2.x, y: p1.y - p2.y};
|
|
}
|
|
|
|
cc.pMult = cc.pMult || function (p1, s) {
|
|
return {x: p1.x * s, y: p1.y * s};
|
|
};
|
|
|
|
//
|
|
// Array: for cocos2d-hmtl5 compatibility
|
|
//
|
|
cc.ArrayRemoveObject = function (arr, delObj) {
|
|
for (var i = 0; i < arr.length; i++) {
|
|
if (arr[i] == delObj) {
|
|
arr.splice(i, 1);
|
|
}
|
|
}
|
|
};
|
|
|
|
//
|
|
// Google "subclasses"
|
|
// borrowed from closure library
|
|
//
|
|
var goog = goog || {}; // Check to see if already defined in current scope
|
|
goog.inherits = function (childCtor, parentCtor) {
|
|
/** @constructor */
|
|
function tempCtor() {};
|
|
tempCtor.prototype = parentCtor.prototype;
|
|
childCtor.superClass_ = parentCtor.prototype;
|
|
childCtor.prototype = new tempCtor();
|
|
childCtor.prototype.constructor = childCtor;
|
|
|
|
// Copy "static" method, but doesn't generate subclasses.
|
|
// for( var i in parentCtor ) {
|
|
// childCtor[ i ] = parentCtor[ i ];
|
|
// }
|
|
};
|
|
goog.base = function(me, opt_methodName, var_args) {
|
|
var caller = arguments.callee.caller;
|
|
if (caller.superClass_) {
|
|
// This is a constructor. Call the superclass constructor.
|
|
ret = caller.superClass_.constructor.apply( me, Array.prototype.slice.call(arguments, 1));
|
|
|
|
// XXX: SpiderMonkey bindings extensions
|
|
// __associateObjWithNative( me, ret );
|
|
return ret;
|
|
}
|
|
|
|
var args = Array.prototype.slice.call(arguments, 2);
|
|
var foundCaller = false;
|
|
for (var ctor = me.constructor;
|
|
ctor; ctor = ctor.superClass_ && ctor.superClass_.constructor) {
|
|
if (ctor.prototype[opt_methodName] === caller) {
|
|
foundCaller = true;
|
|
} else if (foundCaller) {
|
|
return ctor.prototype[opt_methodName].apply(me, args);
|
|
}
|
|
}
|
|
|
|
// If we did not find the caller in the prototype chain,
|
|
// then one of two things happened:
|
|
// 1) The caller is an instance method.
|
|
// 2) This method was not called by the right caller.
|
|
if (me[opt_methodName] === caller) {
|
|
return me.constructor.prototype[opt_methodName].apply(me, args);
|
|
} else {
|
|
throw Error(
|
|
'goog.base called from a method of one name ' +
|
|
'to a method of a different name');
|
|
}
|
|
};
|
|
|
|
|
|
//
|
|
// Simple subclass
|
|
//
|
|
|
|
cc.Class = function(){};
|
|
|
|
cc.Class.extend = function (prop) {
|
|
var _super = this.prototype;
|
|
|
|
// Instantiate a base class (but only create the instance,
|
|
// don't run the init constructor)
|
|
initializing = true;
|
|
var prototype = new this();
|
|
initializing = false;
|
|
fnTest = /xyz/.test(function(){xyz;}) ? /\b_super\b/ : /.*/;
|
|
|
|
// Copy the properties over onto the new prototype
|
|
for (var name in prop) {
|
|
// Check if we're overwriting an existing function
|
|
prototype[name] = typeof prop[name] == "function" &&
|
|
typeof _super[name] == "function" && fnTest.test(prop[name]) ?
|
|
(function (name, fn) {
|
|
return function () {
|
|
var tmp = this._super;
|
|
|
|
// Add a new ._super() method that is the same method
|
|
// but on the super-class
|
|
this._super = _super[name];
|
|
|
|
// The method only need to be bound temporarily, so we
|
|
// remove it when we're done executing
|
|
var ret = fn.apply(this, arguments);
|
|
this._super = tmp;
|
|
|
|
return ret;
|
|
};
|
|
})(name, prop[name]) :
|
|
prop[name];
|
|
}
|
|
|
|
// The dummy class constructor
|
|
function Class() {
|
|
// All construction is actually done in the init method
|
|
if (!initializing && this.ctor)
|
|
this.ctor.apply(this, arguments);
|
|
}
|
|
|
|
// Populate our constructed prototype object
|
|
Class.prototype = prototype;
|
|
|
|
// Enforce the constructor to be what we expect
|
|
Class.prototype.constructor = Class;
|
|
|
|
// And make this class extendable
|
|
Class.extend = arguments.callee;
|
|
|
|
return Class;
|
|
};
|
|
|
|
cc.Layer.extend = cc.Class.extend;
|
|
cc.LayerGradient.extend = cc.Class.extend;
|
|
cc.Sprite.extend = cc.Class.extend;
|
|
cc.MenuItemFont.extend = cc.Class.extend;
|
|
|
|
//
|
|
// Chipmunk helpers
|
|
//
|
|
var cp = cp || {};
|
|
|
|
cp.v = cc.p;
|
|
cp._v = cc._p;
|
|
cp.vzero = cp.v(0,0);
|
|
|
|
//
|
|
// OpenGL Helpers
|
|
//
|
|
var gl = gl || {};
|
|
gl.NEAREST = 0x2600;
|
|
gl.LINEAR = 0x2601;
|
|
gl.REPEAT = 0x2901;
|
|
gl.CLAMP_TO_EDGE = 0x812F;
|
|
gl.CLAMP_TO_BORDER = 0x812D;
|
|
gl.LINEAR_MIPMAP_NEAREST = 0x2701;
|
|
gl.NEAREST_MIPMAP_NEAREST = 0x2700;
|
|
gl.ZERO = 0;
|
|
gl.ONE = 1;
|
|
gl.SRC_COLOR = 0x0300;
|
|
gl.ONE_MINUS_SRC_COLOR = 0x0301;
|
|
gl.SRC_ALPHA = 0x0302;
|
|
gl.ONE_MINUS_SRC_ALPHA = 0x0303;
|
|
gl.DST_ALPHA = 0x0304;
|
|
gl.ONE_MINUS_DST_ALPHA = 0x0305;
|
|
gl.DST_COLOR = 0x0306;
|
|
gl.ONE_MINUS_DST_COLOR = 0x0307;
|
|
gl.SRC_ALPHA_SATURATE = 0x0308;
|
|
|