教你如何用HTML5和JS实现切水果游戏
导读:收集整理的这篇文章主要介绍了教你如何用HTML5和JS实现切水果游戏,觉得挺不错的,现在分享给大家,也给大家做个参考。切水果游戏曾经是一款风靡手机的休闲游戏,今天要介绍的就是一款网页版的切水果游戏,由JavaScript和HTML5实现,虽...
收集整理的这篇文章主要介绍了教你如何用HTML5和JS实现切水果游戏,觉得挺不错的,现在分享给大家,也给大家做个参考。切水果游戏曾经是一款风靡手机的休闲游戏,今天要介绍的就是一款网页版的切水果游戏,由JavaScript和HTML5实现,虽然功能和原版的相差很大,但是基本的功能还是具备了,还是模仿挺逼真的。有一定JavaScript水平的朋友可以看看源代码,相信你的JavaScript水平会有很大提升。在线演示源码下载
所有JavaScript代码
/** * this file was compiled by jsbuild 0.9.6 * @date Fri, 20 Jul 2012 16:21:18 UTC * @author dron * @sITe http://ucren.COM */void function(global){
VAR mapping = {
}
, cache = {
}
;
global.startModule = function(m){
require(m).start();
}
;
global.define = function(id, func){
mapping[id] = func;
}
;
global.require = function(id){
if(!/\.js$/.test(id)) id += '.js';
if(cache[id]) return cache[id];
else return cache[id] = mapping[id]({
}
);
}
;
}
(this);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\collide.js */ define("scripts/collide.js", function(exports){
var fruit = require("scripts/factory/fruit");
var Ucren = require("scripts/lib/ucren");
var fruits = fruit.getFruitInView();
/** * 碰撞检测 */ exports.check = function( knife ){
var ret = [], index = 0;
fruits.foreach(function( fruit ){
var ck = lineinEllipse( knife.slice( 0, 2 ), knife.slice( 2, 4 ), [ fruit.originX, fruit.originY ], fruit.radius );
if( ck ) ret[ index ++ ] = fruit;
}
);
return ret;
}
;
function sqr(x){
return x * x;
}
function sign(n){
return n 0 ? -1 : ( n >
0 ? 1 : 0 );
}
function equation12( a, b, c ){
if(a == 0)return;
var delta = b * b - 4 * a * c;
if(delta == 0) return [ -1 * b / (2 * a), -1 * b / (2 * a) ];
else if(delta >
0) return [ (-1 * b + Math.sqrt(delta)) / (2 * a), (-1 * b - Math.sqrt(delta)) / (2 * a) ];
}
// 返回线段和椭圆的两个交点,如果不相交,返回 null function lineXEllipse( p1, p2, c, r, e ){
// 线段:p1, p2 圆心:c 半径:r 离心率:e if (r = 0) return;
e = e === undefined ? 1 : e;
var t1 = r, t2 = r * e, k;
a = sqr( t2) * sqr(p1[0] - p2[0]) + sqr(t1) * sqr(p1[1] - p2[1]);
if (a = 0) return;
b = 2 * sqr(t2) * (p2[0] - p1[0]) * (p1[0] - c[0]) + 2 * sqr(t1) * (p2[1] - p1[1]) * (p1[1] - c[1]);
c = sqr(t2) * sqr(p1[0] - c[0]) + sqr(t1) * sqr(p1[1] - c[1]) - sqr(t1) * sqr(t2);
if (!( k = equation12(a, b, c, t1, t2) )) return;
var result = [ [ p1[0] + k[0] * (p2[0] - p1[0]), p1[1] + k[0] * (p2[1] - p1[1]) ], [ p1[0] + k[1] * (p2[0] - p1[0]), p1[1] + k[1] * (p2[1] - p1[1]) ] ];
if ( !( ( sign( result[0][0] - p1[0] ) * sign( result[0][0] - p2[0] ) = 0 ) &
&
( sign( result[0][1] - p1[1] ) * sign( result[0][1] - p2[1] ) = 0 ) ) ) result[0] = null;
if ( !( ( sign( result[1][0] - p1[0] ) * sign( result[1][0] - p2[0] ) = 0 ) &
&
( sign( result[1][1] - p1[1] ) * sign( result[1][1] - p2[1] ) = 0 ) ) ) result[1] = null;
return result;
}
// 判断计算线段和椭圆是否相交 function lineInEllipse( p1, p2, c, r, e ){
var t = lineXEllipse( p1, p2, c, r, e );
return t &
&
( t[0] || t[1] );
}
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\control.js */ define("scripts/control.js", function(exports){
var Ucren = require("scripts/lib/ucren");
var knife = require("scripts/object/knife");
var message = require("scripts/message");
var state = require("scripts/state");
var canvasLeft, canvasTop;
canvasLeft = canvasTop = 0;
exports.init = function(){
this.fixCanvasPos();
this.installDragger();
this.installClicker();
}
;
exports.installDragger = function(){
var dragger = new Ucren.Basicdrag({
tyPE: "calc" }
);
dragger.on( "returnValue", function( dx, dy, x, y, kf ){
if( kf = knife.through( x - canvasLeft, y - canvasTop ) ) message.postMessage( kf, "slice" );
}
);
dragger.on( "startDrag", function(){
knife.newKnife();
}
);
dragger.bind( document.documentElement );
}
;
exports.installClicker = function(){
Ucren.addEvent( document, "click", function(){
if( state( "click-enable" ).ison() ) message.postMessage( "click" );
}
);
}
;
exports.fixCanvasPos = function(){
var de = document.documentElement;
var fix = function( e ){
canvasLeft = ( de.clientWidth - 640 ) / 2;
canvasTop = ( de.clientHeight - 480 ) / 2 - 40;
}
;
fix();
Ucren.addEvent( window, "resize", fix );
}
;
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\game.js */ define("scripts/game.js", function(exports){
/** * game LOGic */ var timeline = require("scripts/timeline");
var Ucren = require("scripts/lib/ucren");
var sound = require("scripts/lib/sound");
var fruit = require("scripts/factory/fruit");
var score = require("scripts/object/score");
var message = require("scripts/message");
var state = require("scripts/state");
var lose = require("scripts/object/lose");
var gameOver = require("scripts/object/game-over");
var knife = require("scripts/object/knife");
// var sence = require("scripts/sence");
var background = require("scripts/object/background");
var light = require("scripts/object/light");
var scoreNumber = 0;
var random = Ucren.randomNumber;
var volleyNum = 2, volleyMultipleNumber = 5;
var fruits = [];
var gameInterval;
var snd;
var boomsnd;
// fruit barbette var barbette = function(){
if( fruits.length >
= volleyNum ) return ;
var startX = random( 640 ), endX = random( 640 ), startY = 600;
var f = fruit.create( startX, startY ).shotOut( 0, endX );
fruits.push( f );
snd.play();
barbette();
}
;
// start game exports.start = function(){
snd = sound.create( "sound/throw" );
boomSnd = sound.create( "sound/boom" );
timeline.setTimeout(function(){
state( "game-state" ).set( "playing" );
gameInterval = timeline.setInterval( barbette, 1e3 );
}
, 500);
}
;
exports.gameOver = function(){
state( "game-state" ).set( "over" );
gameInterval.stop();
gameOver.show();
// timeline.setTimeout(function(){
// // sence.switchSence( "home-menu" );
// // TODO: require 出现互相引用时,造成死循环,这个问题需要跟进,这里暂时用 postMessage 代替 // message.postMessage( "home-menu", "sence.switchSence" );
// }
, 2000);
scoreNumber = 0;
volleyNum = 2;
fruits.length = 0;
}
;
exports.applyScore = function( score ){
if( score >
volleyNum * volleyMultipleNumber ) volleyNum ++, volleyMultipleNumber += 50;
}
;
exports.sliceAt = function( fruit, angle ){
var index;
if( state( "game-state" ).isnot( "playing" ) ) return;
if( fruit.type != "boom" ){
fruit.broken( angle );
if( index = fruits.indexOf( fruit ) ) fruits.splice( index, 1 );
score.number( ++ scoreNumber );
this.applyScore( scoreNumber );
}
else{
boomSnd.play();
this.pauseAllFruit();
background.wobble();
light.start( fruit );
}
}
;
exports.pauseAllFruit = function(){
gameInterval.stop();
knife.pause();
fruits.invoke( "pause" );
}
;
// message.addEventListener("fruit.fallOff", function( fruit ){
// var index;
// if( ( index = fruits.indexOf( fruit ) ) >
-1 ) // fruits.splice( index, 1 );
// }
);
message.addEventListener("fruit.remove", function( fruit ){
var index;
if( ( index = fruits.indexOf( fruit ) ) >
-1 ) fruits.splice( index, 1 );
}
);
var eventFruitFallOutOfViewer = function( fruit ){
if( fruit.type != "boom" ) lose.showLoseAt( fruit.originX );
}
;
state( "game-state" ).hook( function( value ){
if( value == "playing" ) message.addEventListener( "fruit.fallOutOfViewer", eventFruitFallOutOfViewer );
else message.removeEventListener( "fruit.fallOutOfViewer", eventFruitFallOutOfViewer );
}
);
message.addEventListener("game.over", function(){
exports.gameOver();
knife.switchOn();
}
);
message.addEventListener("overWhiteLight.show", function(){
knife.endAll();
for(var i = fruits.length - 1;
i >
= 0;
i --) fruits[i].remove();
background.stop();
}
);
message.addEventListener("click", function(){
state( "click-enable" ).off();
gameOver.hide();
message.postMessage( "home-menu", "sence.switchSence" );
}
);
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\layer.js */ define("scripts/layer.js", function(exports){
/** * layer manager */ var Raphael = require("scripts/lib/raphael");
var Ucren = require("scripts/lib/ucren");
var layers = {
}
;
var zindexs = {
"default": zi(), "light": zi(), "knife": zi(), "fruit": zi(), "juice": zi(), "flash": zi(), "mask": zi() }
;
exports.createImage = function( layer, src, x, y, w, h ){
layer = this.getLayer( layer );
return layer.image( src, x, y, w, h );
}
;
exports.createText = function( layer, text, x, y, fill, size ){
layer = this.getLayer( layer );
if( Ucren.isIe ) y += 2;
return layer.text(x, y, text).attr({
fill: fill || "#fff", "font-size": size || "14px", "font-family": "黑体", "text-anchor": "start" }
);
}
;
exports.getLayer = function( name ){
var p, layer;
name = name || "default";
if( p = layers[name] ){
return p;
}
else{
layer = Ucren.makeElement( "p", {
"class": "layer", "style": "z-index: " + ( zindexs[name] || 0 ) + ";
" }
);
Ucren.Element( "extra" ).add( layer );
p = layers[name] = Raphael( layer, 640, 480 );
// if( Ucren.isSafari ) // p.safari();
return p;
}
}
;
function zi(){
return zi.num = ++ zi.num || 2;
}
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\main.js */ define("scripts/main.js", function(exports){
var timeline = require("scripts/timeline");
var tools = require("scripts/tools");
var sence = require("scripts/sence");
var Ucren = require("scripts/lib/ucren");
var buzz = require("scripts/lib/buzz");
var control = require("scripts/control");
var csl = require("scripts/object/console");
var message = require("scripts/message");
var state = require("scripts/state");
var game = require("scripts/game");
var collide = require("scripts/collide");
var setTimeout = timeline.setTimeout.bind( timeline );
var log = function(){
var time = 1e3, add = 300, fn;
fn = function( text ){
setTimeout( function(){
csl.log( text );
}
, time );
time += add;
}
;
fn.clear = function(){
setTimeout( csl.clear.bind( csl ), time );
time += add;
}
;
return fn;
}
();
exports.start = function(){
[ timeline, sence, control ].invoke( "init" );
log( "正在加载鼠标控制脚本" );
log( "正在加载图像资源" );
log( "正在加载游戏脚本" );
log( "正在加载剧情" );
log( "正在初始化" );
log( "正在启动游戏..." );
log.clear();
setTimeout( sence.switchSence.saturate( sence, "home-menu" ), 3000 );
}
;
message.addEventListener("slice", function( knife ){
var fruits = collide.check( knife ), angle;
if( fruits.length ) angle = tools.getAngleByRadian( tools.pointToRadian( knife.slice(0, 2), knife.slice(2, 4) ) ), fruits.forEach(function( fruit ){
message.postMessage( fruit, angle, "slice.at" );
}
);
}
);
message.addEventListener("slice.at", function( fruit, angle ){
if( state( "sence-state" ).isnot( "ready" ) ) return ;
if( state( "sence-name" ).is( "game-body" ) ){
game.sliceAt( fruit, angle );
return ;
}
if( state( "sence-name" ).is( "home-menu" ) ){
fruit.broken( angle );
if( fruit.isHomeMenu ) switch( 1 ){
case fruit.isDojoIcon: sence.switchSence( "dojo-body" );
break;
case fruit.isNewGameIcon: sence.switchSence( "game-body" );
break;
case fruit.isQuitIcon: sence.switchSence( "quit-body" );
break;
}
return ;
}
}
);
var tip = "";
if( !Ucren.isChrome ) tip = "$为了获得最佳流畅度,推荐您使用 span class='b'>
GOOGLE Chrome/span>
体验本游戏";
if( !buzz.isSupported() ) tip = tip.replace( "$", "您的浏览器不支持 &
lt;
audio&
gt 播放声效,且" );
tip = tip.replace( "$", "" );
Ucren.Element( "browser" ).html( tip );
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\message.js */ define("scripts/message.js", function(exports){
/** * a simple message manager * @author dron * @date 2012-06-27 */ var Ucren = require("scripts/lib/ucren");
/** * send a message * @param {
Any}
message,message... message contents * @param {
String}
to message address */ exports.postMessage = function( message/*, message, message... */, to ){
var messages = [].slice.call( arguments, 0 ), splitIndex = messages.length - 1;
to = messages[ splitIndex ];
messages.slice( 0, splitIndex );
Ucren.dispatch( to, messages );
}
;
/** * bind an message handler * @param {
String}
From message address * @param {
Function}
fn message handler */ exports.addEventListener = function( from, fn ){
Ucren.dispatch( from, fn );
}
;
/** * remove an message handler * @param {
String}
from message address * @param {
Function}
fn message handler */ exports.removeEventListener = function( from, fn ){
Ucren.dispatch.remove( from, fn );
}
;
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\sence.js */ define("scripts/sence.js", function(exports){
var Ucren = require("scripts/lib/ucren");
var sound = require("scripts/lib/sound");
var fruit = require("scripts/factory/fruit");
var flash = require("scripts/object/flash");
var state = require("scripts/state");
var message = require("scripts/message");
// the fixed elements var background = require("scripts/object/background");
var fps = require("scripts/object/fps");
// the home page elements var homeMask = require("scripts/object/home-mask");
var logo = require("scripts/object/logo");
var ninja = require("scripts/object/ninja") var homeDesc = require("scripts/object/home-desc");
var dojo = require("scripts/object/dojo");
var newGame = require("scripts/object/new-game");
var quit = require("scripts/object/quit");
var newSign = require("scripts/object/new");
var peach, sandia, boom;
// the elements in game body var score = require("scripts/object/score");
var lose = require("scripts/object/lose");
// the game logic var game = require("scripts/game");
// the elements in 'developing' module var developing = require("scripts/object/developing");
var gameOver = require("scripts/object/game-over");
// commons var message = require("scripts/message");
var timeline = require("scripts/timeline");
var setTimeout = timeline.setTimeout.bind( timeline );
var setInterval = timeline.setInterval.bind( timeline );
var menuSnd;
var gameStartSnd;
// initialize sence exports.init = function(){
menuSnd = sound.create( "sound/menu" );
gameStartSnd = sound.create( "sound/start" );
[ background, homeMask, logo, ninja, homeDesc, dojo, newSign, newGame, quit, score, lose, developing, gameOver, flash /*, fps */ ].invoke( "set" );
// setInterval( fps.update.bind( fps ), 500 );
}
;
// switch sence exports.switchSence = function( name ){
var curSence = state( "sence-name" );
var senceState = state( "sence-state" );
if( curSence.is( name ) ) return ;
var onHide = function(){
curSence.set( name );
senceState.set( "entering" );
switch( name ){
case "home-menu": this.showMenu( onShow );
break;
case "dojo-body": this.showDojo( onShow );
break;
case "game-body": this.showNewGame( onShow );
break;
case "quit-body": this.showQuit( onShow );
break;
}
}
.bind( this );
var onShow = function(){
senceState.set( "ready" );
if( name == "dojo-body" || name == "quit-body" ){
exports.switchSence( "home-menu" );
}
}
;
senceState.set( "exiting" );
if( curSence.isunset() ) onHide();
else if( curSence.is( "home-menu" ) ) this.hideMenu( onHide );
else if( curSence.is( "dojo-body" ) ) this.hideDojo( onHide );
else if( curSence.is( "game-body" ) ) this.hideNewGame( onHide );
else if( curSence.is( "quit-body" ) ) this.hideQuit( onHide );
}
;
// to enter home page menu exports.showMenu = function( callback ){
var callee = arguments.callee;
var times = callee.times = ++ callee.times || 1;
peach = fruit.create( "peach", 137, 333, true );
sandia = fruit.create( "sandia", 330, 322, true );
boom = fruit.create( "boom", 552, 367, true, 2500 );
[ peach, sandia, boom ].forEach(function( f ){
f.isHomeMenu = 1;
}
);
peach.isDojoIcon = sandia.isNewGameIcon = boom.isQuitIcon = 1;
var group = [ [ homeMask, 0 ], [ logo, 0 ], [ ninja, 500 ], [ homeDesc, 1500 ], [ dojo, 2000 ], [ newGame, 2000 ], [ quit, 2000 ], [ newSign, 2000 ], [ peach, 2000 ], [ sandia, 2000 ], [ boom, 2000 ] ];
group.invoke( "show" );
[ peach, sandia ].invoke( "rotate", 2500 );
menuSnd.play();
setTimeout( callback, 2500 );
}
;
// to exit home page menu exports.hideMenu = function( callback ){
[ newSign, dojo, newGame, quit ].invoke( "hide" );
[ homeMask, logo, ninja, homeDesc ].invoke( "hide" );
[ peach, sandia, boom ].invoke( "fallOff", 150 );
menuSnd.stop();
setTimeout( callback, fruit.getDropTimeSetting() );
}
;
// to enter game body exports.showNewGame = function( callback ){
score.show();
lose.show();
game.start();
gameStartSnd.play();
setTimeout( callback, 1000 );
}
;
// to exit game body exports.hideNewGame = function( callback ){
score.hide();
lose.hide();
gameStartSnd.stop();
setTimeout( callback, 1000 );
}
;
// to enter dojo mode exports.showDojo = function( callback ){
developing.show( 250 );
setTimeout( callback, 1500 );
}
;
// to exit dojo mode exports.hideDojo = function( callback ){
// TODO: setTimeout( callback, 1000 );
}
;
// to enter quit page exports.showQuit = function( callback ){
developing.show( 250 );
setTimeout( callback, 1500 );
}
;
// to exit quit page exports.hideQuit = function( callback ){
// TODO: setTimeout( callback, 1000 );
}
;
message.addEventListener("sence.switchSence", function( name ){
exports.switchSence( name );
}
);
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\state.js */ define("scripts/state.js", function(exports){
/** * a simple state manager * @author dron * @date 2012-06-28 */ var Ucren = require("scripts/lib/ucren");
var timeline = require("scripts/timeline");
/** * usage: * state( key ).is( value ) ->
determine if the value of key is the given value * state( key ).isnot( value ) ->
determine if the value of key is not given value * state( key ).ison() ->
determine if the value of key is the boolean value 'true' * state( key ).isoff() ->
determine if the value of key is the boolean value 'false' * state( key ).isunset() ->
determine if the value of key is undefined * state( key ).set( value ) ->
set the value of key to a given value * state( key ).get() ->
get the value of key * state( key ).on() ->
set the value of key to boolean value 'true' * state( key ).off() ->
set the value of key to boolean value 'false' */ var stack = {
}
;
var cache = {
}
;
var callbacks = {
}
;
exports = function( key ){
if( cache[ key ] ) return cache[ key ];
return cache[ key ] = {
is: function( value ){
return stack[key] === value;
}
, isnot: function( value ){
return stack[key] !== value;
}
, ison: function(){
return this.is( true );
}
, isoff: function(){
return this.isnot( true );
}
, isunset: function(){
return this.is( undefined );
}
, set: function(){
var lastValue = NaN;
return function( value ){
var c;
stack[key] = value;
if( lastValue !== value &
&
( c = callbacks[ key ] ) ) for(var i = 0, l = c.length;
i l;
i ++) c[i].call( this, value );
lastValue = value;
}
}
(), get: function(){
return stack[key];
}
, on: function(){
var me = this;
me.set( true );
return {
keep: function( time ){
timeline.setTimeout( me.set.saturate( me, false ), time );
}
}
}
, off: function(){
var me = this;
me.set( false );
return {
keep: function( time ){
timeline.setTimeout( me.set.saturate( me, true ), time );
}
}
}
, hook: function( fn ){
var c;
if( !( c = callbacks[ key ] ) ) callbacks[ key ] = [ fn ];
else c.push( fn );
}
, unhook: function(){
// TODO: }
}
}
;
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\timeline.js */ define("scripts/timeline.js", function(exports){
/** * a easy timeline manager * @version 1.0 * @author dron */ var Ucren = require("scripts/lib/ucren");
var timerCache = {
}
;
var timeline = {
}
;
// var timer = timeline;
// or>
// var timer = timeline.use( name ).init( 10 );
// to use a new timeline instance // // var t = timer.createTask(...);
// t.stop();
// // timer.setTimeout(...);
// timer.setInterval(...);
// timer.getFPS();
function ClassTimer(){
this.tasks = [];
this.addingTasks = [];
this.adding = 0;
}
/** * initialize timeline */ ClassTimer.PRototype.init = function( ms ){
var me = this;
if( me.inited ) return ;
else me.inited = 1;
me.startTime = now();
me.intervalTime = ms || 5;
me.count = 0;
me.intervalFn = function(){
me.count ++;
me.update( now() );
}
;
me.start();
return me;
}
;
/** * create a task * @param {
Object}
conf the config * @return {
Task}
a task instance */ ClassTimer.prototype.createTask = function( conf ){
/* e.g. timer.createTask({
start: 500, duration: 2000, data: [a, b, c,..], object: module, onTimeUpdate: fn(time, a, b, c,..), onTimeStart: fn(a, b, c,..), onTimeEnd: fn(a, b, c,..), recycle: [] }
);
*/ var task = createTask( conf );
this.addingTasks.unshift( task );
this.adding = 1;
if( conf.recycle ) this.taskList( conf.recycle, task );
this.start();
return task;
}
;
/** * use a array to recycle the task * @param {
Array}
queue be use for recycling task * @param {
Task}
task a task instance * @return {
Array}
this queue */ ClassTimer.prototype.taskList = function( queue, task ){
if( !queue.clear ) queue.clear = function(){
var i = this.length;
while( i -- ) task = this[i], task.stop(), this.splice( i, 1 );
return this;
}
;
if( task ) queue.unshift( task );
return queue;
}
;
/** * create a timer for once callback * @param {
Function}
fn callback function * @param {
Number}
time time, unit: ms */ ClassTimer.prototype.setTimeout = function( fn, time ){
// e.g. setTimeout(fn, time);
return this.createTask({
start: time, duration: 0, onTimeStart: fn }
);
}
;
/** * create a timer for ongoing callback * @param {
Function}
fn callback function * @param {
Number}
time time, unit: ms */ ClassTimer.prototype.setInterval = function( fn, time ){
// e.g. setInterval(fn, time);
var timer = setInterval( fn, time );
return {
stop: function(){
clearInterval( timer );
}
}
;
}
;
/** * get the current fps * @return {
Number}
fps number */ ClassTimer.prototype.getFPS = function(){
var t = now(), c = this.count, fps = c / ( t - this.startTime ) * 1e3;
if( c >
1e3 ) this.count = 0, this.startTime = t;
return fps;
}
;
// privates ClassTimer.prototype.start = function(){
clearInterval( this.interval );
this.interval = setInterval( this.intervalFn, this.intervalTime );
}
;
ClassTimer.prototype.stop = function(){
clearInterval( this.interval );
}
;
ClassTimer.prototype.update = function( time ){
var tasks = this.tasks, addingTasks = this.addingTasks, adding = this.adding;
var i = tasks.length, t, task, start, duration, data;
while( i -- ){
task = tasks[i];
start = task.start;
duration = task.duration;
if( time >
= start ){
if( task.stopped ){
tasks.splice( i, 1 );
continue;
}
checkStartTask( task );
if( ( t = time - start ) duration ) updateTask( task, t );
else updateTask( task, duration ), task.onTimeEnd.apply( task.object, task.data.slice(1) ), tasks.splice( i, 1 );
}
}
if( adding ) tasks.unshift.apply( tasks, addingTasks ), addingTasks.length = adding = 0;
if( !tasks.length ) this.stop();
}
;
timeline.use = function( name ){
var module;
if( module = timerCache[ name ] ) return module;
else module = timerCache[ name ] = new ClassTimer;
return module;
}
;
/** * @functions */ var now = function(){
return new Date().getTime();
}
;
var createTask = function( conf ){
var object = conf.object || {
}
;
conf.start = conf.start || 0;
return {
start: conf.start + now(), duration: conf.duration == -1 ? 86400000 : conf.duration, data: conf.data ? [ 0 ].concat( conf.data ) : [ 0 ], started: 0, object: object, onTimeStart: conf.onTimeStart || object.onTimeStart || Ucren.nul, onTimeUpdate: conf.onTimeUpdate || object.onTimeUpdate || Ucren.nul, onTimeEnd: conf.onTimeEnd || object.onTimeEnd || Ucren.nul, stop: function(){
this.stopped = 1;
}
}
}
;
var updateTask = function( task, time ){
var data = task.data;
data[0] = time;
task.onTimeUpdate.apply( task.object, data );
}
;
var checkStartTask = function( task ){
if( !task.started ) task.started = 1, task.onTimeStart.apply( task.object, task.data.slice(1) ), updateTask( task, 0 );
}
;
/** * for compatible the old version */ exports = timeline.use( "default" ).init( 10 );
exports.use = function( name ){
if( Ucren.isIe ) exports;
return timeline.use( name );
}
;
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\tools.js */ define("scripts/tools.js", function(exports){
exports.unsetObject = function( object ){
for(var i in object) if(object.hasOwnProperty(i) &
&
typeof object[i] == "function") object[i] = function(){
}
;
}
;
exports.getAngleByRadian = function( radian ){
return radian * 180 / Math.PI;
}
exports.pointToRadian = function( origin, point ){
var PI = Math.PI;
if( point[0] === origin[0] ){
if ( point[1] >
origin[1] ) return PI * 0.5;
return PI * 1.5 }
else if( point[1] === origin[1] ){
if ( point[0] >
origin[0] ) return 0;
return PI;
}
var t = Math.atan( ( origin[1] - point[1] ) / ( origin[0] - point[0] ) );
if( point[0] >
origin[0] &
&
point[1] origin[1] ) return t + 2 * PI;
if( point[0] >
origin[0] &
&
point[1] >
origin[1] ) return t;
return t + PI;
}
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\factory\displacement.js */ define("scripts/factory/displacement.js", function(exports){
var layer = require("scripts/layer");
var timeline = require("scripts/timeline");
var tween = require("scripts/lib/tween");
/** * 位移类模块模型 */ exports.create = function( imageSrc, width, height, origX, origY, targetX, targetY, animMap, animDur ){
var module = {
}
;
var image;
var anim = {
}
;
if( typeof animMap === "function" ) anim.show = anim.hide = animMap;
else anim = animMap;
var createTask = function( start, duration, sx, sy, ex, ey, anim, mode ){
timeline.createTask({
start: start, duration: duration, object: module, data: [ sx, sy, ex, ey, anim, mode ], onTimeUpdate: module.onTimeUpdate, onTimeStart: module.onTimeStart, onTimeEnd: module.onTimeEnd, recycle: module.anims }
);
}
;
module.anims = [];
module.set = function(){
image = layer.createImage( "default", imageSrc, origX, origY, width, height );
}
;
module.show = function( start ){
createTask( start, animDur, origX, origY, targetX, targetY, anim.show, "show" );
}
;
module.hide = function(){
this.anims.clear();
createTask( 0, animDur, targetX, targetY, origX, origY, anim.hide, "hide" );
}
;
module.onTimeUpdate = function( time, sx, sy, ex, ey, anim ){
image.attr( {
x: anim( time, sx, ex - sx, animDur ), y: anim( time, sy, ey - sy, animDur ) }
);
}
;
module.onTimeStart = function(){
}
;
module.onTimeEnd = function( sx, sy, ex, ey, anim ){
if( anim === "hide" ) image.hide();
}
;
return module;
}
;
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\factory\fruit.js */ define("scripts/factory/fruit.js", function(exports){
var layer = require("scripts/layer");
var Ucren = require("scripts/lib/ucren");
var timeline = require("scripts/timeline").use( "fruit" ).init( 1 );
var timeline2 = require("scripts/timeline").use( "fruit-apart" ).init( 1 );
var tween = require("scripts/lib/tween");
var message = require("scripts/message");
var flame = require("scripts/object/flame");
var flash = require("scripts/object/flash");
var juice = require("scripts/factory/juice");
var ie = Ucren.isIe;
var safari = Ucren.isSafari;
/** * 水果模块模型 */ var zoomAnim = tween.exponential.co;
var rotateAnim = tween.circular;
var linearAnim = tween.linear;
var dropAnim = tween.quadratic.ci;
var fallOffanim = tween.quadratic.co;
var random = Ucren.randomNumber;
var min = Math.min;
var average = function( a, b ){
return ( ( a + b ) / 2 ) >
>
0;
}
;
var dropTime = 1200, dropXScope = 200, shadowPos = 50;
var infos = {
// type: [ imageSrc, width, height, radius, fixAngle, isreverse, juiceColor ] boom: [ "images/fruit/boom.png", 66, 68, 26, 0, 0, null ], peach: [ "images/fruit/peach.png", 62, 59, 37, -50, 0, "#e6c731" ], sandia: [ "images/fruit/sandia.png", 98, 85, 38, -100, 0, "#c00" ], apple: [ "images/fruit/apple.png", 66, 66, 31, -54, 0, "#c8e925" ], banana: [ "images/fruit/banana.png", 126, 50, 43, 90, 0, null ], basaha: [ "images/fruit/basaha.png", 68, 72, 32, -135, 0, "#c00" ] }
;
// TODO: 是否水果全开? var types = [ "peach", "sandia", "apple", "banana", "basaha" ];
// var types = [ "sandia", "boom" ];
var rotateSpeed = [ 60, 50, 40, -40, -50, -60 ];
var fruitCache = [];
function ClassFruit(conf){
var info = infos[ conf.type ], radius = info[3];
this.type = conf.type;
this.originX = conf.originX;
this.originY = conf.originY;
this.radius = radius;
this.startX = conf.originX;
this.startY = conf.originY;
this.radius = radius;
this.anims = [];
if( this.type === "boom" ) this.flame = flame.create( this.startX - radius + 4, this.startY - radius + 5, conf.flameStart || 0 );
}
ClassFruit.prototype.set = function( hide ){
var inf = infos[ this.type ], radius = this.radius;
this.shadow = layer.createImage( "fruit", "images/shadow.png", this.startX - radius, this.startY - radius + shadowPos, 106, 77 );
this.image = layer.createImage( "fruit", inf[0], this.startX - radius, this.startY - radius, inf[1], inf[2] );
if( hide ) this.image.hide(), this.shadow.hide();
return this;
}
;
ClassFruit.prototype.pos = function( x, y ){
if( x == this.originX &
&
y == this.originY ) return ;
var r = this.radius;
this.originX = x;
this.originY = y;
this.image.attr({
x: x -= r, y: y -= r }
);
this.shadow.attr({
x: x, y: y + shadowPos }
);
if( this.type === "boom" ) this.flame.pos( x + 4, y + 5 );
}
;
ClassFruit.prototype.show = function( start ){
timeline.createTask({
start: start, duration: 500, data: [ 1e-5, 1, "show" ], object: this, onTimeUpdate: this.onScaling, onTimeStart: this.onShowStart, recycle: this.anims }
);
}
;
ClassFruit.prototype.hide = function( start ){
if( this.type !== "boom" ) // if it is not a boom, it can't to be hide. return ;
this.anims.clear();
this.flame.remove();
timeline.createTask({
start: start, duration: 500, data: [ 1, 1e-5, "hide" ], object: this, onTimeUpdate: this.onScaling, onTimeEnd: this.onHideEnd, recycle: this.anims }
);
}
;
ClassFruit.prototype.rotate = function( start, speed ){
this.rotateSpeed = speed || rotateSpeed[ random( 6 ) ];
this.rotateAnim = timeline.createTask({
start: start, duration: -1, object: this, onTimeUpdate: this.onRotating, recycle: this.anims }
);
}
;
ClassFruit.prototype.broken = function( angle ){
if( this.brokend )return;
this.brokend = true;
var index;
if( ( index = fruitCache.indexOf( this ) ) >
-1 ) fruitCache.splice( index, 1 );
if( this.type !== "boom" ) flash.showAt( this.originX, this.originY, angle ), juice.create( this.originX, this.originY, infos[ this.type ][6] ), this.apart( angle );
else this.hide();
}
;
ClassFruit.prototype.pause = function(){
if( this.brokend ) return;
this.anims.clear();
if( this.type == "boom" ) this.flame.remove();
}
;
// 分开 ClassFruit.prototype.apart = function( angle ){
this.anims.clear();
this.image.hide();
this.shadow.hide();
this.aparted = true;
var inf = infos[ this.type ], preSrc = inf[0].replace( ".png", "" ), radius = this.radius;
var create = layer.createImage.saturate( layer, this.startX - radius, this.startY - radius, inf[1], inf[2] );
angle = ( ( angle % 180 ) + 360 + inf[4] ) % 360;
this.bImage1 = create( "fruit", preSrc + "-1.png" );
this.bImage2 = create( "fruit", preSrc + "-2.png" );
[ this.bImage1, this.bImage2 ].invoke( "rotate", angle );
this.apartAngle = angle;
timeline2.createTask({
start: 0, duration: dropTime, object: this, onTimeUpdate: this.onBrokenDropUpdate, onTimeStart: this.onBrokenDropStart, onTimeEnd: this.onBrokenDropEnd, recycle: this.anims }
);
}
;
// 抛出 ClassFruit.prototype.shotOut = function(){
var sign = [ -1, 1 ];
return function( start, endX ){
this.shotOutStartX = this.originX;
this.shotOutStartY = this.originY;
this.shotOutEndX = average( this.originX, endX );
this.shotOutEndY = min( this.startY - random( this.startY - 100 ), 200 );
this.fallOffToX = endX;
timeline.createTask({
start: start, duration: dropTime, object: this, onTimeUpdate: this.onShotOuting, onTimeStart: this.onShotOutStart, onTimeEnd: this.onShotOutEnd, recycle: this.anims }
);
if( this.type != "boom" ) this.rotate( 0, ( random( 180 ) + 90 ) * sign[ random( 2 ) ] );
return this;
}
;
}
();
// 掉落 ClassFruit.prototype.fallOff = function(){
var sign = [ -1, 1 ];
var signIndex = 0;
return function( start, x ){
if( this.aparted || this.brokend ) return ;
var y = 600;
if( typeof x !== "number" ) x = this.originX + random( dropXScope ) * sign[ ( signIndex ++ ) % 2 ];
this.fallTargetX = x;
this.fallTargetY = y;
timeline.createTask({
start: start, duration: dropTime, object: this, onTimeUpdate: this.onFalling, onTimeStart: this.onFallStart, onTimeEnd: this.onFallEnd, recycle: this.anims }
);
}
}
();
ClassFruit.prototype.remove = function(){
var index;
this.anims.clear();
if( this.image ) this.image.remove(), this.shadow.remove();
if( this.bImage1 ) this.bImage1.remove(), this.bImage2.remove();
if( this.type === "boom" ) this.flame.remove();
if( ( index = fruitCache.indexOf( this ) ) >
-1 ) fruitCache.splice( index, 1 );
for(var name in this) if( typeof this[name] === "function" ) this[name] = function( name ){
return function(){
throw new Error( "method " + name + " has been removed" );
}
;
}
( name );
else delete this[name];
message.postMessage( this, "fruit.remove" );
}
;
// 显示/隐藏 相关 ClassFruit.prototype.onShowStart = function(){
this.image.show();
// this.shadow.show();
}
;
ClassFruit.prototype.onScaling = function( time, a, b, z ){
this.image.scale( z = zoomAnim( time, a, b - a, 500 ), z );
this.shadow.scale( z, z );
}
;
ClassFruit.prototype.onHideEnd = function(){
this.remove();
}
;
// 旋转相关 ClassFruit.prototype.onRotateStart = function(){
}
;
ClassFruit.prototype.onRotating = function( time ){
this.image.rotate( ( this.rotateSpeed * time / 1e3 ) % 360, true );
}
;
// 裂开相关 ClassFruit.prototype.onBrokenDropUpdate = function( time ){
var radius = this.radius;
this.bImage1.attr({
x: linearAnim( time, this.brokenPOSX - radius, this.brokenTargetX1, dropTime ), y: dropAnim( time, this.brokenPosY - radius, this.brokenTargetY1 - this.brokenPosY + radius, dropTime ) }
).rotate( linearAnim( time, this.apartAngle, this.bImage1RotateAngle, dropTime ), true );
this.bImage2.attr({
x: linearAnim( time, this.brokenPosX - radius, this.brokenTargetX2, dropTime ), y: dropAnim( time, this.brokenPosY - radius, this.brokenTargetY2 - this.brokenPosY + radius, dropTime ) }
).rotate( linearAnim( time, this.apartAngle, this.bImage2RotateAngle, dropTime ), true );
}
;
ClassFruit.prototype.onBrokenDropStart = function(){
this.brokenTargetX1 = -( random( dropXScope ) + 75 );
this.brokenTargetX2 = random( dropXScope + 75 );
this.brokenTargetY1 = 600;
this.brokenTargetY2 = 600;
this.brokenPosX = this.originX;
this.brokenPosY = this.originY;
this.bImage1RotateAngle = - random( 150 ) - 50;
this.bImage2RotateAngle = random( 150 ) + 50;
for(var f, i = fruitCache.length - 1;
i >
= 0;
i --) if( fruitCache[i] === this ) fruitCache.splice( i, 1 );
}
;
ClassFruit.prototype.onBrokenDropEnd = function(){
this.remove();
}
;
// 抛出相关 ClassFruit.prototype.onShotOuting = function( time ){
this.pos( linearAnim( time, this.shotOutStartX, this.shotOutEndX - this.shotOutStartX, dropTime ), fallOffAnim( time, this.shotOutStartY, this.shotOutEndY - this.shotOutStartY, dropTime ) );
}
;
ClassFruit.prototype.onShotOutStart = function(){
// body... }
;
ClassFruit.prototype.onShotOutEnd = function(){
this.fallOff( 0, this.fallOffToX );
}
;
// 掉落相关 ClassFruit.prototype.onFalling = function( time ){
var y;
this.pos( linearAnim( time, this.brokenPosX, this.fallTargetX - this.brokenPosX, dropTime ), y = dropAnim( time, this.brokenPosY, this.fallTargetY - this.brokenPosY, dropTime ) );
this.checkForFallOutOfViewer( y );
}
;
ClassFruit.prototype.onFallStart = function(){
this.brokenPosX = this.originX;
this.brokenPosY = this.originY;
}
;
ClassFruit.prototype.onFallEnd = function(){
message.postMessage( this, "fruit.fallOff" );
this.remove();
}
;
// privates ClassFruit.prototype.checkForFallOutOfViewer = function( y ){
if( y >
480 + this.radius ) this.checkForFallOutOfViewer = Ucren.nul, this.rotateAnim &
&
this.rotateAnim.stop(), message.postMessage( this, "fruit.fallOutOfViewer" );
}
;
exports.create = function( type, originX, originY, isHide, flameStart ){
if( typeof type == "number" ) // 缺省 type isHide = originY, originY = originX, originX = type, type = getType();
var fruit = new ClassFruit({
type: type, originX: originX, originY: originY, flameStart: flameStart }
).set( isHide );
fruitCache.unshift( fruit );
return fruit;
}
;
exports.getFruitInView = function(){
return fruitCache;
}
;
exports.getDropTimeSetting = function(){
return dropTime;
}
;
function getType(){
if( random( 8 ) == 4 ) return "boom";
else return types[ random( 5 ) ];
}
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\factory\juice.js */ define("scripts/factory/juice.js", function(exports){
/** * 果汁 */ var Ucren = require("scripts/lib/ucren");
var layer = require("scripts/layer").getLayer("juice");
var timeline = require("scripts/timeline").use( "juice" ).init( 10 );
var tween = require("scripts/lib/tween");
var tools = require("scripts/tools");
var random = Ucren.randomNumber;
var dur = 1500;
var anim = tween.exponential.co;
var dropAnim = tween.quadratic.co;
var sin = Math.sin;
var cos = Math.cos;
var num = 10;
var radius = 10;
// if( Ucren.isIe6 || Ucren.isSafari ) // switchOn = false;
// if( Ucren.isIe || Ucren.isSafari ) // num = 6;
function ClassJuice( x, y, color ){
this.originX = x;
this.originY = y;
this.color = color;
this.distance = random( 200 ) + 100;
this.radius = radius;
this.dir = random( 360 ) * Math.PI / 180;
}
ClassJuice.prototype.render = function(){
this.circle = layer.circle( this.originX, this.originY, this.radius ).attr({
fill: this.color, stroke: "none" }
);
}
;
ClassJuice.prototype.sputter = function(){
timeline.createTask({
start: 0, duration: dur, object: this, onTimeUpdate: this.onTimeUpdate, onTimeEnd: this.onTimeEnd }
);
}
;
ClassJuice.prototype.onTimeUpdate = function( time ){
var distance, x, y, z;
distance = anim( time, 0, this.distance, dur );
x = this.originX + distance * cos( this.dir );
y = this.originY + distance * sin( this.dir ) + dropAnim( time, 0, 200, dur );
z = anim( time, 1, -1, dur );
this.circle.attr({
cx: x, cy: y }
).scale( z, z );
}
;
ClassJuice.prototype.onTimeEnd = function(){
this.circle.remove();
tools.unsetObject( this );
}
;
exports.create = function( x, y, color ){
for(var i = 0;
i num;
i ++) this.createOne( x, y, color );
}
;
exports.createOne = function( x, y, color ){
if( !color ) return;
var juice = new ClassJuice( x, y, color );
juice.render();
juice.sputter();
}
;
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\factory\rotate.js */ define("scripts/factory/rotate.js", function(exports){
var layer = require("scripts/layer");
var timeline = require("scripts/timeline");
var Ucren = require("scripts/lib/ucren");
/** * 旋转类模块模型 */ exports.create = function( imageSrc, x, y, w, h, z, anim, animDur ){
var module = {
}
, image;
var rotateDire = [12, -12][Ucren.randomNumber(2)];
var defaultAngle = Ucren.randomNumber(360);
module.anims = [];
module.set = function(){
image = layer.createImage( "default", imageSrc, x, y, w, h ).scale( z, z ).rotate( defaultAngle, true );
}
;
module.show = function(start){
timeline.createTask({
start: start, duration: animDur, object: this, data: [z, 1], onTimeUpdate: this.onZooming, onTimeEnd: this.onShowEnd, recycle: this.anims }
);
}
;
module.hide = function(start){
this.anims.clear();
timeline.createTask({
start: start, duration: animDur, object: this, data: [ 1, z ], onTimeUpdate: this.onZooming, recycle: this.anims }
);
}
;
module.onShowEnd = function(name){
this.anims.clear();
timeline.createTask({
start: 0, duration: -1, object: this, onTimeUpdate: module.onRotating, recycle: this.anims }
);
}
;
module.onZooming = function(){
var z;
return function( time, a, b ){
image.scale( z = anim( time, a, b - a, animDur ), z );
}
}
();
module.onRotating = function(){
var lastTime = 0, an = defaultAngle;
return function( time, name, a, b ){
an = ( an + ( time - lastTime ) / 1e3 * rotateDire ) % 360;
image.rotate( an, true );
lastTime = time;
}
}
();
return module;
}
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\lib\buzz.js */ define("scripts/lib/buzz.js", function(exports){
// ---------------------------------------------------------------------------- // Buzz, a Javascript HTML5 Audio library // v 1.0.x beta // Licensed under the MIT license. // http://buzz.jaysalvat.com/ // ---------------------------------------------------------------------------- // Copyright (C) 2011 Jay Salvat // http://jaysalvat.com/ // ---------------------------------------------------------------------------- // Permission is hereby granted, free of charge, to any person oBTaining a copy // of this Software and associated documentation files ( the "Software" ), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPress OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. // ---------------------------------------------------------------------------- var buzz = {
defaults: {
autoplay: false, duration: 5000, formats: [], loop: false, placeholder: '--', preload: 'metadata', volume: 80 }
, types: {
'mP3': 'audio/mpeg', 'ogg': 'audio/ogg', 'wav': 'audio/wav', 'aac': 'audio/aac', 'm4a': 'audio/x-m4a' }
, sounds: [], el: document.createElement( 'audio' ), sound: function( src, options ) {
options = options || {
}
;
var pid = 0, events = [], eventsOnce = {
}
, supported = buzz.isSupported();
// publics this.load = function() {
if ( !supported ) {
return this;
}
this.sound.load();
return this;
}
;
this.play = function() {
if ( !supported ) {
return this;
}
this.sound.play();
return this;
}
;
this.togglePlay = function() {
if ( !supported ) {
return this;
}
if ( this.sound.paused ) {
this.sound.play();
}
else {
this.sound.pause();
}
return this;
}
;
this.pause = function() {
if ( !supported ) {
return this;
}
this.sound.pause();
return this;
}
;
this.isPaused = function() {
if ( !supported ) {
return null;
}
return this.sound.paused;
}
;
this.stop = function() {
if ( !supported ) {
return this;
}
this.setTime( this.getDuration() );
this.sound.pause();
return this;
}
;
this.isEnded = function() {
if ( !supported ) {
return null;
}
return this.sound.ended;
}
;
this.loop = function() {
if ( !supported ) {
return this;
}
this.sound.loop = 'loop';
this.bind( 'ended.buzzloop', function() {
this.currentTime = 0;
this.play();
}
);
return this;
}
;
this.unloop = function() {
if ( !supported ) {
return this;
}
this.sound.removeAttribute( 'loop' );
this.unbind( 'ended.buzzloop' );
return this;
}
;
this.mute = function() {
if ( !supported ) {
return this;
}
this.sound.muted = true;
return this;
}
;
this.unmute = function() {
if ( !supported ) {
return this;
}
this.sound.muted = false;
return this;
}
;
this.toggleMute = function() {
if ( !supported ) {
return this;
}
this.sound.muted = !this.sound.muted;
return this;
}
;
this.isMuted = function() {
if ( !supported ) {
return null;
}
return this.sound.muted;
}
;
this.setVolume = function( volume ) {
if ( !supported ) {
return this;
}
if ( volume 0 ) {
volume = 0;
}
if ( volume >
100 ) {
volume = 100;
}
this.volume = volume;
this.sound.volume = volume / 100;
return this;
}
;
this.getVolume = function() {
if ( !supported ) {
return this;
}
return this.volume;
}
;
this.increaseVolume = function( value ) {
return this.setVolume( this.volume + ( value || 1 ) );
}
;
this.decreaseVolume = function( value ) {
return this.setVolume( this.volume - ( value || 1 ) );
}
;
this.setTime = function( time ) {
if ( !supported ) {
return this;
}
this.whenReady( function() {
this.sound.currentTime = time;
}
);
return this;
}
;
this.getTime = function() {
if ( !supported ) {
return null;
}
var time = Math.round( this.sound.currentTime * 100 ) / 100;
return isNaN( time ) ? buzz.defaults.placeholder : time;
}
;
this.setPercent = function( percent ) {
if ( !supported ) {
return this;
}
return this.setTime( buzz.fromPercent( percent, this.sound.duration ) );
}
;
this.getPercent = function() {
if ( !supported ) {
return null;
}
var percent = Math.round( buzz.toPercent( this.sound.currentTime, this.sound.duration ) );
return isNaN( percent ) ? buzz.defaults.placeholder : percent;
}
;
this.setSpeed = function( duration ) {
if ( !supported ) {
return this;
}
this.sound.playbackRate = duration;
}
;
this.getSpeed = function() {
if ( !supported ) {
return null;
}
return this.sound.playbackRate;
}
;
this.getDuration = function() {
if ( !supported ) {
return null;
}
var duration = Math.round( this.sound.duration * 100 ) / 100;
return isNaN( duration ) ? buzz.defaults.placeholder : duration;
}
;
this.getPlayed = function() {
if ( !supported ) {
return null;
}
return timerangeToArray( this.sound.played );
}
;
this.getBuffered = function() {
if ( !supported ) {
return null;
}
return timerangeToArray( this.sound.buffered );
}
;
this.getSeekable = function() {
if ( !supported ) {
return null;
}
return timerangeToArray( this.sound.seekable );
}
;
this.getErrorCode = function() {
if ( supported &
&
this.sound.error ) {
return this.sound.error.code;
}
return 0;
}
;
this.getErrorMessage = function() {
if ( !supported ) {
return null;
}
switch( this.getErrorCode() ) {
case 1: return 'MEDIA_ERR_ABORTED';
case 2: return 'MEDIA_ERR_NETWORK';
case 3: return 'MEDIA_ERR_DECODE';
case 4: return 'MEDIA_ERR_SRC_NOT_SUPPORTED';
default: return null;
}
}
;
this.getStateCode = function() {
if ( !supported ) {
return null;
}
return this.sound.readyState;
}
;
this.getStateMessage = function() {
if ( !supported ) {
return null;
}
switch( this.getStateCode() ) {
case 0: return 'HAVE_NOTHING';
case 1: return 'HAVE_METADATA';
case 2: return 'HAVE_CURRENT_DATA';
case 3: return 'HAVE_Future_DATA';
case 4: return 'HAVE_ENOUGH_DATA';
default: return null;
}
}
;
this.getNetworkStateCode = function() {
if ( !supported ) {
return null;
}
return this.sound.networkState;
}
;
this.getNetworkStateMessage = function() {
if ( !supported ) {
return null;
}
switch( this.getNetworkStateCode() ) {
case 0: return 'NETWORK_EMPTY';
case 1: return 'NETWORK_idle';
case 2: return 'NETWORK_LOADING';
case 3: return 'NETWORK_NO_SOURCE';
default: return null;
}
}
;
this.set = function( key, value ) {
if ( !supported ) {
return this;
}
this.sound[ key ] = value;
return this;
}
;
this.get = function( key ) {
if ( !supported ) {
return null;
}
return key ? this.sound[ key ] : this.sound;
}
;
this.bind = function( types, func ) {
if ( !supported ) {
return this;
}
types = types.split( ' ' );
var that = this, efunc = function( e ) {
func.call( that, e );
}
;
for( var t = 0;
t types.length;
t++ ) {
var type = types[ t ], idx = type;
type = idx.split( '.' )[ 0 ];
events.push( {
idx: idx, func: efunc }
);
this.sound.addEventListener( type, efunc, true );
}
return this;
}
;
this.unbind = function( types ) {
if ( !supported ) {
return this;
}
types = types.split( ' ' );
for( var t = 0;
t types.length;
t++ ) {
var idx = types[ t ], type = idx.split( '.' )[ 0 ];
for( var i = 0;
i events.length;
i++ ) {
var namespace = events[ i ].idx.split( '.' );
if ( events[ i ].idx == idx || ( namespace[ 1 ] &
&
namespace[ 1 ] == idx.replace( '.', '' ) ) ) {
this.sound.removeEventListener( type, events[ i ].func, true );
// remove event events.splice(i, 1);
}
}
}
return this;
}
;
this.bindOnce = function( type, func ) {
if ( !supported ) {
return this;
}
var that = this;
eventsOnce[ pid++ ] = false;
this.bind( pid + type, function() {
if ( !eventsOnce[ pid ] ) {
eventsOnce[ pid ] = true;
func.call( that );
}
that.unbind( pid + type );
}
);
}
;
this.trigger = function( types ) {
if ( !supported ) {
return this;
}
types = types.split( ' ' );
for( var t = 0;
t types.length;
t++ ) {
var idx = types[ t ];
for( var i = 0;
i events.length;
i++ ) {
var eventType = events[ i ].idx.split( '.' );
if ( events[ i ].idx == idx || ( eventType[ 0 ] &
&
eventType[ 0 ] == idx.replace( '.', '' ) ) ) {
var evt = document.createEvent('HTMLEvents');
evt.initEvent( eventType[ 0 ], false, true );
this.sound.dispatchEvent( evt );
}
}
}
return this;
}
;
this.fadeTo = function( to, duration, callback ) {
if ( !supported ) {
return this;
}
if ( duration instanceof Function ) {
callback = duration;
duration = buzz.defaults.duration;
}
else {
duration = duration || buzz.defaults.duration;
}
var from = this.volume, delay = duration / Math.abs( from - to ), that = this;
this.play();
function doFade() {
setTimeout( function() {
if ( from to &
&
that.volume to ) {
that.setVolume( that.volume += 1 );
doFade();
}
else if ( from >
to &
&
that.volume >
to ) {
that.setVolume( that.volume -= 1 );
doFade();
}
else if ( callback instanceof Function ) {
callback.apply( that );
}
}
, delay );
}
this.whenReady( function() {
doFade();
}
);
return this;
}
;
this.fadeIn = function( duration, callback ) {
if ( !supported ) {
return this;
}
return this.setVolume(0).fadeTo( 100, duration, callback );
}
;
this.fadeOut = function( duration, callback ) {
if ( !supported ) {
return this;
}
return this.fadeTo( 0, duration, callback );
}
;
this.fadeWith = function( sound, duration ) {
if ( !supported ) {
return this;
}
this.fadeOut( duration, function() {
this.stop();
}
);
sound.play().fadeIn( duration );
return this;
}
;
this.whenReady = function( func ) {
if ( !supported ) {
return null;
}
var that = this;
if ( this.sound.readyState === 0 ) {
this.bind( 'canplay.buzzwhenready', function() {
func.call( that );
}
);
}
else {
func.call( that );
}
}
;
// privates function timerangeToArray( timeRange ) {
var array = [], length = timeRange.length - 1;
for( var i = 0;
i = length;
i++ ) {
array.push({
start: timeRange.start( length ), end: timeRange.end( length ) }
);
}
return array;
}
function getExt( filename ) {
return filename.split('.').pop();
}
function addSource( sound, src ) {
var source = document.createElement( 'source' );
source.src = src;
if ( buzz.types[ getExt( src ) ] ) {
source.type = buzz.types[ getExt( src ) ];
}
sound.appendChild( source );
}
// init if ( supported &
&
src ) {
for(var i in buzz.defaults ) {
if(buzz.defaults.hasOwnProperty(i)) {
options[ i ] = options[ i ] || buzz.defaults[ i ];
}
}
this.sound = document.createElement( 'audio' );
if ( src instanceof Array ) {
for( var j in src ) {
if(src.hasOwnProperty(j)) {
addSource( this.sound, src[ j ] );
}
}
}
else if ( options.formats.length ) {
for( var k in options.formats ) {
if(options.formats.hasOwnProperty(k)) {
addSource( this.sound, src + '.' + options.formats[ k ] );
}
}
}
else {
addSource( this.sound, src );
}
if ( options.loop ) {
this.loop();
}
if ( options.autoplay ) {
this.sound.autoplay = 'autoplay';
}
if ( options.preload === true ) {
this.sound.preload = 'auto';
}
else if ( options.preload === false ) {
this.sound.preload = 'none';
}
else {
this.sound.preload = options.preload;
}
this.setVolume( options.volume );
buzz.sounds.push( this );
}
}
, group: function( sounds ) {
sounds = argsToArray( sounds, arguments );
// publics this.getSounds = function() {
return sounds;
}
;
this.add = function( soundArray ) {
soundArray = argsToArray( soundArray, arguments );
for( var a = 0;
a soundArray.length;
a++ ) {
sounds.push( soundArray[ a ] );
}
}
;
this.remove = function( soundArray ) {
soundArray = argsToArray( soundArray, arguments );
for( var a = 0;
a soundArray.length;
a++ ) {
for( var i = 0;
i sounds.length;
i++ ) {
if ( sounds[ i ] == soundArray[ a ] ) {
delete sounds[ i ];
break;
}
}
}
}
;
this.load = function() {
fn( 'load' );
return this;
}
;
this.play = function() {
fn( 'play' );
return this;
}
;
this.togglePlay = function( ) {
fn( 'togglePlay' );
return this;
}
;
this.pause = function( time ) {
fn( 'pause', time );
return this;
}
;
this.stop = function() {
fn( 'stop' );
return this;
}
;
this.mute = function() {
fn( 'mute' );
return this;
}
;
this.unmute = function() {
fn( 'unmute' );
return this;
}
;
this.toggleMute = function() {
fn( 'toggleMute' );
return this;
}
;
this.setVolume = function( volume ) {
fn( 'setVolume', volume );
return this;
}
;
this.increaseVolume = function( value ) {
fn( 'increaseVolume', value );
return this;
}
;
this.decreaseVolume = function( value ) {
fn( 'decreaseVolume', value );
return this;
}
;
this.loop = function() {
fn( 'loop' );
return this;
}
;
this.unloop = function() {
fn( 'unloop' );
return this;
}
;
this.setTime = function( time ) {
fn( 'setTime', time );
return this;
}
;
this.setduration = function( duration ) {
fn( 'setduration', duration );
return this;
}
;
this.set = function( key, value ) {
fn( 'set', key, value );
return this;
}
;
this.bind = function( type, func ) {
fn( 'bind', type, func );
return this;
}
;
this.unbind = function( type ) {
fn( 'unbind', type );
return this;
}
;
this.bindOnce = function( type, func ) {
fn( 'bindOnce', type, func );
return this;
}
;
this.trigger = function( type ) {
fn( 'trigger', type );
return this;
}
;
this.fade = function( from, to, duration, callback ) {
fn( 'fade', from, to, duration, callback );
return this;
}
;
this.fadeIn = function( duration, callback ) {
fn( 'fadeIn', duration, callback );
return this;
}
;
this.fadeOut = function( duration, callback ) {
fn( 'fadeOut', duration, callback );
return this;
}
;
// privates function fn() {
var args = argsToArray( null, arguments ), func = args.shift();
for( var i = 0;
i sounds.length;
i++ ) {
sounds[ i ][ func ].apply( sounds[ i ], args );
}
}
function argsToArray( array, args ) {
return ( array instanceof Array ) ? array : Array.prototype.slice.call( args );
}
}
, all: function() {
return new buzz.group( buzz.sounds );
}
, isSupported: function() {
return !!buzz.el.canPlayType;
}
, isOGGSupported: function() {
return !!buzz.el.canPlayType &
&
buzz.el.canPlayType( 'audio/ogg;
codecs="vorbis"' );
}
, isWAVSupported: function() {
return !!buzz.el.canPlayType &
&
buzz.el.canPlayType( 'audio/wav;
codecs="1"' );
}
, isMP3Supported: function() {
return !!buzz.el.canPlayType &
&
buzz.el.canPlayType( 'audio/mpeg;
' );
}
, isAACSupported: function() {
return !!buzz.el.canPlayType &
&
( buzz.el.canPlayType( 'audio/x-m4a;
' ) || buzz.el.canPlayType( 'audio/aac;
' ) );
}
, toTimer: function( time, withHours ) {
var h, m, s;
h = Math.floor( time / 3600 );
h = isNaN( h ) ? '--' : ( h >
= 10 ) ? h : '0' + h;
m = withHours ? Math.floor( time / 60 % 60 ) : Math.floor( time / 60 );
m = isNaN( m ) ? '--' : ( m >
= 10 ) ? m : '0' + m;
s = Math.floor( time % 60 );
s = isNaN( s ) ? '--' : ( s >
= 10 ) ? s : '0' + s;
return withHours ? h + ':' + m + ':' + s : m + ':' + s;
}
, fromTimer: function( time ) {
var splits = time.toString().split( ':' );
if ( splits &
&
splits.length == 3 ) {
time = ( parseInt( splits[ 0 ], 10 ) * 3600 ) + ( parseInt(splits[ 1 ], 10 ) * 60 ) + parseInt( splits[ 2 ], 10 );
}
if ( splits &
&
splits.length == 2 ) {
time = ( parseInt( splits[ 0 ], 10 ) * 60 ) + parseInt( splits[ 1 ], 10 );
}
return time;
}
, toPercent: function( value, total, decimal ) {
var r = Math.pow( 10, decimal || 0 );
return Math.round( ( ( value * 100 ) / total ) * r ) / r;
}
, fromPercent: function( percent, total, decimal ) {
var r = Math.pow( 10, decimal || 0 );
return Math.round( ( ( total / 100 ) * percent ) * r ) / r;
}
}
;
exports = buzz;
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\lib\raphael.js */ define("scripts/lib/raphael.js", function(exports){
/* * Raphael 1.5.2 - JavaScript Vector Library * * Copyright (c) 2010 Dmitry Baranovskiy (http://raphaeljs.com) * Licensed under the MIT (http://raphaeljs.com/license.html) license. */ var Raphael;
var window = {
}
;
(function(){
function a(){
if(a.is(arguments[0],G)) {
var b=arguments[0],d=bV[m](a,b.splice(0,3+a.is(b[0],E))),e=d.set();
for(var g=0,h=b[w];
gh;
g++){
var i=b[g]||{
}
;
c[f](i.type)&
&
e[L](d[i.type]().attr(i)) }
return e }
return bV[m](a,arguments)}
a.version="1.5.2";
var b=/[, ]+/, c={
circle:1,rect:1,path:1,ellipse:1,text:1,image:1}
, d=/\{
(\d+)\}
/g, e="prototype", f="hasOwnProperty", g=document, h=window, i={
was:Object[e][f].call(h,"Raphael"),is:h.Raphael}
, j=function(){
this.customAttributes={
}
}
, k, l="appendChild", m="apply", n="concat", o="createTouch"in g, p="", q=" ", r=String, s="split",t="click dblclick mousedown mouSEMove mouseout mouseover mouseup touchstart touchmove touchend orientationchange touchcancel gesturestart gesturechange gestureend"[s](q),u={
mousedown:"touchstart",mousemove:"touchmove",mouseup:"touchend"}
, v="join", w="length", x=r[e].toLowerCase, y=Math, z=y.max, A=y.min, B=y.abs, C=y.pow, D=y.PI, E="number", F="string", G="array", H="toString", I="fill", J=Object[e][H], K={
}
, L="push", M=/^url\(['"]?([^\)]+?)['"]?\)$/iN=/^\s*((#[a-f\d]{
6}
)|(#[a-f\d]{
3}
)|rgba?\(\s*([\d\.]+%?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+(?:%?\s*,\s*[\d\.]+)?)%?\s*\)|hsba?\(\s*([\d\.]+(?:deg|\xb0|%)?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+(?:%?\s*,\s*[\d\.]+)?)%?\s*\)|hsla?\(\s*([\d\.]+(?:deg|\xb0|%)?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+(?:%?\s*,\s*[\d\.]+)?)%?\s*\))\s*$/i,O={
"NaN":1,Infinity:1,"-Infinity":1}
,P=/^(?:cubic-)?bezier\(([^,]+),([^,]+),([^,]+),([^\)]+)\)/,Q=y.round,R="setattribute",S=parseFloat,T=parseInt,U=" progid:DXImageTransform.Microsoft",V=r[e].toUpperCase,W={
blur:0,"clip-rect":"0 0 1e9 1e9",cursor:"default",cx:0,cy:0,fill:"#fff","fill-opacity":1,font:"10px \"Arial\"","font-family":"\"Arial\"","font-size":"10","font-style":"normal","font-weight":400,gradient:0,height:0,href:" opacity:1,path:"M0,0",r:0,rotation:0,rx:0,ry:0,scale:"1 1",src:"",stroke:"#000","stroke-dasharray":"","stroke-linecap":"butt","stroke-linejoin":"butt","stroke-miterlimit":0,"stroke-opacity":1,"stroke-width":1,target:"_blank","text-anchor":"middle",title:"Raphael",translation:"0 0",width:0,x:0,y:0}
,X={
along:"along",blur:E,"clip-rect":"csv",cx:E,cy:E,fill:"colour","fill-opacity":E,"font-size":E,height:E,opacity:E,path:"path",r:E,rotation:"csv",rx:E,ry:E,scale:"csv",stroke:"colour","stroke-opacity":E,"stroke-width":E,translation:"csv",width:E,x:E,y:E}
,Y="replace",Z=/^(from|to|\d+%?)$/,$=/\s*,\s*/,_={
hs:1,rg:1}
,ba=/,?([achlmqrstvxz]),?/gi,bb=/([achlmqstvz])[\s,]*((-?\d*\.?\d*(?:e[-+]?\d+)?\s*,?\s*)+)/ig,bc=/(-?\d*\.?\d*(?:e[-+]?\d+)?)\s*,?\s*/ig,bd=/^r(?:\(([^,]+?)\s*,\s*([^\)]+?)\))?/,be=function(a,b){
return a.key-b.key}
;
a.type=h.SVGAngle||g.implementation.hasFeature(" SVG11/feature#BasicStructure","1.1")="SVG":"VML";
if(a.type=="VML"){
var bf=g.createElement("p"),bg;
bf.innerHTML="v:Shape adj=\"1\"/>
";
bg=bf.FirstChild;
bg.style.behavior="url(#default#VML)";
if(!(bg&
&
typeof bg.adj=="object"))return a.type=null;
bf=null}
a.svg=!(a.vml=a.type=="VML");
j[e]=a[e];
k=j[e];
a._id=0;
a._oid=0;
a.fn={
}
;
a.is=function(a,b){
b=x.call(b);
if(b=="finite")return!O[f](+a);
return b=="null"&
&
a===null||b==typeof a||b=="object"&
&
a===Object(a)||b=="array"&
&
Array.isArray&
&
Array.isArray(a)||J.call(a).slice(8,-1).toLowerCase()==b}
;
a.angle=function(b,c,d,e,f,g){
{
if(f==null){
var h=b-d,i=c-e;
if(!h&
&
!i)return 0;
return((h0)*180+y.atan(-i/-h)*180/D+360)%360}
return a.angle(b,c,f,g)-a.angle(d,e,f,g)}
}
;
a.rad=function(a){
return a%360*D/180}
;
a.deg=function(a){
return a*180/D%360}
;
a.snapTo=function(b,c,d){
d=a.is(d,"finite")?d:10;
if(a.is(b,G)){
var e=b.length;
while(e--)if(B(b[e]-c)=d)return b[e]}
else{
b=+b;
var f=c%b;
if(fd)return c-f;
if(f>
b-d)return c-f+b}
return c}
;
function bh(){
var a=[],b=0;
for(;
b32;
b++)a[b]=(~(~(y.random()*16)))[H](16);
a[12]=4;
a[16]=(a[16]&
3|8)[H](16);
return"r-"+a[v]("")}
a.setWindow=function(a){
h=a;
g=h.document}
;
var bi=function(b){
if(a.vml){
var c=/^\s+|\s+$/g,d;
try{
var e=new ActiveXObject("htmlfile");
e.write("body>
");
e.close();
d=e.body}
catch(a){
d=createPopup().document.body}
var f=d.createTextRange();
bi=bm(function(a){
try{
d.style.color=r(a)[Y](c,p);
var b=f.queryCommandValue("ForeColor");
b=(b&
255)16|b&
65280|(b&
16711680)>
>
>
16;
return"#"+("000000"+b[H](16)).slice(-6)}
catch(a){
return"none"}
}
)}
else{
var h=g.createElement("i");
h.title="Raphaël Colour Picker";
h.style.display="none";
g.body[l](h);
bi=bm(function(a){
h.style.color=a;
return g.defaultView.getComputedStyle(h,p).getPropertyValue("color")}
)}
return bi(b)}
,bj=function(){
return"hsb("+[this.h,this.s,this.b]+")"}
,bk=function(){
return"hsl("+[this.h,this.s,this.l]+")"}
,bl=function(){
return this.hex}
;
a.hsb2rgb=function(b,c,d,e){
if(a.is(b,"object")&
&
"h"in b&
&
"s"in b&
&
"b"in b){
d=b.b;
c=b.s;
b=b.h;
e=b.o}
return a.hsl2rgb(b,c,d/2,e)}
;
a.hsl2rgb=function(b,c,d,e){
if(a.is(b,"object")&
&
"h"in b&
&
"s"in b&
&
"l"in b){
d=b.l;
c=b.s;
b=b.h}
if(b>
1||c>
1||d>
1){
b/=360;
c/=100;
d/=100}
var f={
}
,g=["r","g","b"],h,i,j,k,l,m;
if(c){
d0.5?h=d*(1+c):h=d+c-d*c;
i=2*d-h;
for(var n=0;
n3;
n++){
j=b+1/3*-(n-1);
j0&
&
j++;
j>
1&
&
j--;
j*61?f[g[n]]=i+(h-i)*6*j:j*21?f[g[n]]=h:j*32?f[g[n]]=i+(h-i)*(2/3-j)*6:f[g[n]]=i}
}
else f={
r:d,g:d,b:d}
;
f.r*=255;
f.g*=255;
f.b*=255;
f.hex="#"+(16777216|f.b|f.g8|f.r16).toString(16).slice(1);
a.is(e,"finite")&
&
(f.opacity=e);
f.toString=bl;
return f}
;
a.rgb2hsb=function(b,c,d){
if(c==null&
&
a.is(b,"object")&
&
"r"in b&
&
"g"in b&
&
"b"in b){
d=b.b;
c=b.g;
b=b.r}
if(c==null&
&
a.is(b,F)){
var e=a.getRGB(b);
b=e.r;
c=e.g;
d=e.b}
if(b>
1||c>
1||d>
1){
b/=255;
c/=255;
d/=255}
var f=z(b,c,d),g=A(b,c,d),h,i,j=f;
{
if(g==f)return{
h:0,s:0,b:f,toString:bj}
;
var k=f-g;
i=k/f;
b==f?h=(c-d)/k:c==f?h=2+(d-b)/k:h=4+(b-c)/k;
h/=6;
h0&
&
h++;
h>
1&
&
h--}
return{
h:h,s:i,b:j,toString:bj}
}
;
a.rgb2hsl=function(b,c,d){
if(c==null&
&
a.is(b,"object")&
&
"r"in b&
&
"g"in b&
&
"b"in b){
d=b.b;
c=b.g;
b=b.r}
if(c==null&
&
a.is(b,F)){
var e=a.getRGB(b);
b=e.r;
c=e.g;
d=e.b}
if(b>
1||c>
1||d>
1){
b/=255;
c/=255;
d/=255}
var f=z(b,c,d),g=A(b,c,d),h,i,j=(f+g)/2,k;
if(g==f)k={
h:0,s:0,l:j}
;
else{
var l=f-g;
i=j0.5?l/(f+g):l/(2-f-g);
b==f?h=(c-d)/l:c==f?h=2+(d-b)/l:h=4+(b-c)/l;
h/=6;
h0&
&
h++;
h>
1&
&
h--;
k={
h:h,s:i,l:j}
}
k.toString=bk;
return k}
;
a._path2string=function(){
return this.join(",")[Y](ba,"$1")}
;
function bm(a,b,c){
function d(){
var g=Array[e].slice.call(arguments,0),h=g[v]("►"),i=d.cache=d.cache||{
}
,j=d.count=d.count||[];
if(i[f](h))return c?c(i[h]):i[h];
j[w]>
=1000&
&
delete i[j.shift()];
j[L](h);
i[h]=a[m](b,g);
return c?c(i[h]):i[h]}
return d}
a.getRGB=bm(function(b){
if(!b||!(!((b=r(b)).indexOf("-")+1)))return{
r:-1,g:-1,b:-1,hex:"none",error:1}
;
if(b=="none")return{
r:-1,g:-1,b:-1,hex:"none"}
;
!(_[f](b.toLowerCase().substring(0,2))||b.charAt()=="#")&
&
(b=bi(b));
var c,d,e,g,h,i,j,k=b.match(N);
if(k){
if(k[2]){
g=T(k[2].substring(5),16);
e=T(k[2].substring(3,5),16);
d=T(k[2].substring(1,3),16)}
if(k[3]){
g=T((i=k[3].charAt(3))+i,16);
e=T((i=k[3].charAt(2))+i,16);
d=T((i=k[3].charAt(1))+i,16)}
if(k[4]){
j=k[4][s]($);
d=S(j[0]);
j[0].slice(-1)=="%"&
&
(d*=2.55);
e=S(j[1]);
j[1].slice(-1)=="%"&
&
(e*=2.55);
g=S(j[2]);
j[2].slice(-1)=="%"&
&
(g*=2.55);
k[1].toLowerCase().slice(0,4)=="rgba"&
&
(h=S(j[3]));
j[3]&
&
j[3].slice(-1)=="%"&
&
(h/=100)}
if(k[5]){
j=k[5][s]($);
d=S(j[0]);
j[0].slice(-1)=="%"&
&
(d*=2.55);
e=S(j[1]);
j[1].slice(-1)=="%"&
&
(e*=2.55);
g=S(j[2]);
j[2].slice(-1)=="%"&
&
(g*=2.55);
(j[0].slice(-3)=="deg"||j[0].slice(-1)=="°")&
&
(d/=360);
k[1].toLowerCase().slice(0,4)=="hsba"&
&
(h=S(j[3]));
j[3]&
&
j[3].slice(-1)=="%"&
&
(h/=100);
return a.hsb2rgb(d,e,g,h)}
if(k[6]){
j=k[6][s]($);
d=S(j[0]);
j[0].slice(-1)=="%"&
&
(d*=2.55);
e=S(j[1]);
j[1].slice(-1)=="%"&
&
(e*=2.55);
g=S(j[2]);
j[2].slice(-1)=="%"&
&
(g*=2.55);
(j[0].slice(-3)=="deg"||j[0].slice(-1)=="°")&
&
(d/=360);
k[1].toLowerCase().slice(0,4)=="hsla"&
&
(h=S(j[3]));
j[3]&
&
j[3].slice(-1)=="%"&
&
(h/=100);
return a.hsl2rgb(d,e,g,h)}
k={
r:d,g:e,b:g}
;
k.hex="#"+(16777216|g|e8|d16).toString(16).slice(1);
a.is(h,"finite")&
&
(k.opacity=h);
return k}
return{
r:-1,g:-1,b:-1,hex:"none",error:1}
}
,a);
a.getColor=function(a){
var b=this.getColor.start=this.getColor.start||{
h:0,s:1,b:a||0.75}
,c=this.hsb2rgb(b.h,b.s,b.b);
b.h+=0.075;
if(b.h>
1){
b.h=0;
b.s-=0.2;
b.s=0&
&
(this.getColor.start={
h:0,s:1,b:b.b}
)}
return c.hex}
;
a.getColor.reset=function(){
delete this.start}
;
a.parsePathString=bm(function(b){
if(!b)return null;
var c={
a:7,c:6,h:1,l:2,m:2,q:4,s:4,t:2,v:1,z:0}
,d=[];
a.is(b,G)&
&
a.is(b[0],G)&
&
(d=bo(b));
d[w]||r(b)[Y](bb,function(a,b,e){
var f=[],g=x.call(b);
e[Y](bc,function(a,b){
b&
&
f[L](+b)}
);
if(g=="m"&
&
f[w]>
2){
d[L]([b][n](f.splice(0,2)));
g="l";
b=b=="m"?"l":"L"}
while(f[w]>
=c[g]){
d[L]([b][n](f.splice(0,c[g])));
if(!c[g])break}
}
);
d[H]=a._path2string;
return d}
);
a.findDotsAtSegment=function(a,b,c,d,e,f,g,h,i){
var j=1-i,k=C(j,3)*a+C(j,2)*3*i*c+j*3*i*i*e+C(i,3)*g,l=C(j,3)*b+C(j,2)*3*i*d+j*3*i*i*f+C(i,3)*h,m=a+2*i*(c-a)+i*i*(e-2*c+a),n=b+2*i*(d-b)+i*i*(f-2*d+b),o=c+2*i*(e-c)+i*i*(g-2*e+c),p=d+2*i*(f-d)+i*i*(h-2*f+d),q=(1-i)*a+i*c,r=(1-i)*b+i*d,s=(1-i)*e+i*g,t=(1-i)*f+i*h,u=90-y.atan((m-o)/(n-p))*180/D;
(m>
o||np)&
&
(u+=180);
return{
x:k,y:l,m:{
x:m,y:n}
,n:{
x:o,y:p}
,start:{
x:q,y:r}
,end:{
x:s,y:t}
,alpha:u}
}
;
var bn=bm(function(a){
if(!a)return{
x:0,y:0,width:0,height:0}
;
a=bw(a);
var b=0,c=0,d=[],e=[],f;
for(var g=0,h=a[w];
gh;
g++){
f=a[g];
if(f[0]=="M"){
b=f[1];
c=f[2];
d[L](b);
e[L](c)}
else{
var i=bv(b,c,f[1],f[2],f[3],f[4],f[5],f[6]);
d=d[n](i.min.x,i.max.x);
e=e[n](i.min.y,i.max.y);
b=f[5];
c=f[6]}
}
var j=A[m](0,d),k=A[m](0,e);
return{
x:j,y:k,width:z[m](0,d)-j,height:z[m](0,e)-k}
}
),bo=function(b){
var c=[];
if(!a.is(b,G)||!a.is(b&
&
b[0],G))b=a.parsePathString(b);
for(var d=0,e=b[w];
de;
d++){
c[d]=[];
for(var f=0,g=b[d][w];
fg;
f++)c[d][f]=b[d][f]}
c[H]=a._path2string;
return c}
,bp=bm(function(b){
if(!a.is(b,G)||!a.is(b&
&
b[0],G))b=a.parsePathString(b);
var c=[],d=0,e=0,f=0,g=0,h=0;
if(b[0][0]=="M"){
d=b[0][1];
e=b[0][2];
f=d;
g=e;
h++;
c[L](["M",d,e])}
for(var i=h,j=b[w];
ij;
i++){
var k=c[i]=[],l=b[i];
if(l[0]!=x.call(l[0])){
k[0]=x.call(l[0]);
switch(k[0]){
case"a":k[1]=l[1];
k[2]=l[2];
k[3]=l[3];
k[4]=l[4];
k[5]=l[5];
k[6]=+(l[6]-d).toFixed(3);
k[7]=+(l[7]-e).toFixed(3);
break;
case"v":k[1]=+(l[1]-e).toFixed(3);
break;
case"m":f=l[1];
g=l[2];
default:for(var m=1,n=l[w];
mn;
m++)k[m]=+(l[m]-(m%2?d:e)).toFixed(3)}
}
else{
k=c[i]=[];
if(l[0]=="m"){
f=l[1]+d;
g=l[2]+e}
for(var o=0,p=l[w];
op;
o++)c[i][o]=l[o]}
var q=c[i][w];
switch(c[i][0]){
case"z":d=f;
e=g;
break;
case"h":d+=+c[i][q-1];
break;
case"v":e+=+c[i][q-1];
break;
default:d+=+c[i][q-2];
e+=+c[i][q-1]}
}
c[H]=a._path2string;
return c}
,0,bo),bq=bm(function(b){
if(!a.is(b,G)||!a.is(b&
&
b[0],G))b=a.parsePathString(b);
var c=[],d=0,e=0,f=0,g=0,h=0;
if(b[0][0]=="M"){
d=+b[0][1];
e=+b[0][2];
f=d;
g=e;
h++;
c[0]=["M",d,e]}
for(var i=h,j=b[w];
ij;
i++){
var k=c[i]=[],l=b[i];
if(l[0]!=V.call(l[0])){
k[0]=V.call(l[0]);
switch(k[0]){
case"A":k[1]=l[1];
k[2]=l[2];
k[3]=l[3];
k[4]=l[4];
k[5]=l[5];
k[6]=+(l[6]+d);
k[7]=+(l[7]+e);
break;
case"V":k[1]=+l[1]+e;
break;
case"H":k[1]=+l[1]+d;
break;
case"M":f=+l[1]+d;
g=+l[2]+e;
default:for(var m=1,n=l[w];
mn;
m++)k[m]=+l[m]+(m%2?d:e)}
}
else for(var o=0,p=l[w];
op;
o++)c[i][o]=l[o];
switch(k[0]){
case"Z":d=f;
e=g;
break;
case"H":d=k[1];
break;
case"V":e=k[1];
break;
case"M":f=c[i][c[i][w]-2];
g=c[i][c[i][w]-1];
default:d=c[i][c[i][w]-2];
e=c[i][c[i][w]-1]}
}
c[H]=a._path2string;
return c}
,null,bo),br=function(a,b,c,d){
return[a,b,c,d,c,d]}
,bs=function(a,b,c,d,e,f){
var g=1/3,h=2/3;
return[g*a+h*c,g*b+h*d,g*e+h*c,g*f+h*d,e,f]}
,bt=function(a,b,c,d,e,f,g,h,i,j){
var k=D*120/180,l=D/180*(+e||0),m=[],o,p=bm(function(a,b,c){
var d=a*y.cos(c)-b*y.sin(c),e=a*y.sin(c)+b*y.cos(c);
return{
x:d,y:e}
}
);
if(j){
G=j[0];
H=j[1];
E=j[2];
F=j[3]}
else{
o=p(a,b,-l);
a=o.x;
b=o.y;
o=p(h,i,-l);
h=o.x;
i=o.y;
var q=y.cos(D/180*e),r=y.sin(D/180*e),t=(a-h)/2,u=(b-i)/2,x=t*t/(c*c)+u*u/(d*d);
if(x>
1){
x=y.sqrt(x);
c=x*c;
d=x*d}
var z=c*c,A=d*d,C=(f==g?-1:1)*y.sqrt(B((z*A-z*u*u-A*t*t)/(z*u*u+A*t*t))),E=C*c*u/d+(a+h)/2,F=C*-d*t/c+(b+i)/2,G=y.asin(((b-F)/d).toFixed(9)),H=y.asin(((i-F)/d).toFixed(9));
G=aE?D-G:G;
H=hE?D-H:H;
G0&
&
(G=D*2+G);
H0&
&
(H=D*2+H);
g&
&
G>
H&
&
(G=G-D*2);
!g&
&
H>
G&
&
(H=H-D*2)}
var I=H-G;
if(B(I)>
k){
var J=H,K=h,L=i;
H=G+k*(g&
&
H>
G?1:-1);
h=E+c*y.cos(H);
i=F+d*y.sin(H);
m=bt(h,i,c,d,e,0,g,K,L,[H,J,E,F])}
I=H-G;
var M=y.cos(G),N=y.sin(G),O=y.cos(H),P=y.sin(H),Q=y.tan(I/4),R=4/3*c*Q,S=4/3*d*Q,T=[a,b],U=[a+R*N,b-S*M],V=[h+R*P,i-S*O],W=[h,i];
U[0]=2*T[0]-U[0];
U[1]=2*T[1]-U[1];
{
if(j)return[U,V,W][n](m);
m=[U,V,W][n](m)[v]()[s](",");
var X=[];
for(var Y=0,Z=m[w];
YZ;
Y++)X[Y]=Y%2?p(m[Y-1],m[Y],l).y:p(m[Y],m[Y+1],l).x;
return X}
}
,bu=function(a,b,c,d,e,f,g,h,i){
var j=1-i;
return{
x:C(j,3)*a+C(j,2)*3*i*c+j*3*i*i*e+C(i,3)*g,y:C(j,3)*b+C(j,2)*3*i*d+j*3*i*i*f+C(i,3)*h}
}
,bv=bm(function(a,b,c,d,e,f,g,h){
var i=e-2*c+a-(g-2*e+c),j=2*(c-a)-2*(e-c),k=a-c,l=(-j+y.sqrt(j*j-4*i*k))/2/i,n=(-j-y.sqrt(j*j-4*i*k))/2/i,o=[b,h],p=[a,g],q;
B(l)>
"1e12"&
&
(l=0.5);
B(n)>
"1e12"&
&
(n=0.5);
if(l>
0&
&
l1){
q=bu(a,b,c,d,e,f,g,h,l);
p[L](q.x);
o[L](q.y)}
if(n>
0&
&
n1){
q=bu(a,b,c,d,e,f,g,h,n);
p[L](q.x);
o[L](q.y)}
i=f-2*d+b-(h-2*f+d);
j=2*(d-b)-2*(f-d);
k=b-d;
l=(-j+y.sqrt(j*j-4*i*k))/2/i;
n=(-j-y.sqrt(j*j-4*i*k))/2/i;
B(l)>
"1e12"&
&
(l=0.5);
B(n)>
"1e12"&
&
(n=0.5);
if(l>
0&
&
l1){
q=bu(a,b,c,d,e,f,g,h,l);
p[L](q.x);
o[L](q.y)}
if(n>
0&
&
n1){
q=bu(a,b,c,d,e,f,g,h,n);
p[L](q.x);
o[L](q.y)}
return{
min:{
x:A[m](0,p),y:A[m](0,o)}
,max:{
x:z[m](0,p),y:z[m](0,o)}
}
}
),bw=bm(function(a,b){
var c=bq(a),d=b&
&
bq(b),e={
x:0,y:0,bx:0,by:0,X:0,Y:0,qx:null,qy:null}
,f={
x:0,y:0,bx:0,by:0,X:0,Y:0,qx:null,qy:null}
,g=function(a,b){
var c,d;
if(!a)return["C",b.x,b.y,b.x,b.y,b.x,b.y];
!(a[0]in{
T:1,Q:1}
)&
&
(b.qx=b.qy=null);
switch(a[0]){
case"M":b.X=a[1];
b.Y=a[2];
break;
case"A":a=["C"][n](bt[m](0,[b.x,b.y][n](a.slice(1))));
break;
case"S":c=b.x+(b.x-(b.bx||b.x));
d=b.y+(b.y-(b.by||b.y));
a=["C",c,d][n](a.slice(1));
break;
case"T":b.qx=b.x+(b.x-(b.qx||b.x));
b.qy=b.y+(b.y-(b.qy||b.y));
a=["C"][n](bs(b.x,b.y,b.qx,b.qy,a[1],a[2]));
break;
case"Q":b.qx=a[1];
b.qy=a[2];
a=["C"][n](bs(b.x,b.y,a[1],a[2],a[3],a[4]));
break;
case"L":a=["C"][n](br(b.x,b.y,a[1],a[2]));
break;
case"H":a=["C"][n](br(b.x,b.y,a[1],b.y));
break;
case"V":a=["C"][n](br(b.x,b.y,b.x,a[1]));
break;
case"Z":a=["C"][n](br(b.x,b.y,b.X,b.Y));
break}
return a}
,h=function(a,b){
if(a[b][w]>
7){
a[b].shift();
var e=a[b];
while(e[w])a.splice(b++,0,["C"][n](e.splice(0,6)));
a.splice(b,1);
k=z(c[w],d&
&
d[w]||0)}
}
,i=function(a,b,e,f,g){
if(a&
&
b&
&
a[g][0]=="M"&
&
b[g][0]!="M"){
b.splice(g,0,["M",f.x,f.y]);
e.bx=0;
e.by=0;
e.x=a[g][1];
e.y=a[g][2];
k=z(c[w],d&
&
d[w]||0)}
}
;
for(var j=0,k=z(c[w],d&
&
d[w]||0);
jk;
j++){
c[j]=g(c[j],e);
h(c,j);
d&
&
(d[j]=g(d[j],f));
d&
&
h(d,j);
i(c,d,e,f,j);
i(d,c,f,e,j);
var l=c[j],o=d&
&
d[j],p=l[w],q=d&
&
o[w];
e.x=l[p-2];
e.y=l[p-1];
e.bx=S(l[p-4])||e.x;
e.by=S(l[p-3])||e.y;
f.bx=d&
&
(S(o[q-4])||f.x);
f.by=d&
&
(S(o[q-3])||f.y);
f.x=d&
&
o[q-2];
f.y=d&
&
o[q-1]}
return d?[c,d]:c}
,null,bo),bx=bm(function(b){
var c=[];
for(var d=0,e=b[w];
de;
d++){
var f={
}
,g=b[d].match(/^([^:]*):?([\d\.]*)/);
f.color=a.getRGB(g[1]);
if(f.color.error)return null;
f.color=f.color.hex;
g[2]&
&
(f.offset=g[2]+"%");
c[L](f)}
for(d=1,e=c[w]-1;
de;
d++){
if(!c[d].offset){
var h=S(c[d-1].offset||0),i=0;
for(var j=d+1;
je;
j++){
if(c[j].offset){
i=c[j].offset;
break}
}
if(!i){
i=100;
j=e}
i=S(i);
var k=(i-h)/(j-d+1);
for(;
dj;
d++){
h+=k;
c[d].offset=h+"%"}
}
}
return c}
),by=function(b,c,d,e){
var f;
if(a.is(b,F)||a.is(b,"object")){
f=a.is(b,F)?g.getElementById(b):b;
if(f.tagName)return c==null?{
container:f,width:f.style.pixelWidth||f.offsetWidth,height:f.style.pixelHeight||f.offsetHeight}
:{
container:f,width:c,height:d}
}
else return{
container:1,x:b,y:c,width:d,height:e}
}
,bz=function(a,b){
var c=this;
for(var d in b){
if(b[f](d)&
&
!(d in a))switch(typeof b[d]){
case"function":(function(b){
a[d]=a===c?b:function(){
return b[m](c,arguments)}
}
)(b[d]);
break;
case"object":a[d]=a[d]||{
}
;
bz.call(this,a[d],b[d]);
break;
default:a[d]=b[d];
break}
}
}
,bA=function(a,b){
a==b.top&
&
(b.top=a.prev);
a==b.bottom&
&
(b.bottom=a.next);
a.next&
&
(a.next.prev=a.prev);
a.prev&
&
(a.prev.next=a.next)}
,bB=function(a,b){
if(b.top===a)return;
bA(a,b);
a.next=null;
a.prev=b.top;
b.top.next=a;
b.top=a}
,bC=function(a,b){
if(b.bottom===a)return;
bA(a,b);
a.next=b.bottom;
a.prev=null;
b.bottom.prev=a;
b.bottom=a}
,bD=function(a,b,c){
bA(a,c);
b==c.top&
&
(c.top=a);
b.next&
&
(b.next.prev=a);
a.next=b.next;
a.prev=b;
b.next=a}
,bE=function(a,b,c){
bA(a,c);
b==c.bottom&
&
(c.bottom=a);
b.prev&
&
(b.prev.next=a);
a.prev=b.prev;
b.prev=a;
a.next=b}
,bF=function(a){
return function(){
throw new Error("Raphaël: you are calling to method “"+a+"” of removed object")}
}
;
a.pathToRelative=bp;
if(a.svg){
k.svgns=" return+a+(~(~a)===a)*0.5}
;
var bG=function(a,b){
if(b)for(var c in b)b[f](c)&
&
a[R](c,r(b[c]));
else{
a=g.createElementNS(k.svgns,a);
a.style.webkitTapHighlightColor="rgba(0,0,0,0)";
return a}
}
;
a[H]=function(){
return"Your browser supports SVG.\nYou are running Raphaël "+this.version}
;
var bH=function(a,b){
var c=bG("path");
b.canvas&
&
b.canvas[l](c);
var d=new bN(c,b);
d.type="path";
bK(d,{
fill:"none",stroke:"#000",path:a}
);
return d}
,bI=function(a,b,c){
var d="linear",e=0.5,f=0.5,h=a.style;
b=r(b)[Y](bd,function(a,b,c){
d="radial";
if(b&
&
c){
e=S(b);
f=S(c);
var g=(f>
0.5)*2-1;
C(e-0.5,2)+C(f-0.5,2)>
0.25&
&
(f=y.sqrt(0.25-C(e-0.5,2))*g+0.5)&
&
f!=0.5&
&
(f=f.toFixed(5)-0.00001*g)}
return p}
);
b=b[s](/\s*\-\s*/);
if(d=="linear"){
var i=b.shift();
i=-S(i);
if(isNaN(i))return null;
var j=[0,0,y.cos(i*D/180),y.sin(i*D/180)],k=1/(z(B(j[2]),B(j[3]))||1);
j[2]*=k;
j[3]*=k;
if(j[2]0){
j[0]=-j[2];
j[2]=0}
if(j[3]0){
j[1]=-j[3];
j[3]=0}
}
var m=bx(b);
if(!m)return null;
var n=a.getAttribute(I);
n=n.match(/^url\(#(.*)\)$/);
n&
&
c.defs.removeChild(g.getElementById(n[1]));
var o=bG(d+"Gradient");
o.id=bh();
bG(o,d=="radial"?{
fx:e,fy:f}
:{
x1:j[0],y1:j[1],x2:j[2],y2:j[3]}
);
c.defs[l](o);
for(var q=0,t=m[w];
qt;
q++){
var u=bG("stop");
bG(u,{
offset:m[q].offset?m[q].offset:q?"100%":"0%","stop-color":m[q].color||"#fff"}
);
o[l](u)}
bG(a,{
fill:"url(#"+o.id+")",opacity:1,"fill-opacity":1}
);
h.fill=p;
h.opacity=1;
h.fillOpacity=1;
return 1}
,bJ=function(b){
var c=b.getBBox();
bG(b.pattern,{
patternTransform:a.format("translate({
0}
,{
1}
)",c.x,c.y)}
)}
,bK=function(c,d){
var e={
"":[0],none:[0],"-":[3,1],".":[1,1],"-.":[3,1,1,1],"-..":[3,1,1,1,1,1],". ":[1,3],"- ":[4,3],"--":[8,3],"- .":[4,3,1,3],"--.":[8,3,1,3],"--..":[8,3,1,3,1,3]}
,h=c.node,i=c.attrs,j=c.rotate(),k=function(a,b){
b=e[x.call(b)];
if(b){
var c=a.attrs["stroke-width"]||"1",f=({
round:c,square:c,butt:0}
)[a.attrs["stroke-linecap"]||d["stroke-linecap"]]||0,g=[],i=b[w];
while(i--)g[i]=b[i]*c+(i%2?1:-1)*f;
bG(h,{
"stroke-dasharray":g[v](",")}
)}
}
;
d[f]("rotation")&
&
(j=d.rotation);
var m=r(j)[s](b);
if(m.length-1){
m[1]=+m[1];
m[2]=+m[2]}
else m=null;
S(j)&
&
c.rotate(0,true);
for(var n in d){
if(d[f](n)){
if(!W[f](n))continue;
var o=d[n];
i[n]=o;
switch(n){
case"blur":c.blur(o);
break;
case"rotation":c.rotate(o,true);
break;
case"href":case"title":case"target":var t=h.parentNode;
if(x.call(t.tagName)!="a"){
var u=bG("a");
t.insertBefore(u,h);
u[l](h);
t=u}
n=="target"&
&
o=="blank"?t.setAttributeNS(c.paper.xlink,"show","new"):t.setAttributeNS(c.paper.xlink,n,o);
break;
case"cursor":h.style.cursor=o;
break;
case"clip-rect":var y=r(o)[s](b);
if(y[w]==4){
c.clip&
&
c.clip.parentNode.parentNode.removeChild(c.clip.parentNode);
var z=bG("clipPath"),A=bG("rect");
z.id=bh();
bG(A,{
x:y[0],y:y[1],width:y[2],height:y[3]}
);
z[l](A);
c.paper.defs[l](z);
bG(h,{
"clip-path":"url(#"+z.id+")"}
);
c.clip=A}
if(!o){
var B=g.getElementById(h.getAttribute("clip-path")[Y](/(^url\(#|\)$)/g,p));
B&
&
B.parentNode.removeChild(B);
bG(h,{
"clip-path":p}
);
delete c.clip}
break;
case"path":c.type=="path"&
&
bG(h,{
d:o?i.path=bq(o):"M0,0"}
);
break;
case"width":h[R](n,o);
if(i.fx){
n="x";
o=i.x}
else break;
case"x":i.fx&
&
(o=-i.x-(i.width||0));
case"rx":if(n=="rx"&
&
c.type=="rect")break;
case"cx":m&
&
(n=="x"||n=="cx")&
&
(m[1]+=o-i[n]);
h[R](n,o);
c.pattern&
&
bJ(c);
break;
case"height":h[R](n,o);
if(i.fy){
n="y";
o=i.y}
else break;
case"y":i.fy&
&
(o=-i.y-(i.height||0));
case"ry":if(n=="ry"&
&
c.type=="rect")break;
case"cy":m&
&
(n=="y"||n=="cy")&
&
(m[2]+=o-i[n]);
h[R](n,o);
c.pattern&
&
bJ(c);
break;
case"r":c.type=="rect"?bG(h,{
rx:o,ry:o}
):h[R](n,o);
break;
case"src":c.type=="image"&
&
h.setAttributeNS(c.paper.xlink,"href",o);
break;
case"stroke-width":h.style.strokeWidth=o;
h[R](n,o);
i["stroke-dasharray"]&
&
k(c,i["stroke-dasharray"]);
break;
case"stroke-dasharray":k(c,o);
break;
case"translation":var C=r(o)[s](b);
C[0]=+C[0]||0;
C[1]=+C[1]||0;
if(m){
m[1]+=C[0];
m[2]+=C[1]}
cz.call(c,C[0],C[1]);
break;
case"scale":C=r(o)[s](b);
c.scale(+C[0]||1,+C[1]||+C[0]||1,isNaN(S(C[2]))?null:+C[2],isNaN(S(C[3]))?null:+C[3]);
break;
case I:var D=r(o).match(M);
if(D){
z=bG("pattern");
var E=bG("image");
z.id=bh();
bG(z,{
x:0,y:0,patternUnits:"userSpaceOnUse",height:1,width:1}
);
bG(E,{
x:0,y:0}
);
E.setAttributeNS(c.paper.xlink,"href",D[1]);
z[l](E);
var F=g.createElement("img");
F.style.cssText="position:absolute;
left:-9999em;
top-9999em";
F.onload=function(){
bG(z,{
width:this.offsetWidth,height:this.offsetHeight}
);
bG(E,{
width:this.offsetWidth,height:this.offsetHeight}
);
g.body.removeChild(this);
c.paper.safari()}
;
g.body[l](F);
F.src=D[1];
c.paper.defs[l](z);
h.style.fill="url(#"+z.id+")";
bG(h,{
fill:"url(#"+z.id+")"}
);
c.pattern=z;
c.pattern&
&
bJ(c);
break}
var G=a.getRGB(o);
if(G.error)if((({
circle:1,ellipse:1}
)[f](c.type)||r(o).charAt()!="r")&
&
bI(h,o,c.paper)){
i.gradient=o;
i.fill="none";
break}
else{
delete d.gradient;
delete i.gradient;
!a.is(i.opacity,"undefined")&
&
a.is(d.opacity,"undefined")&
&
bG(h,{
opacity:i.opacity}
);
!a.is(i["fill-opacity"],"undefined")&
&
a.is(d["fill-opacity"],"undefined")&
&
bG(h,{
"fill-opacity":i["fill-opacity"]}
)}
G[f]("opacity")&
&
bG(h,{
"fill-opacity":G.opacity>
1?G.opacity/100:G.opacity}
);
case"stroke":G=a.getRGB(o);
h[R](n,G.hex);
n=="stroke"&
&
G[f]("opacity")&
&
bG(h,{
"stroke-opacity":G.opacity>
1?G.opacity/100:G.opacity}
);
break;
case"gradient":(({
circle:1,ellipse:1}
)[f](c.type)||r(o).charAt()!="r")&
&
bI(h,o,c.paper);
break;
case"opacity":i.gradient&
&
!i[f]("stroke-opacity")&
&
bG(h,{
"stroke-opacity":o>
1?o/100:o}
);
case"fill-opacity":if(i.gradient){
var H=g.getElementById(h.getAttribute(I)[Y](/^url\(#|\)$/g,p));
if(H){
var J=H.getelementsbytagname("stop");
J[J[w]-1][R]("stop-opacity",o)}
break}
default:n=="font-size"&
&
(o=T(o,10)+"px");
var K=n[Y](/(\-.)/g,function(a){
return V.call(a.substring(1))}
);
h.style[K]=o;
h[R](n,o);
break}
}
}
bM(c,d);
m?c.rotate(m.join(q)):S(j)&
&
c.rotate(j,true)}
,bL=1.2,bM=function(b,c){
if(b.type!="text"||!(c[f]("text")||c[f]("font")||c[f]("font-size")||c[f]("x")||c[f]("y")))return;
var d=b.attrs,e=b.node,h=e.firstChild?T(g.defaultView.getComputedStyle(e.firstChild,p).getPropertyValue("font-size"),10):10;
if(c[f]("text")){
d.text=c.text;
while(e.firstChild)e.removeChild(e.firstChild);
var i=r(c.text)[s]("\n");
for(var j=0,k=i[w];
jk;
j++)if(i[j]){
var m=bG("tspan");
j&
&
bG(m,{
dy:h*bL,x:d.x}
);
m[l](g.createTextNode(i[j]));
e[l](m)}
}
else{
i=e.getElementsByTagName("tspan");
for(j=0,k=i[w];
jk;
j++)j&
&
bG(i[j],{
dy:h*bL,x:d.x}
)}
bG(e,{
y:d.y}
);
var n=b.getBBox(),o=d.y-(n.y+n.height/2);
o&
&
a.is(o,"finite")&
&
bG(e,{
y:d.y+o}
)}
,bN=function(b,c){
var d=0,e=0;
this[0]=b;
this.id=a._oid++;
this.node=b;
b.raphael=this;
this.paper=c;
this.attrs=this.attrs||{
}
;
this.transformations=[];
this._={
tx:0,ty:0,rt:{
deg:0,cx:0,cy:0}
,sx:1,sy:1}
;
!c.bottom&
&
(c.bottom=this);
this.prev=c.top;
c.top&
&
(c.top.next=this);
c.top=this;
this.next=null}
,bO=bN[e];
bN[e].rotate=function(c,d,e){
if(this.removed)return this;
if(c==null){
if(this._.rt.cx)return[this._.rt.deg,this._.rt.cx,this._.rt.cy][v](q);
return this._.rt.deg}
var f=this.getBBox();
c=r(c)[s](b);
if(c[w]-1){
d=S(c[1]);
e=S(c[2])}
c=S(c[0]);
d!=null&
&
d!==false?this._.rt.deg=c:this._.rt.deg+=c;
e==null&
&
(d=null);
this._.rt.cx=d;
this._.rt.cy=e;
d=d==null?f.x+f.width/2:d;
e=e==null?f.y+f.height/2:e;
if(this._.rt.deg){
this.transformations[0]=a.format("rotate({
0}
{
1}
{
2}
)",this._.rt.deg,d,e);
this.clip&
&
bG(this.clip,{
transform:a.format("rotate({
0}
{
1}
{
2}
)",-this._.rt.deg,d,e)}
)}
else{
this.transformations[0]=p;
this.clip&
&
bG(this.clip,{
transform:p}
)}
bG(this.node,{
transform:this.transformations[v](q)}
);
return this}
;
bN[e].hide=function(){
!this.removed&
&
(this.node.style.display="none");
return this}
;
bN[e].show=function(){
!this.removed&
&
(this.node.style.display="");
return this}
;
bN[e].remove=function(){
if(this.removed)return;
bA(this,this.paper);
this.node.parentNode.removeChild(this.node);
for(var a in this)delete this[a];
this.removed=true}
;
bN[e].getBBox=function(){
if(this.removed)return this;
if(this.type=="path")return bn(this.attrs.path);
if(this.node.style.display=="none"){
this.show();
var a=true}
var b={
}
;
try{
b=this.node.getBBox()}
catch(a){
}
finally{
b=b||{
}
}
if(this.type=="text"){
b={
x:b.x,y:Infinity,width:0,height:0}
;
for(var c=0,d=this.node.getNumberOfchars();
cd;
c++){
var e=this.node.getExtentOfChar(c);
e.yb.y&
&
(b.y=e.y);
e.y+e.height-b.y>
b.height&
&
(b.height=e.y+e.height-b.y);
e.x+e.width-b.x>
b.width&
&
(b.width=e.x+e.width-b.x)}
}
a&
&
this.hide();
return b}
;
bN[e].attr=function(b,c){
if(this.removed)return this;
if(b==null){
var d={
}
;
for(var e in this.attrs)this.attrs[f](e)&
&
(d[e]=this.attrs[e]);
this._.rt.deg&
&
(d.rotation=this.rotate());
(this._.sx!=1||this._.sy!=1)&
&
(d.scale=this.scale());
d.gradient&
&
d.fill=="none"&
&
(d.fill=d.gradient)&
&
delete d.gradient;
return d}
if(c==null&
&
a.is(b,F)){
if(b=="translation")return cz.call(this);
if(b=="rotation")return this.rotate();
if(b=="scale")return this.scale();
if(b==I&
&
this.attrs.fill=="none"&
&
this.attrs.gradient)return this.attrs.gradient;
return this.attrs[b]}
if(c==null&
&
a.is(b,G)){
var g={
}
;
for(var h=0,i=b.length;
hi;
h++)g[b[h]]=this.attr(b[h]);
return g}
if(c!=null){
var j={
}
;
j[b]=c}
else b!=null&
&
a.is(b,"object")&
&
(j=b);
for(var k in this.paper.customAttributes)if(this.paper.customAttributes[f](k)&
&
j[f](k)&
&
a.is(this.paper.customAttributes[k],"function")){
var l=this.paper.customAttributes[k].apply(this,[][n](j[k]));
this.attrs[k]=j[k];
for(var m in l)l[f](m)&
&
(j[m]=l[m])}
bK(this,j);
return this}
;
bN[e].toFront=function(){
if(this.removed)return this;
this.node.parentNode[l](this.node);
var a=this.paper;
a.top!=this&
&
bB(this,a);
return this}
;
bN[e].toBack=function(){
if(this.removed)return this;
if(this.node.parentNode.firstChild!=this.node){
this.node.parentNode.insertBefore(this.node,this.node.parentNode.firstChild);
bC(this,this.paper);
var a=this.paper}
return this}
;
bN[e].insertAfter=function(a){
if(this.removed)return this;
var b=a.node||a[a.length-1].node;
b.nextSibling?b.parentNode.insertBefore(this.node,b.nextSibling):b.parentNode[l](this.node);
bD(this,a,this.paper);
return this}
;
bN[e].insertBefore=function(a){
if(this.removed)return this;
var b=a.node||a[0].node;
b.parentNode.insertBefore(this.node,b);
bE(this,a,this.paper);
return this}
;
bN[e].blur=function(a){
var b=this;
if(+a!==0){
var c=bG("filter"),d=bG("feGaussianBlur");
b.attrs.blur=a;
c.id=bh();
bG(d,{
stdDeviation:+a||1.5}
);
c.appendChild(d);
b.paper.defs.appendChild(c);
b._blur=c;
bG(b.node,{
filter:"url(#"+c.id+")"}
)}
else{
if(b._blur){
b._blur.parentNode.removeChild(b._blur);
delete b._blur;
delete b.attrs.blur}
b.node.removeAttribute("filter")}
}
;
var bP=function(a,b,c,d){
var e=bG("circle");
a.canvas&
&
a.canvas[l](e);
var f=new bN(e,a);
f.attrs={
cx:b,cy:c,r:d,fill:"none",stroke:"#000"}
;
f.type="circle";
bG(e,f.attrs);
return f}
,bQ=function(a,b,c,d,e,f){
var g=bG("rect");
a.canvas&
&
a.canvas[l](g);
var h=new bN(g,a);
h.attrs={
x:b,y:c,width:d,height:e,r:f||0,rx:f||0,ry:f||0,fill:"none",stroke:"#000"}
;
h.type="rect";
bG(g,h.attrs);
return h}
,bR=function(a,b,c,d,e){
var f=bG("ellipse");
a.canvas&
&
a.canvas[l](f);
var g=new bN(f,a);
g.attrs={
cx:b,cy:c,rx:d,ry:e,fill:"none",stroke:"#000"}
;
g.type="ellipse";
bG(f,g.attrs);
return g}
,bS=function(a,b,c,d,e,f){
var g=bG("image");
bG(g,{
x:c,y:d,width:e,height:f,preserveAspectRatio:"none"}
);
g.setAttributeNS(a.xlink,"href",b);
a.canvas&
&
a.canvas[l](g);
var h=new bN(g,a);
h.attrs={
x:c,y:d,width:e,height:f,src:b}
;
h.type="image";
return h}
,bT=function(a,b,c,d){
var e=bG("text");
bG(e,{
x:b,y:c,"text-anchor":"middle"}
);
a.canvas&
&
a.canvas[l](e);
var f=new bN(e,a);
f.attrs={
x:b,y:c,"text-anchor":"middle",text:d,font:W.font,stroke:"none",fill:"#000"}
;
f.type="text";
bK(f,f.attrs);
return f}
,bU=function(a,b){
this.width=a||this.width;
this.height=b||this.height;
this.canvas[R]("width",this.width);
this.canvas[R]("height",this.height);
return this}
,bV=function(){
var b=by[m](0,arguments),c=b&
&
b.container,d=b.x,e=b.y,f=b.width,h=b.height;
if(!c)throw new Error("SVG container not found.");
var i=bG("svg");
d=d||0;
e=e||0;
f=f||512;
h=h||342;
bG(i,{
XMlns:" if(c==1){
i.style.cssText="position:absolute;
left:"+d+"px;
top:"+e+"px";
g.body[l](i)}
else c.firstChild?c.insertBefore(i,c.firstChild):c[l](i);
c=new j;
c.width=f;
c.height=h;
c.canvas=i;
bz.call(c,c,a.fn);
c.clear();
return c}
;
k.clear=function(){
var a=this.canvas;
while(a.firstChild)a.removeChild(a.firstChild);
this.bottom=this.top=null;
(this.desc=bG("desc"))[l](g.createTextNode("Created with Raphaël"));
a[l](this.desc);
a[l](this.defs=bG("defs"))}
;
k.remove=function(){
this.canvas.parentNode&
&
this.canvas.parentNode.removeChild(this.canvas);
for(var a in this)this[a]=bF(a)}
}
if(a.vml){
var bW={
M:"m",L:"l",C:"c",Z:"x",m:"t",l:"r",c:"v",z:"x"}
,bX=/([clmz]),?([^clmz]*)/gi,bY=/ progid:\S+Blur\([^\)]+\)/g,bZ=/-?[^,\s-]+/g,b$=1000+q+1000,b_=10,ca={
path:1,rect:1}
,cb=function(a){
var b=/[ahqstv]/ig,c=bq;
r(a).match(b)&
&
(c=bw);
b=/[clmz]/g;
if(c==bq&
&
!r(a).match(b)){
var d=r(a)[Y](bX,function(a,b,c){
var d=[],e=x.call(b)=="m",f=bW[b];
c[Y](bZ,function(a){
if(e&
&
d[w]==2){
f+=d+bW[b=="m"?"l":"L"];
d=[]}
d[L](Q(a*b_))}
);
return f+d}
);
return d}
var e=c(a),f,g;
d=[];
for(var h=0,i=e[w];
hi;
h++){
f=e[h];
g=x.call(e[h][0]);
g=="z"&
&
(g="x");
for(var j=1,k=f[w];
jk;
j++)g+=Q(f[j]*b_)+(j!=k-1?",":p);
d[L](g)}
return d[v](q)}
;
a[H]=function(){
return"Your browser doesn’t support SVG. Falling down to VML.\nYou are running Raphaël "+this.version}
;
bH=function(a,b){
var c=cd("group");
c.style.cssText="position:absolute;
left:0;
top:0;
width:"+b.width+"px;
height:"+b.height+"px";
c.coordsize=b.coordsize;
c.coordorigin=b.coordorigin;
var d=cd("shape"),e=d.style;
e.width=b.width+"px";
e.height=b.height+"px";
d.coordsize=b$;
d.coordorigin=b.coordorigin;
c[l](d);
var f=new bN(d,c,b),g={
fill:"none",stroke:"#000"}
;
a&
&
(g.path=a);
f.type="path";
f.path=[];
f.Path=p;
bK(f,g);
b.canvas[l](c);
return f}
;
bK=function(c,d){
c.attrs=c.attrs||{
}
;
var e=c.node,h=c.attrs,i=e.style,j,k=(d.x!=h.x||d.y!=h.y||d.width!=h.width||d.height!=h.height||d.r!=h.r)&
&
c.type=="rect",m=c;
for(var n in d)d[f](n)&
&
(h[n]=d[n]);
if(k){
h.path=cc(h.x,h.y,h.width,h.height,h.r);
c.X=h.x;
c.Y=h.y;
c.W=h.width;
c.H=h.height}
d.href&
&
(e.href=d.href);
d.title&
&
(e.title=d.title);
d.target&
&
(e.target=d.target);
d.cursor&
&
(i.cursor=d.cursor);
"blur"in d&
&
c.blur(d.blur);
if(d.path&
&
c.type=="path"||k)e.path=cb(h.path);
d.rotation!=null&
&
c.rotate(d.rotation,true);
if(d.translation){
j=r(d.translation)[s](b);
cz.call(c,j[0],j[1]);
if(c._.rt.cx!=null){
c._.rt.cx+=+j[0];
c._.rt.cy+=+j[1];
c.setBox(c.attrs,j[0],j[1])}
}
if(d.scale){
j=r(d.scale)[s](b);
c.scale(+j[0]||1,+j[1]||+j[0]||1,+j[2]||null,+j[3]||null)}
if("clip-rect"in d){
var o=r(d["clip-rect"])[s](b);
if(o[w]==4){
o[2]=+o[2]+ +o[0];
o[3]=+o[3]+ +o[1];
var q=e.clipRect||g.createElement("p"),t=q.style,u=e.parentNode;
t.clip=a.format("rect({
1}
px {
2}
px {
3}
px {
0}
px)",o);
if(!e.clipRect){
t.position="absolute";
t.top=0;
t.left=0;
t.width=c.paper.width+"px";
t.height=c.paper.height+"px";
u.parentNode.insertBefore(q,u);
q[l](u);
e.clipRect=q}
}
d["clip-rect"]||e.clipRect&
&
(e.clipRect.style.clip=p)}
c.type=="image"&
&
d.src&
&
(e.src=d.src);
if(c.type=="image"&
&
d.opacity){
e.filterOpacity=U+".Alpha(opacity="+d.opacity*100+")";
i.filter=(e.filterMatrix||p)+(e.filterOpacity||p)}
d.font&
&
(i.font=d.font);
d["font-family"]&
&
(i.fontFamily="\""+d["font-family"][s](",")[0][Y](/^['"]+|['"]+$/g,p)+"\"");
d["font-size"]&
&
(i.fontSize=d["font-size"]);
d["font-weight"]&
&
(i.fontWeight=d["font-weight"]);
d["font-style"]&
&
(i.fontStyle=d["font-style"]);
if(d.opacity!=null||d["stroke-width"]!=null||d.fill!=null||d.stroke!=null||d["stroke-width"]!=null||d["stroke-opacity"]!=null||d["fill-opacity"]!=null||d["stroke-dasharray"]!=null||d["stroke-miterlimit"]!=null||d["stroke-linejoin"]!=null||d["stroke-linecap"]!=null){
e=c.shape||e;
var v=e.getElementsByTagName(I)&
&
e.getElementsByTagName(I)[0],x=false;
!v&
&
(x=v=cd(I));
if("fill-opacity"in d||"opacity"in d){
var y=((+h["fill-opacity"]+1||2)-1)*((+h.opacity+1||2)-1)*((+a.getRGB(d.fill).o+1||2)-1);
y=A(z(y,0),1);
v.opacity=y}
d.fill&
&
(v.on=true);
if(v.on==null||d.fill=="none")v.on=false;
if(v.on&
&
d.fill){
var B=d.fill.match(M);
if(B){
v.src=B[1];
v.type="tile"}
else{
v.color=a.getRGB(d.fill).hex;
v.src=p;
v.type="solid";
if(a.getRGB(d.fill).error&
&
(m.type in{
circle:1,ellipse:1}
||r(d.fill).charAt()!="r")&
&
bI(m,d.fill)){
h.fill="none";
h.gradient=d.fill}
}
}
x&
&
e[l](v);
var C=e.getElementsByTagName("stroke")&
&
e.getElementsByTagName("stroke")[0],D=false;
!C&
&
(D=C=cd("stroke"));
if(d.stroke&
&
d.stroke!="none"||d["stroke-width"]||d["stroke-opacity"]!=null||d["stroke-dasharray"]||d["stroke-miterlimit"]||d["stroke-linejoin"]||d["stroke-linecap"])C.on=true;
(d.stroke=="none"||C.on==null||d.stroke==0||d["stroke-width"]==0)&
&
(C.on=false);
var E=a.getRGB(d.stroke);
C.on&
&
d.stroke&
&
(C.color=E.hex);
y=((+h["stroke-opacity"]+1||2)-1)*((+h.opacity+1||2)-1)*((+E.o+1||2)-1);
var F=(S(d["stroke-width"])||1)*0.75;
y=A(z(y,0),1);
d["stroke-width"]==null&
&
(F=h["stroke-width"]);
d["stroke-width"]&
&
(C.weight=F);
F&
&
F1&
&
(y*=F)&
&
(C.weight=1);
C.opacity=y;
d["stroke-linejoin"]&
&
(C.joinstyle=d["stroke-linejoin"]||"miter");
C.miterlimit=d["stroke-miterlimit"]||8;
d["stroke-linecap"]&
&
(C.endcap=d["stroke-linecap"]=="butt"?"flat":d["stroke-linecap"]=="square"?"square":"round");
if(d["stroke-dasharray"]){
var G={
"-":"shortdash",".":"shortdot","-.":"shortdashdot","-..":"shortdashdotdot",". ":"dot","- ":"dash","--":"longdash","- .":"dashdot","--.":"longdashdot","--..":"longdashdotdot"}
;
C.dashstyle=G[f](d["stroke-dasharray"])?G[d["stroke-dasharray"]]:p}
D&
&
e[l](C)}
if(m.type=="text"){
i=m.paper.span.style;
h.font&
&
(i.font=h.font);
h["font-family"]&
&
(i.fontFamily=h["font-family"]);
h["font-size"]&
&
(i.fontSize=h["font-size"]);
h["font-weight"]&
&
(i.fontWeight=h["font-weight"]);
h["font-style"]&
&
(i.fontStyle=h["font-style"]);
m.node.string&
&
(m.paper.span.innerHTML=r(m.node.string)[Y](//g,"")[Y](/&
/g,"&
")[Y](/\n/g,"br>
"));
m.W=h.w=m.paper.span.offsetWidth;
m.H=h.h=m.paper.span.offsetHeight;
m.X=h.x;
m.Y=h.y+Q(m.H/2);
switch(h["text-anchor"]){
case"start":m.node.style["v-text-align"]="left";
m.bbx=Q(m.W/2);
break;
case"end":m.node.style["v-text-align"]="right";
m.bbx=-Q(m.W/2);
break;
default:m.node.style["v-text-align"]="center";
break}
}
}
;
bI=function(a,b){
a.attrs=a.attrs||{
}
;
var c=a.attrs,d,e="linear",f=".5 .5";
a.attrs.gradient=b;
b=r(b)[Y](bd,function(a,b,c){
e="radial";
if(b&
&
c){
b=S(b);
c=S(c);
C(b-0.5,2)+C(c-0.5,2)>
0.25&
&
(c=y.sqrt(0.25-C(b-0.5,2))*((c>
0.5)*2-1)+0.5);
f=b+q+c}
return p}
);
b=b[s](/\s*\-\s*/);
if(e=="linear"){
var g=b.shift();
g=-S(g);
if(isNaN(g))return null}
var h=bx(b);
if(!h)return null;
a=a.shape||a.node;
d=a.getElementsByTagName(I)[0]||cd(I);
!d.parentNode&
&
a.appendChild(d);
if(h[w]){
d.on=true;
d.method="none";
d.color=h[0].color;
d.color2=h[h[w]-1].color;
var i=[];
for(var j=0,k=h[w];
jk;
j++)h[j].offset&
&
i[L](h[j].offset+q+h[j].color);
d.colors&
&
(d.colors.value=i[w]?i[v]():"0% "+d.color);
if(e=="radial"){
d.type="gradientradial";
d.focus="100%";
d.focussize=f;
d.focusposition=f}
else{
d.type="gradient";
d.angle=(270-g)%360}
}
return 1}
;
bN=function(b,c,d){
var e=0,f=0,g=0,h=1;
this[0]=b;
this.id=a._oid++;
this.node=b;
b.raphael=this;
this.X=0;
this.Y=0;
this.attrs={
}
;
this.Group=c;
this.paper=d;
this._={
tx:0,ty:0,rt:{
deg:0}
,sx:1,sy:1}
;
!d.bottom&
&
(d.bottom=this);
this.prev=d.top;
d.top&
&
(d.top.next=this);
d.top=this;
this.next=null}
;
bO=bN[e];
bO.rotate=function(a,c,d){
if(this.removed)return this;
if(a==null){
if(this._.rt.cx)return[this._.rt.deg,this._.rt.cx,this._.rt.cy][v](q);
return this._.rt.deg}
a=r(a)[s](b);
if(a[w]-1){
c=S(a[1]);
d=S(a[2])}
a=S(a[0]);
c!=null?this._.rt.deg=a:this._.rt.deg+=a;
d==null&
&
(c=null);
this._.rt.cx=c;
this._.rt.cy=d;
this.setBox(this.attrs,c,d);
this.Group.style.rotation=this._.rt.deg;
return this}
;
bO.setBox=function(a,b,c){
if(this.removed)return this;
var d=this.Group.style,e=this.shape&
&
this.shape.style||this.node.style;
a=a||{
}
;
for(var g in a)a[f](g)&
&
(this.attrs[g]=a[g]);
b=b||this._.rt.cx;
c=c||this._.rt.cy;
var h=this.attrs,i,j,k,l;
switch(this.type){
case"circle":i=h.cx-h.r;
j=h.cy-h.r;
k=l=h.r*2;
break;
case"ellipse":i=h.cx-h.rx;
j=h.cy-h.ry;
k=h.rx*2;
l=h.ry*2;
break;
case"image":i=+h.x;
j=+h.y;
k=h.width||0;
l=h.height||0;
break;
case"text":this.textpath.v=["m",Q(h.x),", ",Q(h.y-2),"l",Q(h.x)+1,", ",Q(h.y-2)][v](p);
i=h.x-Q(this.W/2);
j=h.y-this.H/2;
k=this.W;
l=this.H;
break;
case"rect":case"path":if(this.attrs.path){
var m=bn(this.attrs.path);
i=m.x;
j=m.y;
k=m.width;
l=m.height}
else{
i=0;
j=0;
k=this.paper.width;
l=this.paper.height}
break;
default:i=0;
j=0;
k=this.paper.width;
l=this.paper.height;
break}
b=b==null?i+k/2:b;
c=c==null?j+l/2:c;
var n=b-this.paper.width/2,o=c-this.paper.height/2,q;
d.left!=(q=n+"px")&
&
(d.left=q);
d.top!=(q=o+"px")&
&
(d.top=q);
this.X=ca[f](this.type)?-n:i;
this.Y=ca[f](this.type)?-o:j;
this.W=k;
this.H=l;
if(ca[f](this.type)){
e.left!=(q=-n*b_+"px")&
&
(e.left=q);
e.top!=(q=-o*b_+"px")&
&
(e.top=q)}
else if(this.type=="text"){
e.left!=(q=-n+"px")&
&
(e.left=q);
e.top!=(q=-o+"px")&
&
(e.top=q)}
else{
d.width!=(q=this.paper.width+"px")&
&
(d.width=q);
d.height!=(q=this.paper.height+"px")&
&
(d.height=q);
e.left!=(q=i-n+"px")&
&
(e.left=q);
e.top!=(q=j-o+"px")&
&
(e.top=q);
e.width!=(q=k+"px")&
&
(e.width=q);
e.height!=(q=l+"px")&
&
(e.height=q)}
}
;
bO.hide=function(){
!this.removed&
&
(this.Group.style.display="none");
return this}
;
bO.show=function(){
!this.removed&
&
(this.Group.style.display="block");
return this}
;
bO.getBBox=function(){
if(this.removed)return this;
if(ca[f](this.type))return bn(this.attrs.path);
return{
x:this.X+(this.bbx||0),y:this.Y,width:this.W,height:this.H}
}
;
bO.remove=function(){
if(this.removed)return;
bA(this,this.paper);
this.node.parentNode.removeChild(this.node);
this.Group.parentNode.removeChild(this.Group);
this.shape&
&
this.shape.parentNode.removeChild(this.shape);
for(var a in this)delete this[a];
this.removed=true}
;
bO.attr=function(b,c){
if(this.removed)return this;
if(b==null){
var d={
}
;
for(var e in this.attrs)this.attrs[f](e)&
&
(d[e]=this.attrs[e]);
this._.rt.deg&
&
(d.rotation=this.rotate());
(this._.sx!=1||this._.sy!=1)&
&
(d.scale=this.scale());
d.gradient&
&
d.fill=="none"&
&
(d.fill=d.gradient)&
&
delete d.gradient;
return d}
if(c==null&
&
a.is(b,"string")){
if(b=="translation")return cz.call(this);
if(b=="rotation")return this.rotate();
if(b=="scale")return this.scale();
if(b==I&
&
this.attrs.fill=="none"&
&
this.attrs.gradient)return this.attrs.gradient;
return this.attrs[b]}
if(this.attrs&
&
c==null&
&
a.is(b,G)){
var g,h={
}
;
for(e=0,g=b[w];
eg;
e++)h[b[e]]=this.attr(b[e]);
return h}
var i;
if(c!=null){
i={
}
;
i[b]=c}
c==null&
&
a.is(b,"object")&
&
(i=b);
if(i){
for(var j in this.paper.customAttributes)if(this.paper.customAttributes[f](j)&
&
i[f](j)&
&
a.is(this.paper.customAttributes[j],"function")){
var k=this.paper.customAttributes[j].apply(this,[][n](i[j]));
this.attrs[j]=i[j];
for(var l in k)k[f](l)&
&
(i[l]=k[l])}
i.text&
&
this.type=="text"&
&
(this.node.string=i.text);
bK(this,i);
i.gradient&
&
(({
circle:1,ellipse:1}
)[f](this.type)||r(i.gradient).charAt()!="r")&
&
bI(this,i.gradient);
(!ca[f](this.type)||this._.rt.deg)&
&
this.setBox(this.attrs)}
return this}
;
bO.toFront=function(){
!this.removed&
&
this.Group.parentNode[l](this.Group);
this.paper.top!=this&
&
bB(this,this.paper);
return this}
;
bO.toBack=function(){
if(this.removed)return this;
if(this.Group.parentNode.firstChild!=this.Group){
this.Group.parentNode.insertBefore(this.Group,this.Group.parentNode.firstChild);
bC(this,this.paper)}
return this}
;
bO.insertAfter=function(a){
if(this.removed)return this;
a.constructor==cC&
&
(a=a[a.length-1]);
a.Group.nextSibling?a.Group.parentNode.insertBefore(this.Group,a.Group.nextSibling):a.Group.parentNode[l](this.Group);
bD(this,a,this.paper);
return this}
;
bO.insertBefore=function(a){
if(this.removed)return this;
a.constructor==cC&
&
(a=a[0]);
a.Group.parentNode.insertBefore(this.Group,a.Group);
bE(this,a,this.paper);
return this}
;
bO.blur=function(b){
var c=this.node.runtimeStyle,d=c.filter;
d=d.replace(bY,p);
if(+b!==0){
this.attrs.blur=b;
c.filter=d+q+U+".Blur(pixelradius="+(+b||1.5)+")";
c.margin=a.format("-{
0}
px 0 0 -{
0}
px",Q(+b||1.5))}
else{
c.filter=d;
c.margin=0;
delete this.attrs.blur}
}
;
bP=function(a,b,c,d){
var e=cd("group"),f=cd("oval"),g=f.style;
e.style.cssText="position:absolute;
left:0;
top:0;
width:"+a.width+"px;
height:"+a.height+"px";
e.coordsize=b$;
e.coordorigin=a.coordorigin;
e[l](f);
var h=new bN(f,e,a);
h.type="circle";
bK(h,{
stroke:"#000",fill:"none"}
);
h.attrs.cx=b;
h.attrs.cy=c;
h.attrs.r=d;
h.setBox({
x:b-d,y:c-d,width:d*2,height:d*2}
);
a.canvas[l](e);
return h}
;
function cc(b,c,d,e,f){
return f?a.format("M{
0}
,{
1}
l{
2}
,0a{
3}
,{
3}
,0,0,1,{
3}
,{
3}
l0,{
5}
a{
3}
,{
3}
,0,0,1,{
4}
,{
3}
l{
6}
,0a{
3}
,{
3}
,0,0,1,{
4}
,{
4}
l0,{
7}
a{
3}
,{
3}
,0,0,1,{
3}
,{
4}
z",b+f,c,d-f*2,f,-f,e-f*2,f*2-d,f*2-e):a.format("M{
0}
,{
1}
l{
2}
,0,0,{
3}
,{
4}
,0z",b,c,d,e,-d)}
bQ=function(a,b,c,d,e,f){
var g=cc(b,c,d,e,f),h=a.path(g),i=h.attrs;
h.X=i.x=b;
h.Y=i.y=c;
h.W=i.width=d;
h.H=i.height=e;
i.r=f;
i.path=g;
h.type="rect";
return h}
;
bR=function(a,b,c,d,e){
var f=cd("group"),g=cd("oval"),h=g.style;
f.style.cssText="position:absolute;
left:0;
top:0;
width:"+a.width+"px;
height:"+a.height+"px";
f.coordsize=b$;
f.coordorigin=a.coordorigin;
f[l](g);
var i=new bN(g,f,a);
i.type="ellipse";
bK(i,{
stroke:"#000"}
);
i.attrs.cx=b;
i.attrs.cy=c;
i.attrs.rx=d;
i.attrs.ry=e;
i.setBox({
x:b-d,y:c-e,width:d*2,height:e*2}
);
a.canvas[l](f);
return i}
;
bS=function(a,b,c,d,e,f){
var g=cd("group"),h=cd("image");
g.style.cssText="position:absolute;
left:0;
top:0;
width:"+a.width+"px;
height:"+a.height+"px";
g.coordsize=b$;
g.coordorigin=a.coordorigin;
h.src=b;
g[l](h);
var i=new bN(h,g,a);
i.type="image";
i.attrs.src=b;
i.attrs.x=c;
i.attrs.y=d;
i.attrs.w=e;
i.attrs.h=f;
i.setBox({
x:c,y:d,width:e,height:f}
);
a.canvas[l](g);
return i}
;
bT=function(b,c,d,e){
var f=cd("group"),g=cd("shape"),h=g.style,i=cd("path"),j=i.style,k=cd("textpath");
f.style.cssText="position:absolute;
left:0;
top:0;
width:"+b.width+"px;
height:"+b.height+"px";
f.coordsize=b$;
f.coordorigin=b.coordorigin;
i.v=a.format("m{
0}
,{
1}
l{
2}
,{
1}
",Q(c*10),Q(d*10),Q(c*10)+1);
i.textpathok=true;
h.width=b.width;
h.height=b.height;
k.string=r(e);
k.on=true;
g[l](k);
g[l](i);
f[l](g);
var m=new bN(k,f,b);
m.shape=g;
m.textpath=i;
m.type="text";
m.attrs.text=e;
m.attrs.x=c;
m.attrs.y=d;
m.attrs.w=1;
m.attrs.h=1;
bK(m,{
font:W.font,stroke:"none",fill:"#000"}
);
m.setBox();
b.canvas[l](f);
return m}
;
bU=function(a,b){
var c=this.canvas.style;
a==+a&
&
(a+="px");
b==+b&
&
(b+="px");
c.width=a;
c.height=b;
c.clip="rect(0 "+a+" "+b+" 0)";
return this}
;
var cd;
g.createStyleSheet().addRule(".rvml","behavior:url(#default#VML)");
try{
!g.namespaces.rvml&
&
g.namespaces.add("rvml","urn:schemas-microsoft-com:vml");
cd=function(a){
return g.createElement("rvml:"+a+" class=\"rvml\">
")}
}
catch(a){
cd=function(a){
return g.createElement(""+a+" xmlns=\"urn:schemas-microsoft.com:vml\" class=\"rvml\">
")}
}
bV=function(){
var b=by[m](0,arguments),c=b.container,d=b.height,e,f=b.width,h=b.x,i=b.y;
if(!c)throw new Error("VML container not found.");
var k=new j,n=k.canvas=g.createElement("p"),o=n.style;
h=h||0;
i=i||0;
f=f||512;
d=d||342;
f==+f&
&
(f+="px");
d==+d&
&
(d+="px");
k.width=1000;
k.height=1000;
k.coordsize=b_*1000+q+b_*1000;
k.coordorigin="0 0";
k.span=g.createElement("span");
k.span.style.cssText="position:absolute;
left:-9999em;
top:-9999em;
padding:0;
margin:0;
line-height:1;
display:inline;
";
n[l](k.span);
o.cssText=a.format("top:0;
left:0;
width:{
0}
;
height:{
1}
;
display:inline-block;
position:relative;
clip:rect(0 {
0}
{
1}
0);
overflow:hidden",f,d);
if(c==1){
g.body[l](n);
o.left=h+"px";
o.top=i+"px";
o.position="absolute"}
else c.firstChild?c.insertBefore(n,c.firstChild):c[l](n);
bz.call(k,k,a.fn);
return k}
;
k.clear=function(){
this.canvas.innerHTML=p;
this.span=g.createElement("span");
this.span.style.cssText="position:absolute;
left:-9999em;
top:-9999em;
padding:0;
margin:0;
line-height:1;
display:inline;
";
this.canvas[l](this.span);
this.bottom=this.top=null}
;
k.remove=function(){
this.canvas.parentNode.removeChild(this.canvas);
for(var a in this)this[a]=bF(a);
return true}
}
var ce=navigator.userAgent.match(/Version\\x2f(.*?)\s/);
navigator.vendor=="Apple Computer, Inc."&
&
(ce&
&
ce[1]4||navigator.platform.slice(0,2)=="iP")?k.safari=function(){
var a=this.rect(-99,-99,this.width+99,this.height+99).attr({
stroke:"none"}
);
h.setTimeout(function(){
a.remove()}
)}
:k.safari=function(){
}
;
var CF=function(){
this.returnValue=false}
,cg=function(){
return this.originalEvent.preventDefault()}
,ch=function(){
this.cancelBubble=true}
,ci=function(){
return this.originalEvent.stopPropagation()}
,cj=(function(){
{
if(g.addEventListener)return function(a,b,c,d){
var e=o&
&
u[b]?u[b]:b,g=function(e){
if(o&
&
u[f](b))for(var g=0,h=e.targetTouches&
&
e.targetTouches.length;
gh;
g++){
if(e.targetTouches[g].target==a){
var i=e;
e=e.targetTouches[g];
e.originalEvent=i;
e.preventDefault=cg;
e.stopPropagation=ci;
break}
}
return c.call(d,e)}
;
a.addEventListener(e,g,false);
return function(){
a.removeEventListener(e,g,false);
return true}
}
;
if(g.attachEvent)return function(a,b,c,d){
var e=function(a){
a=a||h.event;
a.preventDefault=a.preventDefault||cf;
a.stopPropagation=a.stopPropagation||ch;
return c.call(d,a)}
;
a.attachEvent("on"+b,e);
var f=function(){
a.detachEvent("on"+b,e);
return true}
;
return f}
}
}
)(),ck=[],cl=function(a){
var b=a.clientX,c=a.clientY,d=g.documentElement.scrollTop||g.body.scrollTop,e=g.documentElement.scrollLeft||g.body.scrollLeft,f,h=ck.length;
while(h--){
f=ck[h];
if(o){
var i=a.touches.length,j;
while(i--){
j=a.touches[i];
if(j.identifier==f.el._drag.id){
b=j.clientX;
c=j.clientY;
(a.originalEvent?a.originalEvent:a).preventDefault();
break}
}
}
else a.preventDefault();
b+=e;
c+=d;
f.move&
&
f.move.call(f.move_scope||f.el,b-f.el._drag.x,c-f.el._drag.y,b,c,a)}
}
,cm=function(b){
a.unmousemove(cl).unmouseup(cm);
var c=ck.length,d;
while(c--){
d=ck[c];
d.el._drag={
}
;
d.end&
&
d.end.call(d.end_scope||d.start_scope||d.move_scope||d.el,b)}
ck=[]}
;
for(var cn=t[w];
cn--;
)(function(b){
a[b]=bN[e][b]=function(c,d){
if(a.is(c,"function")){
this.events=this.events||[];
this.events.push({
name:b,f:c,unbind:cj(this.shape||this.node||g,b,c,d||this)}
)}
return this}
;
a["un"+b]=bN[e]["un"+b]=function(a){
var c=this.events,d=c[w];
while(d--)if(c[d].name==b&
&
c[d].f==a){
c[d].unbind();
c.splice(d,1);
!c.length&
&
delete this.events;
return this}
return this}
}
)(t[cn]);
bO.hover=function(a,b,c,d){
return this.mouseover(a,c).mouseout(b,d||c)}
;
bO.unhover=function(a,b){
return this.unmouseover(a).unmouseout(b)}
;
bO.drag=function(b,c,d,e,f,h){
this._drag={
}
;
this.mousedown(function(i){
(i.originalEvent||i).preventDefault();
var j=g.documentElement.scrollTop||g.body.scrollTop,k=g.documentElement.scrollLeft||g.body.scrollLeft;
this._drag.x=i.clientX+k;
this._drag.y=i.clientY+j;
this._drag.id=i.identifier;
c&
&
c.call(f||e||this,i.clientX+k,i.clientY+j,i);
!ck.length&
&
a.mousemove(cl).mouseup(cm);
ck.push({
el:this,move:b,end:d,move_scope:e,start_scope:f,end_scope:h}
)}
);
return this}
;
bO.undrag=function(b,c,d){
var e=ck.length;
while(e--)ck[e].el==this&
&
(ck[e].move==b&
&
ck[e].end==d)&
&
ck.splice(e++,1);
!ck.length&
&
a.unmousemove(cl).unmouseup(cm)}
;
k.circle=function(a,b,c){
return bP(this,a||0,b||0,c||0)}
;
k.rect=function(a,b,c,d,e){
return bQ(this,a||0,b||0,c||0,d||0,e||0)}
;
k.ellipse=function(a,b,c,d){
return bR(this,a||0,b||0,c||0,d||0)}
;
k.path=function(b){
b&
&
!a.is(b,F)&
&
!a.is(b[0],G)&
&
(b+=p);
return bH(a.format[m](a,arguments),this)}
;
k.image=function(a,b,c,d,e){
return bS(this,a||"about:blank",b||0,c||0,d||0,e||0)}
;
k.text=function(a,b,c){
return bT(this,a||0,b||0,r(c))}
;
k.set=function(a){
arguments[w]>
1&
&
(a=Array[e].splice.call(arguments,0,arguments[w]));
return new cC(a)}
;
k.setSize=bU;
k.top=k.bottom=null;
k.raphael=a;
function co(){
return this.x+q+this.y}
bO.resetScale=function(){
if(this.removed)return this;
this._.sx=1;
this._.sy=1;
this.attrs.scale="1 1"}
;
bO.scale=function(a,b,c,d){
if(this.removed)return this;
if(a==null&
&
b==null)return{
x:this._.sx,y:this._.sy,toString:co}
;
b=b||a;
!(+b)&
&
(b=a);
var e,f,g,h,i=this.attrs;
if(a!=0){
var j=this.getBBox(),k=j.x+j.width/2,l=j.y+j.height/2,m=B(a/this._.sx),o=B(b/this._.sy);
c=+c||c==0?c:k;
d=+d||d==0?d:l;
var r=this._.sx>
0,s=this._.sy>
0,t=~(~(a/B(a))),u=~(~(b/B(b))),x=m*t,y=o*u,z=this.node.style,A=c+B(k-c)*x*(k>
c==r?1:-1),C=d+B(l-d)*y*(l>
d==s?1:-1),D=a*t>
b*u?o:m;
switch(this.type){
case"rect":case"image":var E=i.width*m,F=i.height*o;
this.attr({
height:F,r:i.r*D,width:E,x:A-E/2,y:C-F/2}
);
break;
case"circle":case"ellipse":this.attr({
rx:i.rx*m,ry:i.ry*o,r:i.r*D,cx:A,cy:C}
);
break;
case"text":this.attr({
x:A,y:C}
);
break;
case"path":var G=bp(i.path),H=true,I=r?x:m,J=s?y:o;
for(var K=0,L=G[w];
KL;
K++){
var M=G[K],N=V.call(M[0]);
{
if(N=="M"&
&
H)continue;
H=false}
if(N=="A"){
M[G[K][w]-2]*=I;
M[G[K][w]-1]*=J;
M[1]*=m;
M[2]*=o;
M[5]=+(t+u?!(!(+M[5])):!(+M[5]))}
else if(N=="H")for(var O=1,P=M[w];
OP;
O++)M[O]*=I;
else if(N=="V")for(O=1,P=M[w];
OP;
O++)M[O]*=J;
else for(O=1,P=M[w];
OP;
O++)M[O]*=O%2?I:J}
var Q=bn(G);
e=A-Q.x-Q.width/2;
f=C-Q.y-Q.height/2;
G[0][1]+=e;
G[0][2]+=f;
this.attr({
path:G}
);
break}
if(this.type in{
text:1,image:1}
&
&
(t!=1||u!=1))if(this.transformations){
this.transformations[2]="scale("[n](t,",",u,")");
this.node[R]("transform",this.transformations[v](q));
e=t==-1?-i.x-(E||0):i.x;
f=u==-1?-i.y-(F||0):i.y;
this.attr({
x:e,y:f}
);
i.fx=t-1;
i.fy=u-1}
else{
this.node.filterMatrix=U+".Matrix(M11="[n](t,", M12=0, M21=0, M22=",u,", Dx=0, Dy=0, sizingmethod='auto expand', filtertype='bilinear')");
z.filter=(this.node.filterMatrix||p)+(this.node.filterOpacity||p)}
else if(this.transformations){
this.transformations[2]=p;
this.node[R]("transform",this.transformations[v](q));
i.fx=0;
i.fy=0}
else{
this.node.filterMatrix=p;
z.filter=(this.node.filterMatrix||p)+(this.node.filterOpacity||p)}
i.scale=[a,b,c,d][v](q);
this._.sx=a;
this._.sy=b}
return this}
;
bO.clone=function(){
if(this.removed)return null;
var a=this.attr();
delete a.scale;
delete a.translation;
return this.paper[this.type]().attr(a)}
;
var cp={
}
,cq=function(b,c,d,e,f,g,h,i,j){
var k=0,l=100,m=[b,c,d,e,f,g,h,i].join(),n=cp[m],o,p;
!n&
&
(cp[m]=n={
data:[]}
);
n.timer&
&
clearTimeout(n.timer);
n.timer=setTimeout(function(){
delete cp[m]}
,2000);
if(j!=null){
var q=cq(b,c,d,e,f,g,h,i);
l=~(~q)*10}
for(var r=0;
rl+1;
r++){
if(n.data[j]>
r)p=n.data[r*l];
else{
p=a.findDotsAtSegment(b,c,d,e,f,g,h,i,r/l);
n.data[r]=p}
r&
&
(k+=C(C(o.x-p.x,2)+C(o.y-p.y,2),0.5));
if(j!=null&
&
k>
=j)return p;
o=p}
if(j==null)return k}
,cr=function(b,c){
return function(d,e,f){
d=bw(d);
var g,h,i,j,k="",l={
}
,m,n=0;
for(var o=0,p=d.length;
op;
o++){
i=d[o];
if(i[0]=="M"){
g=+i[1];
h=+i[2]}
else{
j=cq(g,h,i[1],i[2],i[3],i[4],i[5],i[6]);
if(n+j>
e){
if(c&
&
!l.start){
m=cq(g,h,i[1],i[2],i[3],i[4],i[5],i[6],e-n);
k+=["C",m.start.x,m.start.y,m.m.x,m.m.y,m.x,m.y];
if(f)return k;
l.start=k;
k=["M",m.x,m.y+"C",m.n.x,m.n.y,m.end.x,m.end.y,i[5],i[6]][v]();
n+=j;
g=+i[5];
h=+i[6];
continue}
if(!b&
&
!c){
m=cq(g,h,i[1],i[2],i[3],i[4],i[5],i[6],e-n);
return{
x:m.x,y:m.y,alpha:m.alpha}
}
}
n+=j;
g=+i[5];
h=+i[6]}
k+=i}
l.end=k;
m=b?n:c?l:a.findDotsAtSegment(g,h,i[1],i[2],i[3],i[4],i[5],i[6],1);
m.alpha&
&
(m={
x:m.x,y:m.y,alpha:m.alpha}
);
return m}
}
,cs=cr(1),ct=cr(),cu=cr(0,1);
bO.getTotalLength=function(){
if(this.type!="path")return;
if(this.node.getTotalLength)return this.node.getTotalLength();
return cs(this.attrs.path)}
;
bO.getPointAtLength=function(a){
if(this.type!="path")return;
return ct(this.attrs.path,a)}
;
bO.getSubpath=function(a,b){
if(this.type!="path")return;
if(B(this.getTotalLength()-b)"1e-6")return cu(this.attrs.path,a).end;
var c=cu(this.attrs.path,b,1);
return a?cu(c,a).end:c}
;
a.easing_formulas={
linear:function(a){
return a}
,"":function(a){
return C(a,3)}
,">
":function(a){
return C(a-1,3)+1}
,">
":function(a){
a=a*2;
if(a1)return C(a,3)/2;
a-=2;
return(C(a,3)+2)/2}
,backIn:function(a){
var b=1.70158;
return a*a*((b+1)*a-b)}
,backOut:function(a){
a=a-1;
var b=1.70158;
return a*a*((b+1)*a+b)+1}
,elastic:function(a){
if(a==0||a==1)return a;
var b=0.3,c=b/4;
return C(2,-10*a)*y.sin((a-c)*(2*D)/b)+1}
,bounce:function(a){
var b=7.5625,c=2.75,d;
if(a1/c)d=b*a*a;
else if(a2/c){
a-=1.5/c;
d=b*a*a+0.75}
else if(a2.5/c){
a-=2.25/c;
d=b*a*a+0.9375}
else{
a-=2.625/c;
d=b*a*a+0.984375}
return d}
}
;
var cv=[],cw=function(){
var b=+(new Date);
for(var c=0;
ccv[w];
c++){
var d=cv[c];
if(d.stop||d.el.removed)continue;
var e=b-d.start,g=d.ms,h=d.easing,i=d.from,j=d.diff,k=d.to,l=d.t,m=d.el,n={
}
,o;
if(eg){
var r=h(e/g);
for(var s in i)if(i[f](s)){
switch(X[s]){
case"along":o=r*g*j[s];
k.back&
&
(o=k.len-o);
var t=ct(k[s],o);
m.translate(j.sx-j.x||0,j.sy-j.y||0);
j.x=t.x;
j.y=t.y;
m.translate(t.x-j.sx,t.y-j.sy);
k.rot&
&
m.rotate(j.r+t.alpha,t.x,t.y);
break;
case E:o=+i[s]+r*g*j[s];
break;
case"colour":o="rgb("+[cy(Q(i[s].r+r*g*j[s].r)),cy(Q(i[s].g+r*g*j[s].g)),cy(Q(i[s].b+r*g*j[s].b))][v](",")+")";
break;
case"path":o=[];
for(var u=0,x=i[s][w];
ux;
u++){
o[u]=[i[s][u][0]];
for(var y=1,z=i[s][u][w];
yz;
y++)o[u][y]=+i[s][u][y]+r*g*j[s][u][y];
o[u]=o[u][v](q)}
o=o[v](q);
break;
case"csv":switch(s){
case"translation":var A=r*g*j[s][0]-l.x,B=r*g*j[s][1]-l.y;
l.x+=A;
l.y+=B;
o=A+q+B;
break;
case"rotation":o=+i[s][0]+r*g*j[s][0];
i[s][1]&
&
(o+=","+i[s][1]+","+i[s][2]);
break;
case"scale":o=[+i[s][0]+r*g*j[s][0],+i[s][1]+r*g*j[s][1],2 in k[s]?k[s][2]:p,3 in k[s]?k[s][3]:p][v](q);
break;
case"clip-rect":o=[];
u=4;
while(u--)o[u]=+i[s][u]+r*g*j[s][u];
break}
break;
default:var C=[].concat(i[s]);
o=[];
u=m.paper.customAttributes[s].length;
while(u--)o[u]=+C[u]+r*g*j[s][u];
break}
n[s]=o}
m.attr(n);
m._run&
&
m._run.call(m)}
else{
if(k.along){
t=ct(k.along,k.len*!k.back);
m.translate(j.sx-(j.x||0)+t.x-j.sx,j.sy-(j.y||0)+t.y-j.sy);
k.rot&
&
m.rotate(j.r+t.alpha,t.x,t.y)}
(l.x||l.y)&
&
m.translate(-l.x,-l.y);
k.scale&
&
(k.scale+=p);
m.attr(k);
cv.splice(c--,1)}
}
a.svg&
&
m&
&
m.paper&
&
m.paper.safari();
cv[w]&
&
setTimeout(cw)}
,cx=function(b,c,d,e,f){
var g=d-e;
c.timeouts.push(setTimeout(function(){
a.is(f,"function")&
&
f.call(c);
c.aniMATE(b,g,b.easing)}
,e))}
,cy=function(a){
return z(A(a,255),0)}
,cz=function(a,b){
if(a==null)return{
x:this._.tx,y:this._.ty,toString:co}
;
this._.tx+=+a;
this._.ty+=+b;
switch(this.type){
case"circle":case"ellipse":this.attr({
cx:+a+this.attrs.cx,cy:+b+this.attrs.cy}
);
break;
case"rect":case"image":case"text":this.attr({
x:+a+this.attrs.x,y:+b+this.attrs.y}
);
break;
case"path":var c=bp(this.attrs.path);
c[0][1]+=+a;
c[0][2]+=+b;
this.attr({
path:c}
);
break}
return this}
;
bO.animateWith=function(a,b,c,d,e){
for(var f=0,g=cv.length;
fg;
f++)cv[f].el.id==a.id&
&
(b.start=cv[f].start);
return this.animate(b,c,d,e)}
;
bO.animateAlong=cA();
bO.animateAlongBack=cA(1);
function cA(b){
return function(c,d,e,f){
var g={
back:b}
;
a.is(e,"function")?f=e:g.rot=e;
c&
&
c.constructor==bN&
&
(c=c.attrs.path);
c&
&
(g.along=c);
return this.animate(g,d,f)}
}
function cB(a,b,c,d,e,f){
var g=3*b,h=3*(d-b)-g,i=1-g-h,j=3*c,k=3*(e-c)-j,l=1-j-k;
function m(a){
return((i*a+h)*a+g)*a}
function n(a,b){
var c=o(a,b);
return((l*c+k)*c+j)*c}
function o(a,b){
var c,d,e,f,j,k;
for(e=a,k=0;
k8;
k++){
f=m(e)-a;
if(B(f)b)return e;
j=(3*i*e+2*h)*e+g;
if(B(j)0.000001)break;
e=e-f/j}
c=0;
d=1;
e=a;
if(ec)return c;
if(e>
d)return d;
while(cd){
f=m(e);
if(B(f-a)b)return e;
a>
f?c=e:d=e;
e=(d-c)/2+c}
return e}
return n(a,1/(200*f))}
bO.onAnimation=function(a){
this._run=a||0;
return this}
;
bO.animate=function(c,d,e,g){
var h=this;
h.timeouts=h.timeouts||[];
if(a.is(e,"function")||!e)g=e||null;
if(h.removed){
g&
&
g.call(h);
return h}
var i={
}
,j={
}
,k=false,l={
}
;
for(var m in c)if(c[f](m)){
if(X[f](m)||h.paper.customAttributes[f](m)){
k=true;
i[m]=h.attr(m);
i[m]==null&
&
(i[m]=W[m]);
j[m]=c[m];
switch(X[m]){
case"along":var n=cs(c[m]),o=ct(c[m],n*!(!c.back)),p=h.getBBox();
l[m]=n/d;
l.tx=p.x;
l.ty=p.y;
l.sx=o.x;
l.sy=o.y;
j.rot=c.rot;
j.back=c.back;
j.len=n;
c.rot&
&
(l.r=S(h.rotate())||0);
break;
case E:l[m]=(j[m]-i[m])/d;
break;
case"colour":i[m]=a.getRGB(i[m]);
var q=a.getRGB(j[m]);
l[m]={
r:(q.r-i[m].r)/d,g:(q.g-i[m].g)/d,b:(q.b-i[m].b)/d}
;
break;
case"path":var t=bw(i[m],j[m]);
i[m]=t[0];
var u=t[1];
l[m]=[];
for(var v=0,x=i[m][w];
vx;
v++){
l[m][v]=[0];
for(var y=1,z=i[m][v][w];
yz;
y++)l[m][v][y]=(u[v][y]-i[m][v][y])/d}
break;
case"csv":var A=r(c[m])[s](b),B=r(i[m])[s](b);
switch(m){
case"translation":i[m]=[0,0];
l[m]=[A[0]/d,A[1]/d];
break;
case"rotation":i[m]=B[1]==A[1]&
&
B[2]==A[2]?B:[0,A[1],A[2]];
l[m]=[(A[0]-i[m][0])/d,0,0];
break;
case"scale":c[m]=A;
i[m]=r(i[m])[s](b);
l[m]=[(A[0]-i[m][0])/d,(A[1]-i[m][1])/d,0,0];
break;
case"clip-rect":i[m]=r(i[m])[s](b);
l[m]=[];
v=4;
while(v--)l[m][v]=(A[v]-i[m][v])/d;
break}
j[m]=A;
break;
default:A=[].concat(c[m]);
B=[].concat(i[m]);
l[m]=[];
v=h.paper.customAttributes[m][w];
while(v--)l[m][v]=((A[v]||0)-(B[v]||0))/d;
break}
}
}
if(k){
var G=a.easing_formulas[e];
if(!G){
G=r(e).match(P);
if(G&
&
G[w]==5){
var H=G;
G=function(a){
return cB(a,+H[1],+H[2],+H[3],+H[4],d)}
}
else G=function(a){
return a}
}
cv.push({
start:c.start||+(new Date),ms:d,easing:G,from:i,diff:l,to:j,el:h,t:{
x:0,y:0}
}
);
a.is(g,"function")&
&
(h._ac=setTimeout(function(){
g.call(h)}
,d));
cv[w]==1&
&
setTimeout(cw)}
else{
var C=[],D;
for(var F in c)if(c[f](F)&
&
Z.test(F)){
m={
value:c[F]}
;
F=="from"&
&
(F=0);
F=="to"&
&
(F=100);
m.key=T(F,10);
C.push(m)}
C.sort(be);
C[0].key&
&
C.unshift({
key:0,value:h.attrs}
);
for(v=0,x=C[w];
vx;
v++)cx(C[v].value,h,d/100*C[v].key,d/100*(C[v-1]&
&
C[v-1].key||0),C[v-1]&
&
C[v-1].value.callback);
D=C[C[w]-1].value.callback;
D&
&
h.timeouts.push(setTimeout(function(){
D.call(h)}
,d))}
return this}
;
bO.stop=function(){
for(var a=0;
acv.length;
a++)cv[a].el.id==this.id&
&
cv.splice(a--,1);
for(a=0,ii=this.timeouts&
&
this.timeouts.length;
aii;
a++)clearTimeout(this.timeouts[a]);
this.timeouts=[];
clearTimeout(this._ac);
delete this._ac;
return this}
;
bO.translate=function(a,b){
return this.attr({
translation:a+" "+b}
)}
;
bO[H]=function(){
return"Raphaël’s object"}
;
a.ae=cv;
var cC=function(a){
this.items=[];
this[w]=0;
this.type="set";
if(a)for(var b=0,c=a[w];
bc;
b++){
if(a[b]&
&
(a[b].constructor==bN||a[b].constructor==cC)){
this[this.items[w]]=this.items[this.items[w]]=a[b];
this[w]++}
}
}
;
cC[e][L]=function(){
var a,b;
for(var c=0,d=arguments[w];
cd;
c++){
a=arguments[c];
if(a&
&
(a.constructor==bN||a.constructor==cC)){
b=this.items[w];
this[b]=this.items[b]=a;
this[w]++}
}
return this}
;
cC[e].pop=function(){
delete this[this[w]--];
return this.items.pop()}
;
for(var cD in bO)bO[f](cD)&
&
(cC[e][cD]=(function(a){
return function(){
for(var b=0,c=this.items[w];
bc;
b++)this.items[b][a][m](this.items[b],arguments);
return this}
}
)(cD));
cC[e].attr=function(b,c){
if(b&
&
a.is(b,G)&
&
a.is(b[0],"object"))for(var d=0,e=b[w];
de;
d++)this.items[d].attr(b[d]);
else for(var f=0,g=this.items[w];
fg;
f++)this.items[f].attr(b,c);
return this}
;
cC[e].animate=function(b,c,d,e){
(a.is(d,"function")||!d)&
&
(e=d||null);
var f=this.items[w],g=f,h,i=this,j;
e&
&
(j=function(){
!(--f)&
&
e.call(i)}
);
d=a.is(d,F)?d:j;
h=this.items[--g].animate(b,c,d,j);
while(g--)this.items[g]&
&
!this.items[g].removed&
&
this.items[g].animateWith(h,b,c,d,j);
return this}
;
cC[e].insertAfter=function(a){
var b=this.items[w];
while(b--)this.items[b].insertAfter(a);
return this}
;
cC[e].getBBox=function(){
var a=[],b=[],c=[],d=[];
for(var e=this.items[w];
e--;
){
var f=this.items[e].getBBox();
a[L](f.x);
b[L](f.y);
c[L](f.x+f.width);
d[L](f.y+f.height)}
a=A[m](0,a);
b=A[m](0,b);
return{
x:a,y:b,width:z[m](0,c)-a,height:z[m](0,d)-b}
}
;
cC[e].clone=function(a){
a=new cC;
for(var b=0,c=this.items[w];
bc;
b++)a[L](this.items[b].clone());
return a}
;
a.registerFont=function(a){
if(!a.face)return a;
this.fonts=this.fonts||{
}
;
var b={
w:a.w,face:{
}
,glyphs:{
}
}
,c=a.face["font-family"];
for(var d in a.face)a.face[f](d)&
&
(b.face[d]=a.face[d]);
this.fonts[c]?this.fonts[c][L](b):this.fonts[c]=[b];
if(!a.svg){
b.face["units-per-em"]=T(a.face["units-per-em"],10);
for(var e in a.glyphs)if(a.glyphs[f](e)){
var g=a.glyphs[e];
b.glyphs[e]={
w:g.w,k:{
}
,d:g.d&
&
"M"+g.d[Y](/[mlcxtrv]/g,function(a){
return({
l:"L",c:"C",x:"z",t:"m",r:"l",v:"c"}
)[a]||"M"}
)+"z"}
;
if(g.k)for(var h in g.k)g[f](h)&
&
(b.glyphs[e].k[h]=g.k[h])}
}
return a}
;
k.getFont=function(b,c,d,e){
e=e||"normal";
d=d||"normal";
c=+c||({
normal:400,bold:700,lighter:300,bolder:800}
)[c]||400;
if(!a.fonts)return;
var g=a.fonts[b];
if(!g){
var h=new RegExp("(^|\\s)"+b[Y](/[^\w\d\s+!~.:_-]/g,p)+"(\\s|$)","i");
for(var i in a.fonts)if(a.fonts[f](i)){
if(h.test(i)){
g=a.fonts[i];
break}
}
}
var j;
if(g)for(var k=0,l=g[w];
kl;
k++){
j=g[k];
if(j.face["font-weight"]==c&
&
(j.face["font-style"]==d||!j.face["font-style"])&
&
j.face["font-stretch"]==e)break}
return j}
;
k.print=function(c,d,e,f,g,h,i){
h=h||"middle";
i=z(A(i||0,1),-1);
var j=this.set(),k=r(e)[s](p),l=0,m=p,n;
a.is(f,e)&
&
(f=this.getFont(f));
if(f){
n=(g||16)/f.face["units-per-em"];
var o=f.face.bbox.split(b),q=+o[0],t=+o[1]+(h=="baseline"?o[3]-o[1]+ +f.face.descent:(o[3]-o[1])/2);
for(var u=0,v=k[w];
uv;
u++){
var x=u&
&
f.glyphs[k[u-1]]||{
}
,y=f.glyphs[k[u]];
l+=u?(x.w||f.w)+(x.k&
&
x.k[k[u]]||0)+f.w*i:0;
y&
&
y.d&
&
j[L](this.path(y.d).attr({
fill:"#000",stroke:"none",translation:[l,0]}
))}
j.scale(n,n,q,t).translate(c-q,d-t)}
return j}
;
a.format=function(b,c){
var e=a.is(c,G)?[0][n](c):arguments;
b&
&
a.is(b,F)&
&
e[w]-1&
&
(b=b[Y](d,function(a,b){
return e[++b]==null?p:e[b]}
));
return b||p}
;
a.ninja=function(){
i.was?h.Raphael=i.is:delete Raphael;
return a}
;
a.el=bO;
a.st=cC[e];
i.was?h.Raphael=a:Raphael=a}
)();
exports = Raphael;
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\lib\sound.js */ define("scripts/lib/sound.js", function(exports){
/** * 简易声效控制 */ /** * 使用方法: * * var sound = require("scripts/lib/sound/main");
* * var snd = sound.create("sounds/myfile");
* snd.play();
*/ var buzz = require("scripts/lib/buzz");
var supported = buzz.isSupported();
var config = {
formats: [ "ogg", "mp3" ], preload: true, autoload: true, loop: false }
;
function ClassBuzz( src ){
this.sound = new buzz.sound( src, config );
}
ClassBuzz.prototype.play = function( s ){
s = this.sound;
s.setPercent( 0 );
s.setVolume( 100 );
s.play();
}
;
ClassBuzz.prototype.stop = function(){
this.sound.fadeOut( 1e3, function(){
this.pause();
}
);
}
;
exports.create = function( src ){
if( !supported ) return unSupported;
else return new ClassBuzz( src );
}
function unSupported(){
// TODO: }
unSupported.play = unSupported.stop = function(){
// TODO: }
;
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\lib\tween.js */ define("scripts/lib/tween.js", function(exports){
exports.exponential = function(){
}
;
exports.exponential.co = function(index, offset, target, framesNum){
return (index == framesNum) ? offset + target : target * (-Math.pow(2, -10 * index / framesNum) + 1) + offset;
}
;
// exports.exponential.ci = function(index, offset, target, framesNum){
return (index == 0) ? offset : target * Math.pow(2, 10 * (index / framesNum - 1)) + offset;
}
exports.bounce = function(){
}
;
exports.bounce.co = function(index, offset, target, framesNum){
if((index /= framesNum) (1 / 2.75)) return target * (7.5625 * index * index) + offset;
else if(index (2 / 2.75)) return target * (7.5625 * (index -= (1.5 / 2.75)) * index + .75) + offset;
else if(index (2.5 / 2.75)) return target * (7.5625 * (index -= (2.25 / 2.75)) * index + .9375) + offset;
else return target * (7.5625 * (index -= (2.625 / 2.75)) * index + .984375) + offset;
}
;
exports.quadratic = function(){
}
;
exports.quadratic.ci = function(index, offset, target, framesNum){
return target * (index /= framesNum) * index + offset;
}
;
exports.quadratic.co = function(index, offset, target, framesNum){
return - target * (index /= framesNum) * (index - 2) + offset;
}
exports.quadratic.cio = function(index, offset, target, framesNum){
if((index /= framesNum / 2) 1) return target / 2 * index * index + offset;
else return - target / 2 * ((-- index) * (index - 2) - 1) + offset;
}
;
exports.circular = function(index, offset, target, framesNum){
if((index /= framesNum / 2) 1) return - target / 2 * (Math.sqrt(1 - index * index) - 1) + offset;
else return target / 2 * (Math.sqrt(1 - (index -= 2) * index) + 1) + offset;
}
exports.linear = function(index, offset, target, framesNum){
return target * index / framesNum + offset;
}
;
exports.back = function(){
}
;
exports.back.ci = function(index, offset, target, framesNum, s){
s = 1.70158;
return target * (index /= framesNum) * index * ((s + 1) * index - s) + offset;
}
;
exports.back.co = function(index, offset, target, framesNum, s){
s = 1.70158;
return target * ((index = index / framesNum - 1) * index * ((s + 1) * index + s) + 1) + offset;
}
;
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\lib\ucren.js */ define("scripts/lib/ucren.js", function(exports){
/** * ucren-lite * filename: boot.js * author: dron * version: 5.0.2.20120628 * date: 2009-03-15 * contact: ucren.com */ var Ucren;
var blankArray = [];
var slice = blankArray.slice;
var join = blankArray.join;
// // [基本数据类型扩展] // // String.prototype.trim if( !String.prototype.trim ) String.prototype.trim = function(){
return this.replace( /^\s+|\s+$/, "" );
}
;
// String.prototype.format String.prototype.format = function( conf ){
var rtn = this, blank = {
}
;
Ucren.each( conf, function( item, key ){
item = item.toString().replace( /\$/g, "$$$$" );
rtn = rtn.replace( RegExp( "@{
" + key + "}
", "g" ), item );
}
);
return rtn.toString();
}
;
// String.prototype.htmlEncode String.prototype.htmlEncode = function(){
var p = document.createElement( "p" );
return function(){
var text;
p.appendChild( document.createTextNode( this ));
text = p.innerHTML;
p.innerHTML = "";
return text;
}
;
}
();
// String.prototype.byteLength String.prototype.byteLength = function(){
return this.replace( /[^\x00-\xff]/g, " " ).length;
}
;
// String.prototype.subByte String.prototype.subByte = function( len, tail ){
var s = this;
if( s.byteLength() = len ) return s;
tail = tail || "";
len -= tail.byteLength();
return s = s.slice( 0, len ).replace( /( [^\x00-\xff] )/g, "$1 " ) .slice( 0, len ) .replace( /[^\x00-\xff]$/, "" ) .replace( /( [^\x00-\xff] ) /g, "$1" ) + tail;
}
// Function.prototype.defer Function.prototype.defer = function( scope, timeout ){
var me = this;
var fn = function(){
me.apply( scope, arguments );
}
;
return setTimeout( fn, timeout );
}
;
// Function.prototype.bind if( !Function.prototype.bind ) Function.prototype.bind = function( scope ){
var me = this;
return function(){
return me.apply( scope, arguments );
}
}
;
// Function.prototype.saturate Function.prototype.saturate = function( scope/*, args */ ){
var fn = this, afters = slice.call( arguments, 1 );
return function(){
return fn.apply( scope, slice.call( arguments, 0 ).concat( afters ) );
}
}
;
// Array.prototype.indexOf // if( !Array.prototype.indexOf ) Array.prototype.indexOf = function( item, i ){
var length = this.length;
if( !i ) i = 0;
if( i 0 ) i = length + i;
for( ;
i length;
i ++ ) if( this[i] === item ) return i;
return -1;
}
;
// Array.prototype.every // if( !Array.prototype.every ) Array.prototype.every = function( fn, context ) {
for ( var i = 0, len = this.length;
i len;
i ++ ) if ( !fn.call( context, this[i], i, this ) ) return false;
return true;
}
;
// Array.prototype.filter // if( !Array.prototype.filter ) Array.prototype.filter = function( fn, context ) {
var result = [], val;
for ( var i = 0, len = this.length;
i len;
i ++ ) if ( val = this[i], fn.call( context, val, i, this ) ) result.push( val );
return result;
}
;
// Array.prototype.forEach // if( !Array.prototype.forEach ) Array.prototype.forEach = function( fn, context ) {
for ( var i = 0, len = this.length;
i len;
i ++ ) fn.call( context, this[i], i, this );
}
;
// Array.prototype.map // if( !Array.prototype.map ) Array.prototype.map = function( fn, context ) {
var result = [];
for ( var i = 0, len = this.length;
i len;
i ++ ) result[i] = fn.call( context, this[i], i, this );
return result;
}
;
// Array.prototype.some // if( !Array.prototype.some ) Array.prototype.some = function( fn, context ) {
for ( var i = 0, len = this.length;
i len;
i ++ ) if ( fn.call( context, this[i], i, this ) ) return true;
return false;
}
;
Array.prototype.invoke = function( method /*, args */ ){
var args = slice.call( arguments, 1 );
this.forEach( function( item ){
if( item instanceof Array ) item[0][method].apply( item[0], item.slice( 1 ) );
else item[method].apply( item, args );
}
);
return this;
}
;
Array.prototype.random = function(){
var arr = this.slice( 0 ), ret = [], i = arr.length;
while( i -- ) ret.push( arr.splice( Ucren.randomNumber( i + 1 ), 1 )[0] );
return ret;
}
;
Ucren = {
// // [全局属性] // // Ucren.isIe isIe: /msie/i.test( navigator.userAgent ), // Ucren.isIe6 isIe6: /msie 6/i.test( navigator.userAgent ), // Ucren.isFirefox isFirefox: /firefox/i.test( navigator.userAgent ), // Ucren.isSafari isSafari: /version\/[\d\.]+\s+safari/i.test( navigator.userAgent ), // Ucren.isopera isOpera: /opera/i.test( navigator.userAgent ), // Ucren.isChrome isChrome: /chrome/i.test( navigator.userAgent ), //todo isChrome = true, isSafari = true // Ucren.isStrict isStrict: document.compatMode == "CSS1Compat", // Ucren.tempDom tempDom: document.createElement( "p" ), // // [全局方法] // // Ucren.apply apply: function( form, to, except ){
if( !to )to = {
}
;
if( except ){
Ucren.each( form, function( item, key ){
if( key in except ) return ;
to[key] = item;
}
);
}
else{
Ucren.each( form, function( item, key ){
to[key] = item;
}
);
}
return to;
}
, // Ucren.appendStyle appendStyle: function( text ){
var style;
if( arguments.length >
1 ) text = join.call( arguments, "" );
if( document.createStyleSheet ){
style = document.createStyleSheet();
style.cssText = text;
}
else{
style = document.createElement( "style" );
style.type = "text/css";
//style.innerHTML = text;
fix Chrome bug style.appendChild( document.createTextNode( text ));
document.getElementsByTagName( "head" )[0].appendChild( style );
}
}
, // for copy : ) // // var addEvent = function( target, name, fn ){
// var call = function(){
// fn.apply( target, arguments );
// }
;
// if( window.attachEvent ) // target.attachEvent( "on" + name, call );
// else if( window.addEventListener ) // target.addEventListener( name, call, false );
// else // target["on" + name] = call;
// return call;
// }
// Ucren.addEvent addEvent: function( target, name, fn ){
var call = function(){
fn.apply( target, arguments );
}
;
if( target.dom ){
target = target.dom;
}
if( window.attachEvent ){
target.attachEvent( "on" + name, call );
}
else if( window.addEventListener ){
target.addEventListener( name, call, false );
}
else{
target["on" + name] = call;
}
return call;
}
, // Ucren.delEvent delEvent: function( target, name, fn ){
if( window.detachEvent ){
target.detachEvent( "on" + name, fn );
}
else if( window.removeEventListener ){
target.removeEventListener( name, fn, false );
}
else if( target["on" + name] == fn ){
target["on" + name] = null;
}
}
, // Ucren.Class Class: function( initialize, methods, befores, afters ){
var fn, prototype, blank;
initialize = initialize || function(){
}
;
methods = methods || {
}
;
blank = {
}
;
fn = function(){
this.instanceId = Ucren.id();
initialize.apply( this, arguments );
}
;
prototype = fn.prototype;
Ucren.registerClassEvent.call( prototype );
Ucren.each( methods, function( item, key ){
prototype[key] = function( method, name ){
if( typeof( method ) == "function" ){
return function(){
var args, rtn;
args = slice.call( arguments, 0 );
if( befores &
&
befores.apply( this, [name].concat( args )) === false ){
return ;
}
this.fireEvent( "before" + name, args );
rtn = method.apply( this, args );
if( afters ) afters.apply( this, [name].concat( args ));
this.fireEvent( name, args );
return rtn;
}
;
}
else{
return method;
}
}
( item, key );
}
);
prototype.getOriginMethod = function( name ){
return methods[name];
}
;
return fn;
}
, //private registerClassEvent: function(){
this.on = function( name, fn ){
var instanceId = this.instanceId;
Ucren.dispatch( instanceId + name, fn.bind( this ));
}
;
this.onbefore = function( name, fn ){
var instanceId = this.instanceId;
Ucren.dispatch( instanceId + "before" + name, fn.bind( this ));
}
;
this.un = function( name, fn ){
//todo }
;
this.fireEvent = function( name, args ){
var instanceId = this.instanceId;
Ucren.dispatch( instanceId + name, args );
}
;
}
, // Ucren.createFuze createFuze: function(){
var queue, fn, infire;
queue = [];
fn = function( process ){
if( infire ){
process();
}
else{
queue.push( process );
}
}
;
fn.fire = function(){
while( queue.length ){
queue.shift()();
}
infire = true;
}
;
fn.extinguish = function(){
infire = false;
}
;
fn.wettish = function(){
if( queue.length ){
queue.shift()();
}
}
;
return fn;
}
, // Ucren.createIf // createIf: function( expressionFunction ){
// return function( callback ){
// var expression = expressionFunction();
// var returnValue = {
// Else: function( callback ){
// callback = callback || nul;
// expression || callback();
// }
// }
;
// callback = callback || nul;
// expression &
&
callback();
// return returnValue;
// }
;
// }
, // Ucren.dispatch dispatch: function(){
var map = {
}
, send, incept, ret;
send = function( processId, args, scope ){
var processItems;
if( processItems = map[ processId ] ) Ucren.each( processItems, function( item ){
item.apply( scope, args );
}
);
}
;
incept = function( processId, fn ){
var m;
if( !( m = map[ processId ] ) ) map[processId] = [ fn ];
else m.push( fn );
}
;
ret = function( arg1, arg2, arg3 ){
if( typeof( arg2 ) === "undefined" ) arg2 = [];
if( arg2 instanceof Array ) send.apply( this, arguments );
else if( typeof( arg2 ) === "function" ) incept.apply( this, arguments );
}
;
ret.remove = function( processId, fn ){
var m, i;
if( ( m = map[ processId ] ) &
&
~( i = m.indexOf( fn ) ) ) m.splice( i, 1 );
}
;
return ret;
}
(), // Ucren.each ( not recommended ) each: function( unknown, fn ){
/// unknown 是 array 的,会慢慢退化,建议用 Array.prototype.forEach 替代 /// unknown 为其它类似的,短期内将暂时支持 if( unknown instanceof Array || ( typeof unknown == "object" &
&
typeof unknown[0] != "undefined" &
&
unknown.length )){
if( typeof unknown == "object" &
&
Ucren.isSafari ) unknown = slice.call( unknown );
// for( var i = 0, l = unknown.length;
i l;
i ++ ){
// if( fn( unknown[i], i ) === false ){
// break;
// }
// }
unknown.forEach( fn );
}
else if( typeof( unknown ) == "object" ){
var blank = {
}
;
for( var i in unknown ){
if( blank[i] ){
continue;
}
if( fn( unknown[i], i ) === false ){
break;
}
}
}
else if( typeof( unknown ) == "number" ){
for( var i = 0;
i unknown;
i ++ ){
if( fn( i, i ) === false ){
break;
}
}
}
else if( typeof( unknown ) == "string" ){
for( var i = 0, l = unknown.length;
i l;
i ++ ){
if( fn( unknown.charAt( i ), i ) === false ){
break;
}
}
}
}
, // Ucren.Element Element: function( el, returnDom ){
var rtn, handleId;
if( el &
&
el.isUcrenElement ){
return returnDom ? el.dom : el;
}
el = typeof( el ) == "string" ? document.getElementById( el ) : el;
if( !el ) return null;
if( returnDom ) return el;
handleId = el.getAttribute( "handleId" );
if( typeof handleId == "string" ){
return Ucren.handle( handleId - 0 );
}
else{
rtn = new Ucren.BasicElement( el );
handleId = Ucren.handle( rtn );
el.setAttribute( "handleId", handleId + "" );
return rtn;
}
}
, // Ucren.Event Event: function( e ){
e = e || window.event;
if( !e ){
var c = arguments.callee.caller;
while( c ){
e = c.arguments[0];
if( e &
&
typeof( e.altKey ) == "boolean" ){
// duck typing break;
}
c = c.caller;
e = null;
}
}
return e;
}
, // Ucren.fixNumber fixNumber: function( unknown, defaultValue ){
return typeof( unknown ) == "number" ? unknown : defaultValue;
}
, // Ucren.fixString fixString: function( unknown, defaultValue ){
return typeof( unknown ) == "string" ? unknown : defaultValue;
}
, // Ucren.fixConfig fixConfig: function( conf ){
var defaultConf;
defaultConf = {
}
;
if( typeof conf == "undefined" ){
return defaultConf;
}
else if( typeof conf == "function" ){
return new conf;
}
else{
return conf;
}
}
, // Ucren.handle handle: function( unknown ){
var fn, type, number;
fn = arguments.callee;
if( !fn.cache ){
fn.cache = {
}
;
}
if( typeof( fn.number ) == "undefined" ){
fn.number = 0;
}
type = typeof( unknown );
if( type == "number" ){
return fn.cache[unknown.toString()];
}
else if( type == "object" || type == "function" ){
number = fn.number ++;
fn.cache[number.toString()] = unknown;
return number;
}
}
, // Ucren.id id: function(){
var id = arguments.callee;
id.number = ++ id.number || 0;
return "_" + id.number;
}
, // Ucren.loadImage loadImage: function( urls, onLoadcomplete ){
var length = urls.length;
var loaded = 0;
var check = function(){
if( loaded == length ) onLoadComplete &
&
onLoadComplete();
}
;
Ucren.each( urls, function( url ){
var img = document.createElement( "img" );
img.onload = img.onerror = function(){
this.onload = this.onerror = null;
loaded ++;
check();
}
;
Ucren.tempDom.appendChild( img );
img.src = url;
}
);
}
, // Ucren.loadScript loadScript: function( src, callback ){
Ucren.request( src, function( text ){
eval( text );
callback &
&
callback( text );
}
);
}
, // Ucren.makeElement makeElement: function( tagName, attributes ){
var el = document.createElement( tagName );
var setStyle = function( unknown ){
if( typeof unknown == "string" ) el.style.cssText = unknown;
else Ucren.apply( unknown, el.style );
}
;
for ( var prop in attributes ) {
if ( prop === "class" ) el.classname = attributes[prop];
else if ( prop === "for" ) el.htmlFor = attributes[prop];
else if( prop === "style" ) setStyle( attributes[prop] );
else el.setAttribute( prop, attributes[prop] );
}
return el;
}
, // Ucren.nul nul: function(){
return false;
}
, // Ucren.queryString // queryString: function( name, sourceString ){
// var source, pattern, result;
// source = sourceString || location.href;
// pattern = new RegExp( "( \\?|&
)" + name + "=( [^&
#]* )( #|&
|$ )", "i" );
// result = source.match( pattern );
// return result ? result[2] : "";
// }
, // Ucren.randomNumber randomNumber: function( num ){
return Math.floor( Math.random() * num );
}
, // Ucren.randomWord randomWord: function(){
var cw = "0123456789abcDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
return function( length, sourceString ){
var words, re = [];
words = sourceString || cw;
Ucren.each( length, function( index ){
re[index] = words.charAt( this.randomNumber( words.length ));
}
.bind( this ));
return re.join( "" );
}
}
(), // Ucren.request request: function( url, callback ){
request = Ucren.request;
var xhr = request.xhr;
if( !request.xhr ){
if( window.XMLHttpRequest ){
xhr = request.xhr = new XMLHttpRequest();
}
else{
xhr = request.xhr = new ActiveXObject( "Microsoft.XMLHTTP" );
}
}
xhr.open( "GET", url, true );
xhr.onreadystatechange = function(){
if( xhr.readyState == 4 &
&
xhr.status == 200 ){
callback( xhr.responseText );
}
}
;
xhr.send( null );
}
// // Ucren.decodeColor // decodeColor: function(){
// var r = /^\#?( \w{
2}
)( \w{
2}
)( \w{
2}
)$/;
// var x = function( x ){
// return parseInt( x, 16 );
// }
;
// return function( color ){
// r.test( color );
// return {
// red: x( RegExp.$1 ), // green: x( RegExp.$2 ), // blue: x( RegExp.$3 ) // }
;
// }
// }
(), // // Ucren.encodeColor // encodeColor: function(){
// var x = function( x ){
// return x.toString( 16 ).split( "." )[0];
// }
;
// x = x.improve( function( origin, x ){
// x = origin( x );
// return x.length == 1 ? "0" + x : x;
// }
);
// return function( data ){
// return ["#", x( data.red ), x( data.green ), x( data.blue )].join( "" );
// }
// }
() }
;
// // [底层操作类] // // Ucren.BasicDrag Ucren.BasicDrag = Ucren.Class( /* constructor */ function( conf ){
conf = Ucren.fixConfig( conf );
this.type = Ucren.fixString( conf.type, "normal" );
var isTouch = this.isTouch = "ontouchstart" in window;
this.TOUCH_START = isTouch ? "touchstart" : "mousedown", this.TOUCH_MOVE = isTouch ? "touchmove" : "mousemove", this.TOUCH_END = isTouch ? "touchend" : "mouseup";
}
, /* methods */ {
bind: function( el, handle ){
el = Ucren.Element( el );
handle = Ucren.Element( handle ) || el;
var evt = {
}
;
evt[this.TOUCH_START] = function( e ){
e = Ucren.Event( e );
this.startDrag();
e.cancelBubble = true;
e.stopPropagation &
&
e.stopPropagation();
return e.returnValue = false;
}
.bind( this );
handle.addEvents( evt );
this.target = el;
}
, //private getCoors: function( e ){
var coors = [];
if ( e.targetTouches &
&
e.targetTouches.length ) {
// iPhone var thisTouch = e.targetTouches[0];
coors[0] = thisTouch.clientX;
coors[1] = thisTouch.clientY;
}
else{
// all others coors[0] = e.clientX;
coors[1] = e.clientY;
}
return coors;
}
, //private startDrag: function(){
var target, draging, e;
target = this.target;
draging = target.draging = {
}
;
this.isDraging = true;
draging.x = parseInt( target.style( "left" ), 10 ) || 0;
draging.y = parseInt( target.style( "top" ), 10 ) || 0;
e = Ucren.Event();
var coors = this.getCoors( e );
draging.mouseX = coors[0];
draging.mouseY = coors[1];
this.registerDocumentEvent();
}
, //private endDrag: function(){
this.isDraging = false;
this.unRegisterDocumentEvent();
}
, //private registerDocumentEvent: function(){
var target, draging;
target = this.target;
draging = target.draging;
draging.DocumentselectStart = Ucren.addEvent( document, "selectstart", function( e ){
e = e || event;
e.stopPropagation &
&
e.stopPropagation();
e.cancelBubble = true;
return e.returnValue = false;
}
);
draging.documentMouseMove = Ucren.addEvent( document, this.TOUCH_MOVE, function( e ){
var ie, nie;
e = e || event;
ie = Ucren.isIe &
&
e.button != 1;
nie = !Ucren.isIe &
&
e.button != 0;
if( (ie || nie ) &
&
!this.isTouch ) this.endDrag();
var coors = this.getCoors( e );
draging.newMouseX = coors[0];
draging.newMouseY = coors[1];
e.stopPropagation &
&
e.stopPropagation();
return e.returnValue = false;
}
.bind( this ));
draging.documentMouseUp = Ucren.addEvent( document, this.TOUCH_END, function(){
this.endDrag();
}
.bind( this ));
var lx, ly;
clearInterval( draging.timer );
draging.timer = setInterval( function(){
var x, y, dx, dy;
if( draging.newMouseX != lx &
&
draging.newMouseY != ly ){
lx = draging.newMouseX;
ly = draging.newMouseY;
dx = draging.newMouseX - draging.mouseX;
dy = draging.newMouseY - draging.mouseY;
x = draging.x + dx;
y = draging.y + dy;
if( this.type == "calc" ){
this.returnValue( dx, dy, draging.newMouseX, draging.newMouseY );
}
else{
target.left( x ).top( y );
}
}
}
.bind( this ), 10 );
}
, //private unRegisterDocumentEvent: function(){
var draging = this.target.draging;
Ucren.delEvent( document, this.TOUCH_MOVE, draging.documentMouseMove );
Ucren.delEvent( document, this.TOUCH_END, draging.documentMouseUp );
Ucren.delEvent( document, "selectstart", draging.documentSelectStart );
clearInterval( draging.timer );
}
, //private returnValue: function( dx, dy, x, y ){
//todo something }
}
);
// Ucren.Template Ucren.Template = Ucren.Class( /* constructor */ function(){
this.string = join.call( arguments, "" );
}
, /* methods */ {
apply: function( conf ){
return this.string.format( conf );
}
}
);
// Ucren.BasicElement Ucren.BasicElement = Ucren.Class( /* constructor */ function( el ){
this.dom = el;
this.countMapping = {
}
;
}
, /* methods */ {
isUcrenElement: true, attr: function( name, value ){
if( typeof value == "string" ){
this.dom.setAttribute( name, value );
}
else{
return this.dom.getAttribute( name );
}
return this;
}
, style: function( /* unknown1, unknown2 */ ){
var getStyle = Ucren.isIe ? function( name ){
return this.dom.currentStyle[name];
}
: function( name ){
var style;
style = document.defaultView.getComputedStyle( this.dom, null );
return style.getPropertyValue( name );
}
;
return function( unknown1, unknown2 ){
if( typeof unknown1 == "object" ){
Ucren.each( unknown1, function( value, key ){
this[key] = value;
}
.bind( this.dom.style ));
}
else if( typeof unknown1 == "string" &
&
typeof unknown2 == "undefined" ){
return getStyle.call( this, unknown1 );
}
else if( typeof unknown1 == "string" &
&
typeof unknown2 != "undefined" ){
this.dom.style[unknown1] = unknown2;
}
return this;
}
;
}
(), hasClass: function( name ){
var className = " " + this.dom.className + " ";
return className.indexOf( " " + name + " " ) >
-1;
}
, setClass: function( name ){
if( typeof( name ) == "string" ) this.dom.className = name.trim();
return this;
}
, addClass: function( name ){
var el, className;
el = this.dom;
className = " " + el.className + " ";
if( className.indexOf( " " + name + " " ) == -1 ){
className += name;
className = className.trim();
className = className.replace( / +/g, " " );
el.className = className;
}
return this;
}
, delClass: function( name ){
var el, className;
el = this.dom;
className = " " + el.className + " ";
if( className.indexOf( " " + name + " " ) >
-1 ){
className = className.replace( " " + name + " ", " " );
className = className.trim();
className = className.replace( / +/g, " " );
el.className = className;
}
return this;
}
, html: function( html ){
var el = this.dom;
if( typeof html == "string" ){
el.innerHTML = html;
}
else if( html instanceof Array ){
el.innerHTML = html.join( "" );
}
else{
return el.innerHTML;
}
return this;
}
, left: function( number ){
var el = this.dom;
if( typeof( number ) == "number" ){
el.style.left = number + "px";
this.fireEvent( "infect", [{
left: number }
] );
}
else{
return this.getPos().x;
}
return this;
}
, top: function( number ){
var el = this.dom;
if( typeof( number ) == "number" ){
el.style.top = number + "px";
this.fireEvent( "infect", [{
top: number }
] );
}
else{
return this.getPos().y;
}
return this;
}
, width: function( unknown ){
var el = this.dom;
if( typeof unknown == "number" ){
el.style.width = unknown + "px";
this.fireEvent( "infect", [{
width: unknown }
] );
}
else if( typeof unknown == "string" ){
el.style.width = unknown;
this.fireEvent( "infect", [{
width: unknown }
] );
}
else{
return this.getSize().width;
}
return this;
}
, height: function( unknown ){
var el = this.dom;
if( typeof unknown == "number" ){
el.style.height = unknown + "px";
this.fireEvent( "infect", [{
height: unknown }
] );
}
else if( typeof unknown == "string" ){
el.style.height = unknown;
this.fireEvent( "infect", [{
height: unknown }
] );
}
else{
return this.getSize().height;
}
return this;
}
, count: function( name ){
return this.countMapping[name] = ++ this.countMapping[name] || 1;
}
, display: function( bool ){
var dom = this.dom;
if( typeof( bool ) == "boolean" ){
dom.style.display = bool ? "block" : "none";
this.fireEvent( "infect", [{
display: bool }
] );
}
else{
return this.style( "display" ) != "none";
}
return this;
}
, first: function(){
var c = this.dom.firstChild;
while( c &
&
!c.tagName &
&
c.nextSibling ){
c = c.nextSibling;
}
return c;
}
, add: function( dom ){
var el;
el = Ucren.Element( dom );
this.dom.appendChild( el.dom );
return this;
}
, remove: function( dom ){
var el;
if( dom ){
el = Ucren.Element( dom );
el.html( "" );
this.dom.removeChild( el.dom );
}
else{
el = Ucren.Element( this.dom.parentNode );
el.remove( this );
}
return this;
}
, insert: function( dom ){
var tdom;
tdom = this.dom;
if( tdom.firstChild ){
tdom.insertBefore( dom, tdom.firstChild );
}
else{
this.add( dom );
}
return this;
}
, addEvents: function( conf ){
var blank, el, rtn;
blank = {
}
;
rtn = {
}
;
el = this.dom;
Ucren.each( conf, function( item, key ){
rtn[key] = Ucren.addEvent( el, key, item );
}
);
return rtn;
}
, removeEvents: function( conf ){
var blank, el;
blank = {
}
;
el = this.dom;
Ucren.each( conf, function( item, key ){
Ucren.delEvent( el, key, item );
}
);
return this;
}
, getPos: function(){
var el, parentNode, pos, box, offset;
el = this.dom;
pos = {
}
;
if( el.getBoundingClientRect ){
box = el.getBoundingClientRect();
offset = Ucren.isIe ? 2 : 0;
var doc = document;
var scrollTop = Math.max( doc.documentElement.scrollTop, doc.body.scrollTop );
var scrollLeft = Math.max( doc.documentElement.scrollLeft, doc.body.scrollLeft );
return {
x: box.left + scrollLeft - offset, y: box.top + scrollTop - offset }
;
}
else{
pos = {
x: el.offsetLeft, y: el.offsetTop }
;
parentNode = el.offsetParent;
if( parentNode != el ){
while( parentNode ){
pos.x += parentNode.offsetLeft;
pos.y += parentNode.offsetTop;
parentNode = parentNode.offsetParent;
}
}
if( Ucren.isSafari &
&
this.style( "position" ) == "absolute" ){
// safari doubles in some cases pos.x -= document.body.offsetLeft;
pos.y -= document.body.offsetTop;
}
}
if( el.parentNode ){
parentNode = el.parentNode;
}
else{
parentNode = null;
}
while( parentNode &
&
parentNode.tagName.toUpperCase() != "BODY" &
&
parentNode.tagName.toUpperCase() != "HTML" ){
// account for any scrolled ancestors pos.x -= parentNode.scrollLeft;
pos.y -= parentNode.scrollTop;
if( parentNode.parentNode ){
parentNode = parentNode.parentNode;
}
else{
parentNode = null;
}
}
return pos;
}
, getSize: function(){
var dom = this.dom;
var display = this.style( "display" );
if ( display &
&
display !== "none" ) {
return {
width: dom.offsetWidth, height: dom.offsetHeight }
;
}
var style = dom.style;
var originalStyles = {
visibility: style.visibility, position: style.position, display: style.display }
;
var newStyles = {
visibility: "hidden", display: "block" }
;
if ( originalStyles.position !== "fixed" ) newStyles.position = "absolute";
this.style( newStyles );
var dimensions = {
width: dom.offsetWidth, height: dom.offsetHeight }
;
this.style( originalStyles );
return dimensions;
}
, observe: function( el, fn ){
el = Ucren.Element( el );
el.on( "infect", fn.bind( this ));
return this;
}
, usePNGbackground: function( image ){
var dom;
dom = this.dom;
if( /\.png$/i.test( image ) &
&
Ucren.isIe6 ){
dom.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader( src='" + image + "',sizingMethod='scale' );
";
/// _background: none;
/// _filter: progid:DXImageTransform.Microsoft.AlphaImageLoader( src='images/pic.png',sizingMethod='scale' );
}
else{
dom.style.backgroundImage = "url( " + image + " )";
}
return this;
}
, setAlpha: function(){
var reOpacity = /alpha\s*\(\s*opacity\s*=\s*([^\)]+)\)/;
return function( value ){
var element = this.dom, es = element.style;
if( !Ucren.isIe ){
es.opacity = value / 100;
/* }
else if( es.filter === "string" ){
*/ }
else{
if ( element.currentStyle &
&
!element.currentStyle.hasLayout ) es.zoom = 1;
if ( reOpacity.test( es.filter )) {
value = value >
= 99.99 ? "" : ( "alpha( opacity=" + value + " )" );
es.filter = es.filter.replace( reOpacity, value );
}
else {
es.filter += " alpha( opacity=" + value + " )";
}
}
return this;
}
;
}
(), fadeIn: function( callback ){
if( typeof this.fadingNumber == "undefined" ) this.fadingNumber = 0;
this.setAlpha( this.fadingNumber );
var fading = function(){
this.setAlpha( this.fadingNumber );
if( this.fadingNumber == 100 ){
clearInterval( this.fadingInterval );
callback &
&
callback();
}
else this.fadingNumber += 10;
}
.bind( this );
this.display( true );
clearInterval( this.fadingInterval );
this.fadingInterval = setInterval( fading, Ucren.isIe ? 20 : 30 );
return this;
}
, fadeOut: function( callback ){
if( typeof this.fadingNumber == "undefined" ) this.fadingNumber = 100;
this.setAlpha( this.fadingNumber );
var fading = function(){
this.setAlpha( this.fadingNumber );
if( this.fadingNumber == 0 ){
clearInterval( this.fadingInterval );
this.display( false );
callback &
&
callback();
}
else this.fadingNumber -= 10;
}
.bind( this );
clearInterval( this.fadingInterval );
this.fadingInterval = setInterval( fading, Ucren.isIe ? 20 : 30 );
return this;
}
, useMouseAction: function( className, actions ){
/** * 调用示例: el.useMouseAction( "xbutton", "over,out,down,up" );
* 使用效果: el 会在 "xbutton xbutton-over","xbutton xbutton-out","xbutton xbutton-down","xbutton xbutton-up" * 等四个 className 中根据相应的鼠标事件来进行切换。 * 特别提示: useMouseAction 可使用不同参数多次调用。 */ if( !this.MouseAction ) this.MouseAction = new Ucren.MouseAction({
element: this }
);
this.MouseAction.use( className, actions );
return this;
}
}
);
if( Ucren.isIe ) document.execCommand( "BackgroundImageCache", false, true );
for( var i in Ucren ){
exports[i] = Ucren[i];
}
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\object\background.js */ define("scripts/object/background.js", function(exports){
var Ucren = require("scripts/lib/ucren");
var layer = require("scripts/layer");
var timeline = require("scripts/timeline");
var image, time;
var random = Ucren.randomNumber;
exports.set = function(){
image = layer.createImage( "default", "images/background.jpg", 0, 0, 640, 480 );
}
;
exports.wobble = function(){
time = timeline.setInterval( wobble, 50 );
}
;
exports.stop = function(){
time.stop();
image.attr({
x: 0, y: 0 }
);
}
;
function wobble(){
var x, y;
x = random( 12 ) - 6;
y = random( 12 ) - 6;
image.attr({
x: x, y: y }
);
}
;
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\object\console.js */ define("scripts/object/console.js", function(exports){
var layer = require("scripts/layer");
var x = 16, y = 0;
var texts = [];
exports.set = function(){
}
;
exports.clear = function(){
for(var i = 0, l = texts.length;
i l;
i ++) texts[i].remove();
texts.length = y = 0;
}
;
exports.log = function(text){
y += 20;
texts.push( layer.createText( "default", text, x, y ) );
}
;
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\object\developing.js */ define("scripts/object/developing.js", function(exports){
var layer = require("scripts/layer");
var tween = require("scripts/lib/tween");
var timeline = require("scripts/timeline");
var message = require("scripts/message");
var exponential = tween.exponential.co;
/** * "coming soon" 模块 */ exports.anims = [];
exports.set = function(){
this.image = layer.createImage( "default", "images/developing.png", 103, 218, 429, 53 ).hide().scale( 1e-5, 1e-5 );
}
;
exports.show = function( start ){
timeline.createTask({
start: start, duration: 500, data: [ 1e-5, 1, "show" ], object: this, onTimeUpdate: this.onZooming, onTimeStart: this.onZoomStart, onTimeEnd: this.onZoomEnd, recycle: this.anims }
);
this.hide( 2000 );
}
;
exports.hide = function( start ){
timeline.createTask({
start: start, duration: 500, data: [ 1, 1e-5, "hide" ], object: this, onTimeUpdate: this.onZooming, onTimeStart: this.onZoomStart, onTimeEnd: this.onZoomEnd, recycle: this.anims }
);
}
;
// 显示/隐藏 相关 exports.onZoomStart = function(){
this.image.show();
}
;
exports.onZooming = function( time, sz, ez, z ){
this.image.scale( z = exponential( time, sz, ez - sz, 500 ), z );
}
;
exports.onZoomEnd = function( sz, ez, mode ){
if( mode === "hide" ) this.image.hide();
}
;
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\object\dojo.js */ define("scripts/object/dojo.js", function(exports){
var rotate = require("scripts/factory/rotate");
var tween = require("scripts/lib/tween");
exports = rotate.create("images/dojo.png", 41, 240, 175, 175, 1e-5, tween.exponential.co, 500);
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\object\flame.js */ define("scripts/object/flame.js", function(exports){
/** * 火焰模块 * @author zswang, dron */ var layer = require("scripts/layer").getLayer( "fruit" );
var timeline = require("scripts/timeline");
var Ucren = require("scripts/lib/ucren");
/* raphael.path('M 27,122 Q 9,42 27,21 45,42 27,122') .attr({
stroke: 'none', fill: '180-#D8D380-#EDED7A-#D8D380' }
);
*/ // 缩写 var math = Math, cos = math.cos, sin = math.sin, trunc = parseInt, random = math.random, PI = math.PI;
var guid = 0;
/** * 添加一个火苗 * @param{
Array}
center 中心位置 单位像素 * @param{
Number}
angle 运动方向 单位幅度 * @param{
Number}
length 运动长度 单位像素 * @param{
Number}
life 存活时间 单位毫秒 */ function appenDFlame( center, angle, length, life, flames ){
return flames[guid] = {
id: guid ++, birthday: new Date, center: center, angle: angle, length: length, life: life, path: layer.path().attr({
stroke: 'none', fill: trunc( angle * 180 / PI ) + '-#fafad9-#f0ef9c' }
) }
;
}
var radius = 15;
function updateFlame( flames, n ){
var item = flames[n];
if ( !item ) return;
var age, center, p1, p2, p3, p4;
age = 1 - (new Date - item.birthday) / item.life;
if ( age = 0 ){
item.path.remove();
delete flames[item.id];
return;
}
var ia, ic, il;
ia = item.angle;
ic = item.center;
il = item.length;
center = [ trunc(ic[0] + cos(ia) * il * (1 - age)), trunc(ic[1] + sin(ia) * il * (1 - age)) ];
p1 = [ trunc(center[0] - cos(ia) * radius * age), trunc(center[1] - sin(ia) * radius * age) ];
p2 = [ trunc(center[0] + cos(ia) * radius * age), trunc(center[1] + sin(ia) * radius * age) ];
p3 = [ trunc(center[0] - cos(ia + .5 * PI) * radius * .4 * age), trunc(center[1] - sin(ia + .5 * PI) * radius * .4 * age) ];
p4 = [ trunc(center[0] - cos(ia - .5 * PI) * radius * .4 * age), trunc(center[1] - sin(ia - .5 * PI) * radius * .4 * age) ];
item.path.attr({
path: 'M' + p1 + ' Q' + [ p3, p2, p4, p1 ].join(' ') }
);
}
;
function removeFlame( flames, n ){
var item = flames[n];
if( !item ) return;
item.path.remove();
delete flames[ n ];
}
;
exports.create = function( ox, oy, start ){
var timer1, timer2;
var object = {
pos: function( x, y ){
nx = x;
ny = y;
image.attr( "x", nx - 21 ).attr( "y", ny - 21 );
}
, remove: function(){
[ timer1, timer2 ].invoke( "stop" );
image.remove();
for (var p in flames) removeFlame( flames, p );
}
}
;
var nx = ox, ny = oy;
var image = layer.image("images/smoke.png", nx - 21, ny - 21, 43, 43).hide();
var flames = {
}
;
timer1 = timeline.setTimeout(function(){
image.show();
timer2 = timeline.setInterval(function(){
if(random() 0.9) appendFlame( [ nx, ny ], PI * 2 * random(), 60, 200 + 500 * random(), flames );
for (var p in flames) updateFlame( flames, p );
}
, Ucren.isIe ? 20 : 40);
}
, start || 0);
return object;
}
;
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\object\flash.js */ define("scripts/object/flash.js", function(exports){
/** * */ var layer = require("scripts/layer");
var timeline = require("scripts/timeline").use( "flash" ).init( 10 );
var tween = require("scripts/lib/tween");
var sound = require("scripts/lib/sound");
var image, snd, xDiff = 0, yDiff = 0;
var anim = tween.quadratic.cio;
var anims = [];
var dur = 100;
exports.set = function(){
image = layer.createImage( "flash", "images/flash.png", 0, 0, 358, 20 ).hide();
snd = sound.create( "sound/splatter" );
}
;
exports.showAt = function( x, y, an ){
image.rotate( an, true ).scale( 1e-5, 1e-5 ).attr({
x: x + xDiff, y: y + yDiff }
).show();
anims.clear &
&
anims.clear();
snd.play();
timeline.createTask({
start: 0, duration: dur, data: [ 1e-5, 1 ], object: this, onTimeUpdate: this.onTimeUpdate, recycle: anims }
);
timeline.createTask({
start: dur, duration: dur, data: [ 1, 1e-5 ], object: this, onTimeUpdate: this.onTimeUpdate, recycle: anims }
);
}
;
exports.onTimeUpdate = function( time, a, b, z ){
image.scale( z = anim( time, a, b - a, dur ), z );
}
;
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\object\fps.js */ define("scripts/object/fps.js", function(exports){
// var layer = require("scripts/layer");
// var timeline =require("scripts/timeline");
// var text, fps = "fps: ";
// exports.set = function(){
// text = layer.createText( "default", fps + "0", 4, 470 ).attr( "fill", "#ccc" );
// }
;
// exports.update = function(){
// text.attr( "text", fps + ( timeline.getFPS() >
>
0 ) );
// }
;
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\object\game-over.js */ define("scripts/object/game-over.js", function(exports){
var layer = require("scripts/layer");
var tween = require("scripts/lib/tween");
var timeline = require("scripts/timeline");
var message = require("scripts/message");
var state = require("scripts/state");
var exponential = tween.exponential.co;
/** * "game-over"模块 */ exports.anims = [];
exports.set = function(){
this.image = layer.createImage( "default", "images/game-over.png", 75, 198, 490, 85 ).hide().scale( 1e-5, 1e-5 );
}
;
exports.show = function( start ){
timeline.createTask({
start: start, duration: 500, data: [ 1e-5, 1, "show" ], object: this, onTimeUpdate: this.onZooming, onTimeStart: this.onZoomStart, onTimeEnd: this.onZoomEnd, recycle: this.anims }
);
}
;
exports.hide = function( start ){
timeline.createTask({
start: start, duration: 500, data: [ 1, 1e-5, "hide" ], object: this, onTimeUpdate: this.onZooming, onTimeStart: this.onZoomStart, onTimeEnd: this.onZoomEnd, recycle: this.anims }
);
}
;
// 显示/隐藏 相关 exports.onZoomStart = function( sz, ez, mode ){
if( mode == "show" ) this.image.show();
}
;
exports.onZooming = function( time, sz, ez, z ){
this.image.scale( z = exponential( time, sz, ez - sz, 500 ), z );
}
;
exports.onZoomEnd = function( sz, ez, mode ){
if( mode == "show" ) state( "click-enable" ).on();
else if( mode === "hide" ) this.image.hide();
}
;
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\object\home-desc.js */ define("scripts/object/home-desc.js", function(exports){
var displacement = require("scripts/factory/displacement");
var tween = require("scripts/lib/tween");
exports = displacement.create("images/home-desc.png", 161, 91, -161, 140, 7, 127, tween.exponential.co, 500);
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\object\home-mask.js */ define("scripts/object/home-mask.js", function(exports){
var displacement = require("scripts/factory/displacement");
var tween = require("scripts/lib/tween");
exports = displacement.create("images/home-mask.png", 640, 183, 0, -183, 0, 0, tween.exponential.co, 1e3);
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\object\knife.js */ define("scripts/object/knife.js", function(exports){
var timeline = require("scripts/timeline");
var layer = require("scripts/layer").getLayer( "knife" );
var Ucren = require("scripts/lib/ucren");
/** * 刀光模块 */ var lastX = null, lastY = null;
var abs = Math.abs;
var life = 200;
var stroke = 10;
var color = "#cbd3db";
var anims = [];
var switchState = true;
var knifes = [];
function ClassKnifePart( conf ){
this.sx = conf.sx;
this.sy = conf.sy;
this.ex = conf.ex;
this.ey = conf.ey;
knifes.push( this );
}
ClassKnifePart.prototype.set = function(){
var sx, sy, ex, ey, dx, dy, ax, ay;
sx = this.sx;
sy = this.sy;
ex = this.ex;
ey = this.ey;
dx = sx - ex;
dy = sy - ey;
ax = abs(dx);
ay = abs(dy);
if(ax >
ay) sx += dx 0 ? -1 : 1, sy += dy 0 ? -( 1 * ay / ax ) : 1 * ay / ax;
else sx += dx 0 ? -( 1 * ax / ay ) : 1 * ax / ay, sy += dy 0 ? -1 : 1;
this.line = layer.path( "M" + sx + "," + sy + "L" + ex + "," + ey ).attr({
"stroke": color, "stroke-width": stroke + "px" }
);
timeline.createTask({
start: 0, duration: life, object: this, onTimeUpdate: this.update, onTimeEnd: this.end, recycle: anims }
);
return this;
}
;
ClassKnifePart.prototype.update = function( time ){
this.line.attr( "stroke-width", stroke * (1 - time / life) + "px" );
}
;
ClassKnifePart.prototype.end = function(){
this.line.remove();
var index;
if( index = knifes.indexOf( this ) ) knifes.splice( index, 1 );
}
;
exports.newKnife = function(){
lastX = lastY = null;
}
;
exports.through = function( x, y ){
if( !switchState ) return ;
var ret = null;
if( lastX !== null &
&
( lastX != x || lastY != y ) ) new ClassKnifePart({
sx: lastX, sy: lastY, ex: x, ey: y }
).set(), ret = [ lastX, lastY, x, y ];
lastX = x;
lastY = y;
return ret;
}
;
exports.pause = function(){
anims.clear();
this.switchOff();
}
;
exports.switchOff = function(){
switchState = false;
}
;
exports.switchOn = function(){
switchState = true;
this.endAll();
}
;
exports.endAll = function(){
for(var i = knifes.length - 1;
i >
= 0;
i --) knifes[i].end();
}
;
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\object\light.js */ define("scripts/object/light.js", function(exports){
/** * 炸弹爆炸时的光线 */ var layer = require("scripts/layer");
var maskLayer = layer.getLayer( "mask" );
layer = layer.getLayer( "light" );
var Ucren = require("scripts/lib/ucren");
var timeline = require("scripts/timeline");
var message = require("scripts/message");
var random = Ucren.randomNumber;
var pi = Math.PI;
var sin = Math.sin;
var cos = Math.cos;
var lights = [];
var indexs = [];
var lightsNum = 10;
for(var i = 0;
i lightsNum;
i ++) indexs[i] = i;
exports.start = function( boom ){
var x = boom.originX, y = boom.originY, time = 0, idx = indexs.random();
var i = lightsNum, b = function(){
build( x, y, idx[ this ] );
}
;
while( i -- ) timeline.setTimeout( b.bind( i ), time += 100 );
timeline.setTimeout(function(){
this.overWhiteLight();
}
.bind( this ), time + 100);
}
;
exports.overWhiteLight = function(){
message.postMessage( "overWhiteLight.show" );
this.removeLights();
var dur = 4e3;
var mask = maskLayer.rect( 0, 0, 640, 480 ).attr({
fill: "#fff", stroke: "none" }
);
var control = {
onTimeUpdate: function( time ){
mask.attr( "opacity", 1 - time / dur );
}
, onTimeEnd: function(){
mask.remove();
message.postMessage( "game.over" );
}
}
;
timeline.createTask({
start: 0, duration: dur, object: control, onTimeUpdate: control.onTimeUpdate, onTimeEnd: control.onTimeEnd }
);
}
;
exports.removeLights = function(){
for(var i = 0, l = lights.length;
i l;
i ++) lights[i].remove();
lights.length = 0;
}
;
function build( x, y, r ){
var a1, a2, x1, y1, x2, y2;
a1 = r * 36 + random( 10 );
a2 = a1 + 5;
a1 = pi * a1 / 180;
a2 = pi * a2 / 180;
x1 = x + 640 * cos( a1 );
y1 = y + 640 * sin( a1 );
x2 = x + 640 * cos( a2 );
y2 = y + 640 * sin( a2 );
var light = layer.path( [ "M", x, y, "L", x1, y1, "L", x2, y2, "Z" ] ).attr({
stroke: "none", fill: "#fff" }
);
lights.push( light );
}
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\object\logo.js */ define("scripts/object/logo.js", function(exports){
var displacement = require("scripts/factory/displacement");
var tween = require("scripts/lib/tween");
exports = displacement.create("images/logo.png", 288, 135, 17, -182, 17, 1, tween.exponential.co, 1e3);
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\object\lose.js */ define("scripts/object/lose.js", function(exports){
var layer = require("scripts/layer");
var tween = require("scripts/lib/tween");
var timeline = require("scripts/timeline");
var Ucren = require("scripts/lib/ucren");
var message = require("scripts/message");
var anim = tween.exponential.co;
var back = tween.back.co;
/** * */ var o1, o2, o3, animLength = 500;
var conF1 = {
src: "images/x.png", sx: 650, ex: 561, y: 5, w: 22, h: 19 }
;
var conf2 = {
src: "images/xx.png", sx: 671, ex: 582, y: 5, w: 27, h: 26 }
;
var conf3 = {
src: "images/xxx.png", sx: 697, ex: 608, y: 6, w: 31, h: 32 }
;
var number = 0;
exports.anims = [];
exports.set = function(){
o1 = layer.createImage( "default", conf1.src, conf1.sx, conf1.y, conf1.w, conf1.h ).hide();
o2 = layer.createImage( "default", conf2.src, conf2.sx, conf2.y, conf2.w, conf2.h ).hide();
o3 = layer.createImage( "default", conf3.src, conf3.sx, conf3.y, conf3.w, conf3.h ).hide();
}
;
exports.reset = function(){
number = 0;
[ [ o1, conf1 ], [ o2, conf2 ], [ o3, conf3 ] ].forEach(function( infx ){
infx[0].attr( "src", infx[1].src.replace( "xf.png", "x.png" ) );
}
) }
;
exports.show = function( start ){
timeline.createTask({
start: start, duration: animLength, data: [ "show", conf1.sx, conf1.ex, conf2.sx, conf2.ex, conf3.sx, conf3.ex ], object: this, onTimeUpdate: this.onTimeUpdate, onTimeStart: this.onTimeStart, onTimeEnd: this.onTimeEnd, recycle: this.anims }
);
}
;
exports.hide = function( start ){
timeline.createTask({
start: start, duration: animLength, data: [ "hide", conf1.ex, conf1.sx, conf2.ex, conf2.sx, conf3.ex, conf3.sx ], object: this, onTimeUpdate: this.onTimeUpdate, onTimeStart: this.onTimeStart, onTimeEnd: this.onTimeEnd, recycle: this.anims }
);
}
;
exports.showLoseAt = function( x ){
var infx, inf = [ [ o1, conf1 ], [ o2, conf2 ], [ o3, conf3 ] ];
createPosShow( x );
infx = inf[ ( ++ number ) - 1 ];
infx[0].attr( "src", infx[1].src.replace( "x.png", "xf.png" ) ).scale( 1e-5, 1e-5 );
this.scaleImage( infx[0] );
if( number == 3 ) message.postMessage( "game.over" );
}
;
exports.scaleImage = function( image ){
var dur = 500;
image.myOnScaling = image.myOnScaling || function( time, z ){
this.scale( z = back( time, 1e-5, 1 - 1e-5, dur ), z );
}
;
image.myOnScaleEnd = image.myOnScaleEnd || function(){
this.scale( 1, 1 );
}
;
timeline.createTask({
start: 0, duration: dur, object: image, onTimeUpdate: image.myOnScaling, onTimeEnd: image.myOnScaleEnd, recycle: this.anims }
);
}
;
// 显示/隐藏 相关 exports.onTimeUpdate = function( time, mode, x1s, x1e, x2s, x2e, x3s, x3e ){
o1.attr( "x", anim( time, x1s, x1e - x1s, animLength ) );
o2.attr( "x", anim( time, x2s, x2e - x2s, animLength ) );
o3.attr( "x", anim( time, x3s, x3e - x3s, animLength ) );
}
;
exports.onTimeStart = function( mode ){
if( mode == "show" ) [ o1, o2, o3 ].invoke( "show" );
}
;
exports.onTimeEnd = function( mode ){
if( mode == "hide" ) [ o1, o2, o3 ].invoke( "hide" ), this.reset();
}
;
function createPosShow( x ){
var image = layer.createImage( "default", "images/lose.png", x - 27, 406, 54, 50 ).scale( 1e-5, 1e-5 );
var duration = 500;
var control = {
show: function( start ){
timeline.createTask({
start: start, duration: duration, data: [ tween.back.co, 1e-5, 1 ], object: this, onTimeUpdate: this.onScaling, onTimeEnd: this.onShowEnd // recycle: anims }
);
}
, hide: function( start ){
timeline.createTask({
start: start, duration: duration, data: [ tween.back.ci, 1, 1e-5 ], object: this, onTimeUpdate: this.onScaling, onTimeEnd: this.onHideEnd // recycle: anims }
);
}
, onScaling: function( time, anim, a, b, z ){
image.scale( z = anim( time, a, b - a, duration ), z );
}
, onShowEnd: function(){
this.hide( 1500 );
}
, onHideEnd: function(){
image.remove();
}
}
;
control.show( 200 );
}
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\object\new-game.js */ define("scripts/object/new-game.js", function(exports){
var rotate = require("scripts/factory/rotate");
var tween = require("scripts/lib/tween");
exports = rotate.create("images/new-game.png", 244, 231, 195, 195, 1e-5, tween.exponential.co, 500);
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\object\new.js */ define("scripts/object/new.js", function(exports){
var layer = require("scripts/layer");
var tween = require("scripts/lib/tween");
var timeline = require("scripts/timeline");
var Ucren = require("scripts/lib/ucren");
var image;
var cycleTime = 300;
var sx = 129, sy = 328, ex = 170, ey = 221, sw = 0, sh = 0, ew = 70, eh = 42, dy = 8;
var showAnim = tween.exponential.co;
var jumpAnim = tween.quadratic.ci;
exports.anims = [];
exports.set = function(){
image = layer.createImage( "default", "images/new.png", sx, sy, sw, sh );
}
;
exports.unset = function(){
}
;
exports.show = function( start ){
timeline.createTask({
start: start, duration: 500, data: [ sx, ex, sy, ey, sw, ew, sh, eh ], object: this, onTimeUpdate: this.onShowing, onTimeStart: this.onShowStart, onTimeEnd: this.onShowEnd, recycle: this.anims }
);
}
;
exports.hide = function( start ){
this.anims.clear();
timeline.createTask({
start: start, duration: 500, data: [ ex, sx, ey, sy, ew, sw, eh, sh ], object: this, onTimeUpdate: this.onShowing, recycle: this.anims }
);
}
;
exports.jump = function(){
this.anims.clear();
timeline.createTask({
start: 0, duration: -1, object: this, onTimeUpdate: this.onJumping, recycle: this.anims }
);
}
;
// 显示相关 exports.onShowStart = function(){
}
;
exports.onShowing = function( time, sx, ex, sy, ey, sw, ew, sh, eh ){
image.attr({
x: showAnim( time, sx, ex - sx, 500 ), y: showAnim( time, sy, ey - sy, 500 ), width: showAnim( time, sw, ew - sw, 500 ), height: showAnim( time, sh, eh - sh, 500 ) }
);
}
;
exports.onShowEnd = function(){
this.jump();
}
;
// 跳跃相关 exports.onJumping = function(time){
var t = parseInt(time / cycleTime);
time = time % cycleTime;
if( t % 2 ) time = cycleTime - time;
image.attr("y", jumpAnim( time, ey, dy, cycleTime ));
}
;
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\object\ninja.js */ define("scripts/object/ninja.js", function(exports){
var displacement = require("scripts/factory/displacement");
var tween = require("scripts/lib/tween");
exports = displacement.create("images/ninja.png", 244, 81, 315, -140, 315, 43, {
show: tween.bounce.co, hide: tween.exponential.co }
, 1e3);
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\object\quit.js */ define("scripts/object/quit.js", function(exports){
var rotate = require("scripts/factory/rotate");
var tween = require("scripts/lib/tween");
exports = rotate.create("images/quit.png", 493, 311, 141, 141, 1e-5, tween.exponential.co, 500);
;
return exports;
}
);
/** * @source D:\hosting\demos\fruit-ninja\output\scripts\object\score.js */ define("scripts/object/score.js", function(exports){
var layer = require("scripts/layer");
var tween = require("scripts/lib/tween");
var timeline = require("scripts/timeline");
var Ucren = require("scripts/lib/ucren");
var setTimeout = timeline.setTimeout.bind( timeline );
var anim = tween.exponential.co;
var message = require("scripts/message");
/** * 分数模块 */ var image, text1, text2, animLength = 500;
;
var imageSx = -94, imageEx = 6;
var text1Sx = -59, text1Ex = 41;
var text2Sx = -93, text2Ex = 7;
exports.anims = [];
exports.set = function(){
image = layer.createImage( "default", "images/score.png", imageSx, 8, 29, 31 ).hide();
text1 = layer.createText( "default", "0", text1Sx, 24, "90-#fc7f0c-#ffec53", "30px" ).hide();
text2 = layer.createText( "default", "BEST 999", text2Sx, 48, "#af7c05", "14px" ).hide();
}
;
exports.show = function( start ){
timeline.createTask({
start: start, duration: animLength, data: [ "show", imageSx, imageEx, text1Sx, text1Ex, text2Sx, text2Ex ], object: this, onTimeUpdate: this.onTimeUpdate, onTimeStart: this.onTimeStart, onTimeEnd: this.onTimeEnd, recycle: this.anims }
);
}
;
exports.hide = function( start ){
timeline.createTask({
start: start, duration: animLength, data: [ "hide", imageEx, imageSx, text1Ex, text1Sx, text2Ex, text2Sx ], object: this, onTimeUpdate: this.onTimeUpdate, onTimeStart: this.onTimeStart, onTimeEnd: this.onTimeEnd, recycle: this.anims }
);
}
;
exports.number = function( number ){
text1.attr( "text", number || 0 );
image.scale( 1.2, 1.2 );
setTimeout(function(){
image.scale( 1, 1 );
}
, 60);
// message.postMessage( number, "score.change" );
}
;
// 显示/隐藏 相关 exports.onTimeUpdate = function( time, mode, isx, iex, t1sx, t1ex, t2sx, t2ex ){
image.attr( "x", anim( time, isx, iex - isx, animLength ) );
text1.attr( "x", anim( time, t1sx, t1ex - t1sx, animLength ) );
text2.attr( "x", anim( time, t2sx, t2ex - t2sx, animLength ) );
}
;
exports.onTimeStart = function( mode ){
if( mode === "show" ) [ image, text1, text2 ].invoke( "show" );
}
;
exports.onTimeEnd = function( mode ){
if( mode === "hide" ) [ image, text1, text2 ].invoke( "hide" ), text1.attr( "text", 0 );
}
;
;
return exports;
}
);
startModule("scripts/main");
以上就是教你如何用HTML5和JS实现切水果游戏的内容,更多相关内容请关注PHP中文网(www.php.cn)!
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: 教你如何用HTML5和JS实现切水果游戏
本文地址: https://pptw.com/jishu/584124.html
