1 /**************************************************************************** 2 Copyright (c) 2010-2012 cocos2d-x.org 3 Copyright (c) 2008-2010 Ricardo Quesada 4 Copyright (c) 2011 Zynga Inc. 5 6 http://www.cocos2d-x.org 7 8 Permission is hereby granted, free of charge, to any person obtaining a copy 9 of this software and associated documentation files (the "Software"), to deal 10 in the Software without restriction, including without limitation the rights 11 to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 12 copies of the Software, and to permit persons to whom the Software is 13 furnished to do so, subject to the following conditions: 14 15 The above copyright notice and this permission notice shall be included in 16 all copies or substantial portions of the Software. 17 18 THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 19 IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 20 FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 21 AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 22 LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 23 OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 24 THE SOFTWARE. 25 ****************************************************************************/ 26 27 /** 28 * cc.ShakyTiles3D action 29 * @class 30 * @extends cc.TiledGrid3DAction 31 */ 32 cc.ShakyTiles3D = cc.TiledGrid3DAction.extend(/** @lends cc.ShakyTiles3D# */{ 33 _randRange:0, 34 _shakeZ:false, 35 36 ctor:function () { 37 cc.GridAction.prototype.ctor.call(this); 38 this._randRange = 0; 39 this._shakeZ = false; 40 }, 41 42 /** 43 * initializes the action with a range, whether or not to shake Z vertices, a grid size, and duration 44 * @param {Number} duration 45 * @param {cc.Size} gridSize 46 * @param {Number} range 47 * @param {Boolean} shakeZ 48 * @return {Boolean} 49 */ 50 initWithDuration:function (duration, gridSize, range, shakeZ) { 51 if (cc.TiledGrid3DAction.prototype.initWithDuration.call(this, duration, gridSize)) { 52 this._randRange = range; 53 this._shakeZ = shakeZ; 54 return true; 55 } 56 return false; 57 }, 58 59 update:function (time) { 60 var locGridSize = this._gridSize, locRandRange = this._randRange; 61 var locPos = cc.p(0, 0); 62 for (var i = 0; i < locGridSize.width; ++i) { 63 for (var j = 0; j < locGridSize.height; ++j) { 64 locPos.x = i; 65 locPos.y = j; 66 var coords = this.originalTile(locPos); 67 68 // X 69 coords.bl.x += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 70 coords.br.x += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 71 coords.tl.x += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 72 coords.tr.x += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 73 74 // Y 75 coords.bl.y += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 76 coords.br.y += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 77 coords.tl.y += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 78 coords.tr.y += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 79 80 if (this._shakeZ) { 81 coords.bl.z += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 82 coords.br.z += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 83 coords.tl.z += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 84 coords.tr.z += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 85 } 86 87 this.setTile(locPos, coords); 88 } 89 } 90 } 91 }); 92 93 /** 94 * creates the action with a range, whether or not to shake Z vertices, a grid size, and duration 95 * @param {Number} duration 96 * @param {cc.Size} gridSize 97 * @param {Number} range 98 * @param {Boolean} shakeZ 99 * @return {cc.ShakyTiles3D} 100 */ 101 cc.ShakyTiles3D.create = function (duration, gridSize, range, shakeZ) { 102 var action = new cc.ShakyTiles3D(); 103 action.initWithDuration(duration, gridSize, range, shakeZ); 104 return action; 105 }; 106 107 /** 108 * cc.ShatteredTiles3D action 109 * @class 110 * @extends cc.TiledGrid3DAction 111 */ 112 cc.ShatteredTiles3D = cc.TiledGrid3DAction.extend(/** @lends cc.ShatteredTiles3D# */{ 113 _randRange:0, 114 _once:false, 115 _shatterZ:false, 116 117 ctor:function () { 118 cc.GridAction.prototype.ctor.call(this); 119 this._randRange = 0; 120 this._shakeZ = false; 121 this._once = false; 122 }, 123 124 /** 125 * initializes the action with a range, whether or not to shatter Z vertices, a grid size and duration 126 * @param {Number} duration 127 * @param {cc.Size} gridSize 128 * @param {Number} range 129 * @param {Boolean} shatterZ 130 * @return {Boolean} 131 */ 132 initWithDuration:function (duration, gridSize, range, shatterZ) { 133 if (cc.TiledGrid3DAction.prototype.initWithDuration.call(this, duration, gridSize)) { 134 this._once = false; 135 this._randRange = range; 136 this._shatterZ = shatterZ; 137 return true; 138 } 139 return false; 140 }, 141 142 update:function (time) { 143 if (this._once === false) { 144 var locGridSize = this._gridSize, locRandRange = this._randRange; 145 var coords, locPos = cc.p(0, 0); 146 for (var i = 0; i < locGridSize.width; ++i) { 147 for (var j = 0; j < locGridSize.height; ++j) { 148 locPos.x = i; 149 locPos.y = j; 150 coords = this.originalTile(locPos); 151 152 // X 153 coords.bl.x += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 154 coords.br.x += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 155 coords.tl.x += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 156 coords.tr.x += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 157 158 // Y 159 coords.bl.y += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 160 coords.br.y += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 161 coords.tl.y += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 162 coords.tr.y += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 163 164 if (this._shatterZ) { 165 coords.bl.z += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 166 coords.br.z += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 167 coords.tl.z += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 168 coords.tr.z += ( cc.rand() % (locRandRange * 2) ) - locRandRange; 169 } 170 this.setTile(locPos, coords); 171 } 172 } 173 this._once = true; 174 } 175 } 176 }); 177 178 /** 179 * creates the action with a range, whether of not to shatter Z vertices, a grid size and duration 180 * @param {Number} duration 181 * @param {cc.Size} gridSize 182 * @param {Number} range 183 * @param {Boolean} shatterZ 184 * @return {cc.ShatteredTiles3D} 185 */ 186 cc.ShatteredTiles3D.create = function (duration, gridSize, range, shatterZ) { 187 var action = new cc.ShatteredTiles3D(); 188 action.initWithDuration(duration, gridSize, range, shatterZ); 189 return action; 190 }; 191 192 /** 193 * A Tile composed of position, startPosition and delta 194 * @Class 195 * @constructor 196 * @param {cc.Point} [position=cc.p(0,0)] 197 * @param {cc.Point} [startPosition=cc.p(0,0)] 198 * @param {cc.Size} [delta=cc.p(0,0)] 199 */ 200 cc.Tile = function (position, startPosition, delta) { 201 this.position = position || cc.p(0,0); 202 this.startPosition = startPosition || cc.p(0,0); 203 this.delta = delta || cc.p(0,0); 204 }; 205 206 /** 207 * cc.ShuffleTiles action, Shuffle the tiles in random order 208 * @class 209 * @extends cc.TiledGrid3DAction 210 */ 211 cc.ShuffleTiles = cc.TiledGrid3DAction.extend(/** @lends cc.ShuffleTiles# */{ 212 _seed:0, 213 _tilesCount:0, 214 _tilesOrder:null, 215 _tiles:null, 216 217 ctor:function () { 218 cc.GridAction.prototype.ctor.call(this); 219 this._tilesOrder = []; 220 this._tiles = []; 221 this._seed = 0; 222 this._tilesCount = 0; 223 }, 224 225 /** 226 * initializes the action with a random seed, the grid size and the duration 227 * @param {Number} duration 228 * @param {cc.Size} gridSize 229 * @param {Number} seed 230 * @return {Boolean} 231 */ 232 initWithDuration:function (duration, gridSize, seed) { 233 if (cc.TiledGrid3DAction.prototype.initWithDuration.call(this, duration, gridSize)) { 234 this._seed = seed; 235 this._tilesOrder.length = 0; 236 this._tiles.length = 0; 237 return true; 238 } 239 return false; 240 }, 241 242 /** 243 * shuffle 244 * @param {Array} array 245 * @param {Number} len 246 */ 247 shuffle:function (array, len) { 248 for (var i = len - 1; i >= 0; i--) { 249 var j = 0 | (cc.rand() % (i + 1)); 250 var v = array[i]; 251 array[i] = array[j]; 252 array[j] = v; 253 } 254 }, 255 256 /** 257 * get Delta 258 * @param {cc.Size} pos 259 */ 260 getDelta:function (pos) { 261 var locGridSize = this._gridSize; 262 var idx = pos.width * locGridSize.height + pos.height; 263 return cc.size(((this._tilesOrder[idx] / locGridSize.height) - pos.width), 264 ((this._tilesOrder[idx] % locGridSize.height) - pos.height)); 265 }, 266 267 /** 268 * place Tile 269 * @param {cc.Point} pos 270 * @param {cc.Tile} tile 271 */ 272 placeTile:function (pos, tile) { 273 var coords = this.originalTile(pos); 274 275 var step = this.target.grid.getStep(); 276 var locPosition = tile.position; 277 coords.bl.x += (locPosition.x * step.x); 278 coords.bl.y += (locPosition.y * step.y); 279 280 coords.br.x += (locPosition.x * step.x); 281 coords.br.y += (locPosition.y * step.y); 282 283 coords.tl.x += (locPosition.x * step.x); 284 coords.tl.y += (locPosition.y * step.y); 285 286 coords.tr.x += (locPosition.x * step.x); 287 coords.tr.y += (locPosition.y * step.y); 288 289 this.setTile(pos, coords); 290 }, 291 292 /** 293 * start with target 294 * @param {cc.Node} target 295 */ 296 startWithTarget:function (target) { 297 cc.TiledGrid3DAction.prototype.startWithTarget.call(this, target); 298 var locGridSize = this._gridSize; 299 300 this._tilesCount = locGridSize.width * locGridSize.height; 301 var locTilesOrder = this._tilesOrder; 302 locTilesOrder.length = 0; 303 304 /** 305 * Use k to loop. Because m_nTilesCount is unsigned int, 306 * and i is used later for int. 307 */ 308 for (var k = 0; k < this._tilesCount; ++k) 309 locTilesOrder[k] = k; 310 this.shuffle(locTilesOrder, this._tilesCount); 311 312 var locTiles = this._tiles ; 313 locTiles.length = 0; 314 var tileIndex = 0, tempSize = cc.size(0,0); 315 for (var i = 0; i < locGridSize.width; ++i) { 316 for (var j = 0; j < locGridSize.height; ++j) { 317 locTiles[tileIndex] = new cc.Tile(); 318 locTiles[tileIndex].position = cc.p(i, j); 319 locTiles[tileIndex].startPosition = cc.p(i, j); 320 tempSize.width = i; 321 tempSize.height = j; 322 locTiles[tileIndex].delta = this.getDelta(tempSize); 323 ++tileIndex; 324 } 325 } 326 }, 327 328 update:function (time) { 329 var tileIndex = 0, locGridSize = this._gridSize, locTiles = this._tiles; 330 var selTile, locPos = cc.p(0, 0); 331 for (var i = 0; i < locGridSize.width; ++i) { 332 for (var j = 0; j < locGridSize.height; ++j) { 333 locPos.x = i; 334 locPos.y = j; 335 selTile = locTiles[tileIndex]; 336 selTile.position.x = selTile.delta.width * time; 337 selTile.position.y = selTile.delta.height * time; 338 this.placeTile(locPos, selTile); 339 ++tileIndex; 340 } 341 } 342 } 343 }); 344 345 /** 346 * creates the action with a random seed, the grid size and the duration 347 * @param {Number} duration 348 * @param {cc.Size} gridSize 349 * @param {Number} seed 350 * @return {cc.ShuffleTiles} 351 */ 352 cc.ShuffleTiles.create = function (duration, gridSize, seed) { 353 var action = new cc.ShuffleTiles(); 354 action.initWithDuration(duration, gridSize, seed); 355 return action; 356 }; 357 358 /** 359 * cc.FadeOutTRTiles action. Fades out the tiles in a Top-Right direction 360 * @class 361 * @extends cc.TiledGrid3DAction 362 */ 363 cc.FadeOutTRTiles = cc.TiledGrid3DAction.extend(/** @lends cc.FadeOutTRTiles# */{ 364 /** 365 * @param {cc.Size} pos 366 * @param {Number} time 367 */ 368 testFunc:function (pos, time) { 369 var locX = this._gridSize.width * time; 370 var locY = this._gridSize.height * time; 371 if ((locX + locY) == 0.0) 372 return 1.0; 373 return Math.pow((pos.width + pos.height) / (locX + locY), 6); 374 }, 375 376 /** 377 * turn on Tile 378 * @param {cc.Point} pos 379 */ 380 turnOnTile:function (pos) { 381 this.setTile(pos, this.originalTile(pos)); 382 }, 383 384 /** 385 * turn Off Tile 386 * @param {cc.Point} pos 387 */ 388 turnOffTile:function (pos) { 389 this.setTile(pos, new cc.Quad3()); 390 }, 391 392 /** 393 * transform tile 394 * @param {cc.Point} pos 395 * @param {Number} distance 396 */ 397 transformTile:function (pos, distance) { 398 var coords = this.originalTile(pos); 399 var step = this.target.grid.getStep(); 400 401 coords.bl.x += (step.x / 2) * (1.0 - distance); 402 coords.bl.y += (step.y / 2) * (1.0 - distance); 403 404 coords.br.x -= (step.x / 2) * (1.0 - distance); 405 coords.br.y += (step.y / 2) * (1.0 - distance); 406 407 coords.tl.x += (step.x / 2) * (1.0 - distance); 408 coords.tl.y -= (step.y / 2) * (1.0 - distance); 409 410 coords.tr.x -= (step.x / 2) * (1.0 - distance); 411 coords.tr.y -= (step.y / 2) * (1.0 - distance); 412 413 this.setTile(pos, coords); 414 }, 415 416 update:function (time) { 417 var locGridSize = this._gridSize; 418 var locPos = cc.p(0, 0), locSize = cc.size(0, 0), distance; 419 for (var i = 0; i < locGridSize.width; ++i) { 420 for (var j = 0; j < locGridSize.height; ++j) { 421 locPos.x = i; 422 locPos.y = j; 423 locSize.width = i; 424 locSize.height = j; 425 distance = this.testFunc(locSize, time); 426 if (distance == 0) 427 this.turnOffTile(locPos); 428 else if (distance < 1) 429 this.transformTile(locPos, distance); 430 else 431 this.turnOnTile(locPos); 432 } 433 } 434 } 435 }); 436 437 /** 438 * creates the action with the grid size and the duration 439 * @param duration 440 * @param gridSize 441 * @return {cc.FadeOutTRTiles} 442 */ 443 cc.FadeOutTRTiles.create = function (duration, gridSize) { 444 var action = new cc.FadeOutTRTiles(); 445 action.initWithDuration(duration, gridSize); 446 return action; 447 }; 448 449 /** 450 * cc.FadeOutBLTiles action. Fades out the tiles in a Bottom-Left direction 451 * @class 452 * @extends cc.FadeOutTRTiles 453 */ 454 cc.FadeOutBLTiles = cc.FadeOutTRTiles.extend(/** @lends cc.FadeOutBLTiles# */{ 455 /** 456 * @param {cc.Size} pos 457 * @param {Number} time 458 */ 459 testFunc:function (pos, time) { 460 var locX = this._gridSize.width * (1.0 - time); 461 var locY = this._gridSize.height * (1.0 - time); 462 if ((pos.width + pos.height) == 0) 463 return 1.0; 464 465 return Math.pow((locX + locY) / (pos.width + pos.height), 6); 466 } 467 }); 468 469 /** 470 * creates the action with the grid size and the duration 471 * @param duration 472 * @param gridSize 473 * @return {cc.FadeOutBLTiles} 474 */ 475 cc.FadeOutBLTiles.create = function (duration, gridSize) { 476 var action = new cc.FadeOutBLTiles(); 477 action.initWithDuration(duration, gridSize); 478 return action; 479 }; 480 481 /** 482 * cc.FadeOutUpTiles action. Fades out the tiles in upwards direction 483 * @class 484 * @extends cc.FadeOutTRTiles 485 */ 486 cc.FadeOutUpTiles = cc.FadeOutTRTiles.extend(/** @lends cc.FadeOutUpTiles# */{ 487 testFunc:function (pos, time) { 488 var locY = this._gridSize.height * time; 489 if (locY == 0.0) 490 return 1.0; 491 return Math.pow(pos.height / locY, 6); 492 }, 493 494 transformTile:function (pos, distance) { 495 var coords = this.originalTile(pos); 496 var step = this.target.grid.getStep(); 497 498 coords.bl.y += (step.y / 2) * (1.0 - distance); 499 coords.br.y += (step.y / 2) * (1.0 - distance); 500 coords.tl.y -= (step.y / 2) * (1.0 - distance); 501 coords.tr.y -= (step.y / 2) * (1.0 - distance); 502 503 this.setTile(pos, coords); 504 } 505 }); 506 507 /** 508 * creates the action with the grid size and the duration 509 * @param {Number} duration 510 * @param {cc.Size} gridSize 511 * @return {cc.FadeOutUpTiles} 512 */ 513 cc.FadeOutUpTiles.create = function (duration, gridSize) { 514 var action = new cc.FadeOutUpTiles(); 515 action.initWithDuration(duration, gridSize); 516 return action; 517 }; 518 519 /** 520 * cc.FadeOutDownTiles action. Fades out the tiles in downwards direction 521 * @class 522 * @extends cc.FadeOutUpTiles 523 */ 524 cc.FadeOutDownTiles = cc.FadeOutUpTiles.extend(/** @lends cc.FadeOutDownTiles# */{ 525 testFunc:function (pos, time) { 526 var locY = this._gridSize.height * (1.0 - time); 527 if (pos.height == 0) 528 return 1.0; 529 return Math.pow(locY / pos.height, 6); 530 } 531 }); 532 533 /** 534 * creates the action with the grid size and the duration 535 * @param {Number} duration 536 * @param {cc.Size} gridSize 537 * @return {cc.FadeOutDownTiles} 538 */ 539 cc.FadeOutDownTiles.create = function (duration, gridSize) { 540 var action = new cc.FadeOutDownTiles(); 541 action.initWithDuration(duration, gridSize); 542 return action; 543 }; 544 545 546 /** 547 * cc.TurnOffTiles action.<br/> 548 * Turn off the files in random order 549 * @class 550 * @extends cc.TiledGrid3DAction 551 */ 552 cc.TurnOffTiles = cc.TiledGrid3DAction.extend(/** @lends cc.TurnOffTiles# */{ 553 _seed:null, 554 _tilesCount:0, 555 _tilesOrder:null, 556 557 ctor:function () { 558 cc.GridAction.prototype.ctor.call(this); 559 this._tilesOrder = []; 560 this._seed = null; 561 this._tilesCount = 0; 562 }, 563 564 /** initializes the action with a random seed, the grid size and the duration 565 * @param {Number} duration 566 * @param {cc.Size} gridSize 567 * @param {Number} seed 568 * @return {Boolean} 569 */ 570 initWithDuration:function (duration, gridSize, seed) { 571 if (cc.TiledGrid3DAction.prototype.initWithDuration.call(this, duration, gridSize)) { 572 this._seed = seed; 573 this._tilesOrder.length = 0; 574 return true; 575 } 576 return false; 577 }, 578 579 /** 580 * @param {Array} array 581 * @param {Number} len 582 */ 583 shuffle:function (array, len) { 584 for (var i = len - 1; i >= 0; i--) { 585 var j = 0 | (cc.rand() % (i + 1)); 586 var v = array[i]; 587 array[i] = array[j]; 588 array[j] = v; 589 } 590 }, 591 592 /** 593 * @param {cc.Point} pos 594 */ 595 turnOnTile:function (pos) { 596 this.setTile(pos, this.originalTile(pos)); 597 }, 598 599 /** 600 * @param {cc.Point} pos 601 */ 602 turnOffTile:function (pos) { 603 this.setTile(pos, new cc.Quad3()); 604 }, 605 606 /** 607 * @param {cc.Node} target 608 */ 609 startWithTarget:function (target) { 610 cc.TiledGrid3DAction.prototype.startWithTarget.call(this, target); 611 612 this._tilesCount = this._gridSize.width * this._gridSize.height; 613 var locTilesOrder = this._tilesOrder; 614 locTilesOrder.length = 0; 615 for (var i = 0; i < this._tilesCount; ++i) 616 locTilesOrder[i] = i; 617 this.shuffle(locTilesOrder, this._tilesCount); 618 }, 619 620 /** 621 * @param {Number} time 622 */ 623 update:function (time) { 624 var l = 0 | (time * this._tilesCount), locGridSize = this._gridSize; 625 var t,tilePos = cc.p(0,0), locTilesOrder = this._tilesOrder; 626 for (var i = 0; i < this._tilesCount; i++) { 627 t = locTilesOrder[i]; 628 tilePos.x = 0 | (t / locGridSize.height); 629 tilePos.y = t % (0 | locGridSize.height); 630 if (i < l) 631 this.turnOffTile(tilePos); 632 else 633 this.turnOnTile(tilePos); 634 } 635 } 636 }); 637 638 /** 639 * creates the action with a random seed, the grid size and the duration 640 * @param {Number} duration 641 * @param {cc.Size} gridSize 642 * @param {Number|Null} [seed=0] 643 * @return {cc.TurnOffTiles} 644 * @example 645 * // example 646 * // turnOffTiles without seed 647 * var toff = cc.TurnOffTiles.create(this._duration, cc.size(x, y)); 648 * 649 * // turnOffTiles with seed 650 * var toff = cc.TurnOffTiles.create(this._duration, cc.size(x, y), 0); 651 */ 652 cc.TurnOffTiles.create = function (duration, gridSize, seed) { 653 seed = seed || 0; 654 var action = new cc.TurnOffTiles(); 655 action.initWithDuration(duration, gridSize, seed); 656 return action; 657 }; 658 659 /** 660 * cc.WavesTiles3D action. 661 * @class 662 * @extends cc.TiledGrid3DAction 663 */ 664 cc.WavesTiles3D = cc.TiledGrid3DAction.extend(/** @lends cc.WavesTiles3D# */{ 665 _waves:0, 666 _amplitude:0, 667 _amplitudeRate:0, 668 669 ctor:function () { 670 cc.GridAction.prototype.ctor.call(this); 671 this._waves = 0; 672 this._amplitude = 0; 673 this._amplitudeRate = 0; 674 }, 675 676 /** 677 * get amplitude of waves 678 * @return {Number} 679 */ 680 getAmplitude:function () { 681 return this._amplitude; 682 }, 683 684 /** 685 * set amplitude of waves 686 * @param {Number} amplitude 687 */ 688 setAmplitude:function (amplitude) { 689 this._amplitude = amplitude; 690 }, 691 692 /** 693 * get amplitude rate of waves 694 * @return {Number} 695 */ 696 getAmplitudeRate:function () { 697 return this._amplitudeRate; 698 }, 699 700 /** 701 * set amplitude rate of waves 702 * @param {Number} amplitudeRate 703 */ 704 setAmplitudeRate:function (amplitudeRate) { 705 this._amplitudeRate = amplitudeRate; 706 }, 707 708 /** 709 * initializes the action with a number of waves, the waves amplitude, the grid size and the duration 710 * @param {Number} duration 711 * @param {cc.Size} gridSize 712 * @param {Number} waves 713 * @param {Number} amplitude 714 * @return {Boolean} 715 */ 716 initWithDuration:function (duration, gridSize, waves, amplitude) { 717 if (cc.TiledGrid3DAction.prototype.initWithDuration.call(this, duration, gridSize)) { 718 this._waves = waves; 719 this._amplitude = amplitude; 720 this._amplitudeRate = 1.0; 721 return true; 722 } 723 return false; 724 }, 725 726 update:function (time) { 727 var locGridSize = this._gridSize, locWaves = this._waves, locAmplitude = this._amplitude, locAmplitudeRate = this._amplitudeRate; 728 var locPos = cc.p(0, 0), coords; 729 for (var i = 0; i < locGridSize.width; i++) { 730 for (var j = 0; j < locGridSize.height; j++) { 731 locPos.x = i; 732 locPos.y = j; 733 coords = this.originalTile(locPos); 734 coords.bl.z = (Math.sin(time * Math.PI * locWaves * 2 + 735 (coords.bl.y + coords.bl.x) * 0.01) * locAmplitude * locAmplitudeRate); 736 coords.br.z = coords.bl.z; 737 coords.tl.z = coords.bl.z; 738 coords.tr.z = coords.bl.z; 739 this.setTile(locPos, coords); 740 } 741 } 742 } 743 }); 744 745 /** 746 * creates the action with a number of waves, the waves amplitude, the grid size and the duration 747 * @param {Number} duration 748 * @param {cc.Size} gridSize 749 * @param {Number} waves 750 * @param {Number} amplitude 751 * @return {cc.WavesTiles3D} 752 */ 753 cc.WavesTiles3D.create = function (duration, gridSize, waves, amplitude) { 754 var action = new cc.WavesTiles3D(); 755 action.initWithDuration(duration, gridSize, waves, amplitude); 756 return action; 757 }; 758 759 /** 760 * cc.JumpTiles3D action. A sin function is executed to move the tiles across the Z axis 761 * @class 762 * @extends cc.TiledGrid3DAction 763 */ 764 cc.JumpTiles3D = cc.TiledGrid3DAction.extend(/** @lends cc.JumpTiles3D# */{ 765 _jumps:0, 766 _amplitude:0, 767 _amplitudeRate:0, 768 769 ctor:function () { 770 cc.GridAction.prototype.ctor.call(this); 771 this._jumps = 0; 772 this._amplitude = 0; 773 this._amplitudeRate = 0; 774 }, 775 776 /** 777 * get amplitude of the sin 778 * @return {Number} 779 */ 780 getAmplitude:function () { 781 return this._amplitude; 782 }, 783 784 /** 785 * set amplitude of the sin 786 * @param {Number} amplitude 787 */ 788 setAmplitude:function (amplitude) { 789 this._amplitude = amplitude; 790 }, 791 792 /** 793 * get amplitude rate 794 * @return {Number} 795 */ 796 getAmplitudeRate:function () { 797 return this._amplitudeRate; 798 }, 799 800 /** 801 * set amplitude rate 802 * @param amplitudeRate 803 */ 804 setAmplitudeRate:function (amplitudeRate) { 805 this._amplitudeRate = amplitudeRate; 806 }, 807 808 /** 809 * initializes the action with the number of jumps, the sin amplitude, the grid size and the duration 810 * @param {Number} duration 811 * @param {cc.Size} gridSize 812 * @param {Number} numberOfJumps 813 * @param {Number} amplitude 814 */ 815 initWithDuration:function (duration, gridSize, numberOfJumps, amplitude) { 816 if (cc.TiledGrid3DAction.prototype.initWithDuration.call(this, duration, gridSize)) { 817 this._jumps = numberOfJumps; 818 this._amplitude = amplitude; 819 this._amplitudeRate = 1.0; 820 return true; 821 } 822 return false; 823 }, 824 825 update:function (time) { 826 var sinz = (Math.sin(Math.PI * time * this._jumps * 2) * this._amplitude * this._amplitudeRate ); 827 var sinz2 = (Math.sin(Math.PI * (time * this._jumps * 2 + 1)) * this._amplitude * this._amplitudeRate ); 828 829 var locGridSize = this._gridSize; 830 var locGrid = this.target.grid; 831 var coords, locPos = cc.p(0, 0); 832 for (var i = 0; i < locGridSize.width; i++) { 833 for (var j = 0; j < locGridSize.height; j++) { 834 locPos.x = i; 835 locPos.y = j; 836 //hack for html5 837 //var coords = this.originalTile(cc.p(i, j)); 838 coords = locGrid.originalTile(locPos); 839 840 if (((i + j) % 2) == 0) { 841 coords.bl.z += sinz; 842 coords.br.z += sinz; 843 coords.tl.z += sinz; 844 coords.tr.z += sinz; 845 } else { 846 coords.bl.z += sinz2; 847 coords.br.z += sinz2; 848 coords.tl.z += sinz2; 849 coords.tr.z += sinz2; 850 } 851 //hack for html5 852 //this.setTile(cc.p(i, j), coords); 853 locGrid.setTile(locPos, coords); 854 } 855 } 856 } 857 }); 858 859 /** 860 * creates the action with the number of jumps, the sin amplitude, the grid size and the duration 861 * @param {Number} duration 862 * @param {cc.Size} gridSize 863 * @param {Number} numberOfJumps 864 * @param {Number} amplitude 865 * @return {cc.JumpTiles3D} 866 */ 867 cc.JumpTiles3D.create = function (duration, gridSize, numberOfJumps, amplitude) { 868 var action = new cc.JumpTiles3D(); 869 action.initWithDuration(duration, gridSize, numberOfJumps, amplitude); 870 return action; 871 }; 872 873 /** 874 * cc.SplitRows action 875 * @class 876 * @extends cc.TiledGrid3DAction 877 */ 878 cc.SplitRows = cc.TiledGrid3DAction.extend(/** @lends cc.SplitRows# */{ 879 _rows:0, 880 _winSize:null, 881 882 ctor:function () { 883 cc.GridAction.prototype.ctor.call(this); 884 this._rows = 0; 885 this._winSize = null; 886 }, 887 888 /** 889 * initializes the action with the number of rows to split and the duration 890 * @param {Number} duration 891 * @param {Number} rows 892 * @return {Boolean} 893 */ 894 initWithDuration:function (duration, rows) { 895 this._rows = rows; 896 return cc.TiledGrid3DAction.prototype.initWithDuration.call(this, duration, cc.size(1, rows)); 897 }, 898 899 update:function (time) { 900 var locGridSize = this._gridSize, locWinSizeWidth = this._winSize.width; 901 var coords, direction, locPos = cc.p(0, 0); 902 for (var j = 0; j < locGridSize.height; ++j) { 903 locPos.y = j; 904 coords = this.originalTile(locPos); 905 direction = 1; 906 907 if ((j % 2 ) == 0) 908 direction = -1; 909 910 coords.bl.x += direction * locWinSizeWidth * time; 911 coords.br.x += direction * locWinSizeWidth * time; 912 coords.tl.x += direction * locWinSizeWidth * time; 913 coords.tr.x += direction * locWinSizeWidth * time; 914 915 this.setTile(locPos, coords); 916 } 917 }, 918 919 startWithTarget:function (target) { 920 cc.TiledGrid3DAction.prototype.startWithTarget.call(this, target); 921 this._winSize = cc.director.getWinSizeInPixels(); 922 } 923 }); 924 925 /** 926 * creates the action with the number of rows to split and the duration 927 * @param {Number} duration 928 * @param {Number} rows 929 * @return {cc.SplitRows} 930 */ 931 cc.SplitRows.create = function (duration, rows) { 932 var action = new cc.SplitRows(); 933 action.initWithDuration(duration, rows); 934 return action; 935 }; 936 937 /** 938 * cc.SplitCols action 939 * @class 940 * @extends cc.TiledGrid3DAction 941 */ 942 cc.SplitCols = cc.TiledGrid3DAction.extend(/** @lends cc.SplitCols# */{ 943 _cols:0, 944 _winSize:null, 945 946 ctor:function () { 947 cc.GridAction.prototype.ctor.call(this); 948 this._cols = 0; 949 this._winSize = null; 950 }, 951 /** 952 * initializes the action with the number of columns to split and the duration 953 * @param {Number} duration 954 * @param {Number} cols 955 * @return {Boolean} 956 */ 957 initWithDuration:function (duration, cols) { 958 this._cols = cols; 959 return cc.TiledGrid3DAction.prototype.initWithDuration.call(this, duration, cc.size(cols, 1)); 960 }, 961 962 update:function (time) { 963 var locGridSizeWidth = this._gridSize.width, locWinSizeHeight = this._winSize.height; 964 var coords, direction, locPos = cc.p(0, 0); 965 for (var i = 0; i < locGridSizeWidth; ++i) { 966 locPos.x = i; 967 coords = this.originalTile(locPos); 968 direction = 1; 969 970 if ((i % 2 ) == 0) 971 direction = -1; 972 973 coords.bl.y += direction * locWinSizeHeight * time; 974 coords.br.y += direction * locWinSizeHeight * time; 975 coords.tl.y += direction * locWinSizeHeight * time; 976 coords.tr.y += direction * locWinSizeHeight * time; 977 978 this.setTile(locPos, coords); 979 } 980 }, 981 982 /** 983 * @param {cc.Node} target 984 */ 985 startWithTarget:function (target) { 986 cc.TiledGrid3DAction.prototype.startWithTarget.call(this, target); 987 this._winSize = cc.director.getWinSizeInPixels(); 988 } 989 }); 990 991 /** 992 * creates the action with the number of columns to split and the duration 993 * @param {Number} duration 994 * @param {Number} cols 995 * @return {cc.SplitCols} 996 */ 997 cc.SplitCols.create = function (duration, cols) { 998 var action = new cc.SplitCols(); 999 action.initWithDuration(duration, cols); 1000 return action; 1001 };