Downloads containing ab24btl08.j2as

Downloads
Name Author Game Mode Rating
TSF with JJ2+ Only: Anniversary Bash 24 Battle PurpleJazz Battle N/A Download file

File preview

  1. uint spreadShotCountdown = 0;
  2. uint R = 125;
  3. uint G = 220;
  4. uint B = 250;
  5. uint light = 100;
  6.  
  7. #pragma require "BubbleGun.j2a"
  8.  
  9. void onLevelLoad() {
  10.         jjObjectPresets[OBJECT::ELECTROBULLETPU].eventID = OBJECT::ELECTROBULLET;
  11.         jjLayerOrderSet(array<jjLAYER@> = {jjLayers[3], jjLayers[4], jjLayers[1], jjLayers[5], jjLayers[6], jjLayers[2], jjLayers[7], jjLayers[8]});
  12.         jjWeapons[WEAPON::GUN8].spread = SPREAD::NORMAL;
  13.         jjWeapons[WEAPON::GUN9].allowed = true;
  14.         jjWeapons[WEAPON::GUN9].allowedPowerup = true;
  15.        
  16.         jjObjectPresets[OBJECT::CHIPS].scriptedCollisions = true;
  17.         jjObjectPresets[OBJECT::CHIPS].behavior = SpreadShot();
  18.        
  19.         jjAnimSets[ANIM::CUSTOM[0]].load(0, "BubbleGun.j2a");
  20.         jjAnimSets[ANIM::CUSTOM[1]].load(1, "BubbleGun.j2a");
  21.         jjAnimSets[ANIM::CUSTOM[2]].load(2, "BubbleGun.j2a");
  22.         jjAnimations[jjAnimSets[ANIM::AMMO] + 29] = jjAnimations[jjAnimSets[ANIM::AMMO] + 8];
  23.         jjAnimations[jjAnimSets[ANIM::AMMO] + 28] = jjAnimations[jjAnimSets[ANIM::CUSTOM[0]] + 0];
  24.        
  25.         jjObjectPresets[OBJECT::ICEBULLET].special = jjObjectPresets[OBJECT::ICEBULLET].determineCurAnim(ANIM::AMMO, 8);
  26.         jjObjectPresets[OBJECT::ICEBULLET].behavior = BubbleGun;
  27.         jjObjectPresets[OBJECT::ICEBULLET].xSpeed = 2;
  28.         jjObjectPresets[OBJECT::ICEBULLET].counterEnd = 105;
  29.         jjObjectPresets[OBJECT::ICEBULLET].var[6] = 0;
  30.         jjObjectPresets[OBJECT::ICEBULLET].freeze = 0;
  31.         jjObjectPresets[OBJECT::ICEBULLET].lightType = jjObjectPresets[OBJECT::BLASTERBULLET].lightType;
  32.  
  33.         jjObjectPresets[OBJECT::ICEBULLETPU].special = jjObjectPresets[OBJECT::ICEBULLETPU].determineCurAnim(ANIM::CUSTOM[0], 0);
  34.         jjObjectPresets[OBJECT::ICEBULLETPU].behavior = BubbleGunPU;
  35.         jjObjectPresets[OBJECT::ICEBULLETPU].xSpeed = 3;
  36.         jjObjectPresets[OBJECT::ICEBULLETPU].counterEnd = 105;
  37.         jjObjectPresets[OBJECT::ICEBULLETPU].var[6] = 0;
  38.         jjObjectPresets[OBJECT::ICEBULLETPU].freeze = 0;
  39.         jjObjectPresets[OBJECT::ICEBULLETPU].lightType = jjObjectPresets[OBJECT::BLASTERBULLET].lightType;
  40.        
  41.         jjObjectPresets[OBJECT::ICEPOWERUP].determineCurAnim(ANIM::CUSTOM[1], 0, true);
  42.        
  43.         jjWeapons[WEAPON::ICE].spread = SPREAD::NORMAL;
  44.         jjWeapons[WEAPON::ICE].defaultSample = false;
  45.        
  46.         jjANIMATION@ anim = jjAnimations[jjAnimSets[ANIM::AMMO] + 8];
  47.                 for (uint j = 0; j < anim.frameCount; j++) {
  48.                         jjANIMFRAME@ frame = jjAnimFrames[anim + j];
  49.                         jjPIXELMAP sprite(frame);
  50.                         for (uint x = 0; x < sprite.width; ++x) {
  51.                                 for (uint y = 0; y < sprite.height; ++y) {
  52.                                         if (sprite[x,y] >= 32 && sprite[x,y] <= 39) sprite[x,y] -= 8;
  53.                                 }
  54.                         }
  55.                         sprite.save(frame);
  56.                 }
  57.        
  58.         jjANIMATION@ anim2 = jjAnimations[jjAnimSets[ANIM::CUSTOM[0]] + 0];
  59.                 for (uint j = 0; j < anim2.frameCount; j++) {
  60.                         jjANIMFRAME@ frame2 = jjAnimFrames[anim2 + j];
  61.                         jjPIXELMAP sprite2(frame2);
  62.                         for (uint x = 0; x < sprite2.width; ++x) {
  63.                                 for (uint y = 0; y < sprite2.height; ++y) {
  64.                                         if (sprite2[x,y] >= 80 && sprite2[x,y] <= 87) sprite2[x,y] -= 40;
  65.                                 }
  66.                         }
  67.                         sprite2.save(frame2);
  68.                 }
  69.                
  70.         jjANIMATION@ anim3 = jjAnimations[jjAnimSets[ANIM::CUSTOM[1]] + 0];
  71.                 for (uint j = 0; j < anim3.frameCount; j++) {
  72.                         jjANIMFRAME@ frame3 = jjAnimFrames[anim3 + j];
  73.                         jjPIXELMAP sprite3(frame3);
  74.                         for (uint x = 0; x < sprite3.width; ++x) {
  75.                                 for (uint y = 0; y < sprite3.height; ++y) {
  76.                                         if (sprite3[x,y] >= 80 && sprite3[x,y] <= 87) sprite3[x,y] -= 40;
  77.                                 }
  78.                         }
  79.                         sprite3.save(frame3);
  80.                 }
  81.         generateCustomSpringSprites(jjAnimSets[ANIM::CUSTOM[0]], array<uint> = {64});
  82.         turnIntoCustomSpring(jjObjectPresets[OBJECT::FROZENSPRING], 0, 34.f, false);
  83. }
  84.  
  85. void resetSpread() {
  86.         jjWeapons[WEAPON::BLASTER].spread = SPREAD::NORMAL;
  87.         jjWeapons[WEAPON::BOUNCER].spread = SPREAD::NORMAL;
  88.         jjWeapons[WEAPON::ICE].spread = SPREAD::ICE;
  89.         jjWeapons[WEAPON::SEEKER].spread = SPREAD::NORMAL;
  90.         jjWeapons[WEAPON::RF].spread = SPREAD::RF;
  91.         jjWeapons[WEAPON::TNT].spread = SPREAD::NORMAL;
  92.         jjWeapons[WEAPON::TOASTER].spread = SPREAD::TOASTER;
  93.         jjWeapons[WEAPON::GUN8].spread = SPREAD::NORMAL;
  94.         jjWeapons[WEAPON::GUN9].spread = SPREAD::NORMAL;
  95. }
  96.  
  97. uint16 angle = 0;
  98.  
  99. void onPlayer(jjPLAYER@ p) {
  100. handleFastCustomSpringSpeeds(p);
  101.        
  102.         p.lightType = LIGHT::NONE;
  103.         p.lighting = light;
  104.  
  105.  
  106.         p.powerup[9] = true;
  107.         if (spreadShotCountdown > 0 && jjGameTicks % 70 == 0) {
  108.                 spreadShotCountdown--;
  109.                 if (spreadShotCountdown == 0) {
  110.                         resetSpread();
  111.                 }
  112.         }
  113.         else if (spreadShotCountdown == 15) {
  114.                 for (uint i = 1; i <= 9; i++) {
  115.                         jjWeapons[i].spread = SPREAD::RFPU;
  116.                 }  
  117.         }
  118.         if (spreadShotCountdown > 0) {
  119.                 jjTEXTAPPEARANCE normal(STRING::NORMAL);
  120.                
  121.                 int x = int(p.cameraX);
  122.                 int y = int(p.cameraY);
  123.                
  124.                 jjDrawSprite(x + jjResolutionWidth - 72, y + jjResolutionHeight - 270, ANIM::PICKUPS, 87, jjGameTicks >> 2, 0, SPRITE::NORMAL, 0, 1);
  125.                 jjDrawString(x + jjResolutionWidth - 55, y + jjResolutionHeight - 274, "" + spreadShotCountdown, STRING::MEDIUM, normal, 0, SPRITE::PALSHIFT, 0, 1);
  126.         }
  127.         if (p.health == 0) {
  128.                 spreadShotCountdown == 0;
  129.                 resetSpread();
  130.         }
  131.         angle += 12;
  132.  
  133. }
  134.  
  135. class SpreadShot : jjBEHAVIORINTERFACE {
  136.         void onBehave(jjOBJ@ obj) {
  137.                 obj.behave(BEHAVIOR::PICKUP, false);
  138.                 obj.light = 12;
  139.                 obj.lightType = LIGHT::BRIGHT;
  140.                         obj.xPos=obj.xOrg+0*jjSin(-jjGameTicks*5+int(obj.xOrg)*32/3);
  141.                         obj.yPos=obj.yOrg+0*jjCos(-jjGameTicks*5+int(obj.xOrg)*32/3);   }
  142.         void onDraw(jjOBJ@ obj) {
  143.                 jjDrawRotatedSprite(obj.xPos, obj.yPos + 10, ANIM::AMMO, 37, jjGameTicks >> 2, angle, 1, 1, SPRITE::NORMAL, 0, 1);
  144.                 jjDrawRotatedSprite(obj.xPos, obj.yPos, ANIM::AMMO, 37, jjGameTicks >> 2, angle, 1, 1, SPRITE::NORMAL, 0, 1);
  145.                 jjDrawRotatedSprite(obj.xPos, obj.yPos - 10, ANIM::AMMO, 37, jjGameTicks >> 2, angle, 1, 1, SPRITE::NORMAL, 0, 1);
  146.         }
  147.         bool onObjectHit(jjOBJ@ obj, jjOBJ@ bullet, jjPLAYER@ p, int force) {
  148.                 obj.bulletHandling = HANDLING::IGNOREBULLET;
  149.                 obj.behavior = BEHAVIOR::EXPLOSION2;
  150.                 obj.scriptedCollisions = false;
  151.                 obj.frameID = 0;
  152.                 if (p.isLocal) spreadShotCountdown = 15;
  153.                 jjSamplePriority(SOUND::COMMON_PICKUP1);
  154.                 return true;
  155.         }
  156. }
  157.  
  158. void BubbleGun(jjOBJ@ bubble) {
  159.     if (bubble.state == STATE::START) {
  160.                 bubble.state = STATE::FLY;
  161.                 if (jjPlayers[bubble.creatorID].isLocal) jjSample(bubble.xPos, bubble.yPos, SOUND::COMMON_PLOP2, 0, 0);
  162.         }
  163.        
  164.         if (bubble.state == STATE::FLY) jjDrawSpriteFromCurFrame(bubble.xPos, bubble.yPos, bubble.curFrame, bubble.direction, SPRITE::NORMAL);
  165.        
  166.         if (jjMaskedPixel(int(bubble.xPos) + int(bubble.xSpeed), int(bubble.yPos)) || jjMaskedPixel(int(bubble.xPos) - int(bubble.xSpeed), int(bubble.yPos)) || jjMaskedPixel(int(bubble.xPos), int(bubble.yPos) + int(bubble.ySpeed)) || jjMaskedPixel(int(bubble.xPos), int(bubble.yPos) - int(bubble.ySpeed))) {
  167.                 jjSample(bubble.xPos, bubble.yPos, SOUND::P2_SPLOUT, 0, 0);
  168.         }
  169.        
  170.         bubble.behave(BEHAVIOR::WATERSHIELDBULLET, false);
  171.        
  172.         if (bubble.state == STATE::FLY && bubble.counter > 0) {
  173.                 switch (bubble.direction) {
  174.                         case 1: bubble.xSpeed = bubble.xSpeed - 0.04; bubble.ySpeed = bubble.ySpeed - 0.04; break;
  175.                         case -1: bubble.xSpeed = bubble.xSpeed + 0.04; bubble.ySpeed = bubble.ySpeed - 0.04; break;
  176.                 }
  177.         }
  178.        
  179.         bubble.killAnim = jjObjectPresets[OBJECT::WATERSHIELDBULLET].killAnim;
  180. }
  181.  
  182. void BubbleGunPU(jjOBJ@ bubble) {
  183.         if (bubble.state == STATE::START) {
  184.                 bubble.state = STATE::FLY;
  185.                 if (jjPlayers[bubble.creatorID].isLocal) jjSample(bubble.xPos, bubble.yPos, SOUND::COMMON_PLOP2, 0, 0);
  186.         }
  187.        
  188.         if (bubble.state == STATE::FLY) jjDrawSpriteFromCurFrame(bubble.xPos, bubble.yPos, bubble.curFrame, bubble.direction, SPRITE::NORMAL);
  189.  
  190.         if (jjMaskedPixel(int(bubble.xPos) + int(bubble.xSpeed), int(bubble.yPos)) || jjMaskedPixel(int(bubble.xPos) - int(bubble.xSpeed), int(bubble.yPos)) || jjMaskedPixel(int(bubble.xPos), int(bubble.yPos) + int(bubble.ySpeed)) || jjMaskedPixel(int(bubble.xPos), int(bubble.yPos) - int(bubble.ySpeed))) {
  191.                 jjSample(bubble.xPos, bubble.yPos, SOUND::P2_SPLOUT, 0, 0);
  192.         }
  193.        
  194.         bubble.behave(BEHAVIOR::WATERSHIELDBULLET, false);
  195.        
  196.         if (bubble.state == STATE::FLY && bubble.counter > 0) {
  197.                 switch (bubble.direction) {
  198.                         case 1: bubble.xSpeed = bubble.xSpeed - 0.1; bubble.ySpeed = bubble.ySpeed - 0.08; break;
  199.                         case -1: bubble.xSpeed = bubble.xSpeed + 0.1; bubble.ySpeed = bubble.ySpeed - 0.08; break;
  200.                 }
  201.         }
  202.        
  203.         bubble.killAnim = jjObjectPresets[OBJECT::WATERSHIELDBULLET].killAnim;
  204. }
  205.  
  206.  
  207.  
  208. jjANIMSET@ customSpringSprite;
  209. array<int> fastCustomSpringSpeeds(jjLocalPlayerCount);
  210. bool generateCustomSpringSprites(jjANIMSET@ anim, const array<uint> &in colors) {
  211.         int length = colors.length();
  212.         bool success = (@customSpringSprite = anim).allocate(array<uint>(length * 3, 5)) !is null;
  213.         if (success) {
  214.                 uint srcSet = jjAnimSets[ANIM::SPRING];
  215.                 for (int i = 0; i < length; i++) {
  216.                         uint color = colors[i];
  217.                         uint destAnimOffset = anim + i * 3;
  218.                         for (int j = 0; j < 3; j++) {
  219.                                 uint srcAnim = jjAnimations[srcSet + j];
  220.                                 uint destAnim = jjAnimations[destAnimOffset + j];
  221.                                 for (int k = 0; k < 5; k++) {
  222.                                         jjPIXELMAP image(jjAnimFrames[destAnim + k] = jjAnimFrames[srcAnim + k]);
  223.                                         int width = image.width;
  224.                                         int height = image.height;
  225.                                         for (int l = 0; l < height; l++) {
  226.                                                 for (int m = 0; m < width; m++) {
  227.                                                         int pixel = image[m, l];
  228.                                                         if (pixel >= 32 && pixel < 40)
  229.                                                                 image[m, l] = color + (pixel & 7);
  230.                                                 }
  231.                                         }
  232.                                         if (!image.save(jjAnimFrames[destAnim + k]))
  233.                                                 return false;
  234.                                 }
  235.                         }
  236.                 }
  237.         }
  238.         return success;
  239. }
  240. void initializeCustomSpring(jjOBJ@ obj) {
  241.         int anim = obj.curAnim;
  242.         obj.behave(obj.behavior = BEHAVIOR::SPRING, false);
  243.         if (obj.curAnim != anim) {
  244.                 obj.curAnim = anim + 2;
  245.                 obj.determineCurFrame();
  246.         }
  247.         obj.draw();
  248. }
  249. void turnIntoCustomSpring(jjOBJ@ obj, uint color, float power, bool horizontal) {
  250.         if (horizontal) {
  251.                 obj.xSpeed = power;
  252.                 obj.ySpeed = 0.f;
  253.         } else {
  254.                 obj.xSpeed = 0.f;
  255.                 obj.ySpeed = -power;
  256.                 if (obj.state == STATE::START && obj.creatorType == CREATOR::LEVEL) {
  257.                         int x = int(obj.xPos) >> 5;
  258.                         int y = int(obj.yPos) >> 5;
  259.                         if (jjParameterGet(x, y, 0, 1) != 0) {
  260.                                 jjParameterSet(x, y, 0, 1, 0);
  261.                                 obj.yPos -= 4.f;
  262.                                 obj.ySpeed = power;
  263.                         }
  264.                 }
  265.         }
  266.         obj.behavior = initializeCustomSpring;
  267.         obj.curAnim = customSpringSprite + color * 3 + (horizontal ? 1 : 0);
  268.         obj.energy = obj.frameID = obj.freeze = obj.justHit = obj.light = obj.points = 0;
  269.         obj.causesRicochet = obj.isBlastable = obj.isTarget = obj.scriptedCollisions = obj.triggersTNT = false;
  270.         obj.deactivates = obj.isFreezable = true;
  271.         obj.bulletHandling = HANDLING::IGNOREBULLET;
  272.         obj.playerHandling = HANDLING::SPECIAL;
  273.         obj.lightType = LIGHT::NORMAL;
  274.         obj.determineCurFrame();
  275. }
  276. void handleFastCustomSpringSpeeds(jjPLAYER@ player) {
  277.         if (player.ySpeed < -32.f) {
  278.                 fastCustomSpringSpeeds[player.localPlayerID] = int(ceil((player.ySpeed + 30.f) / -0.125f));
  279.         } else if (fastCustomSpringSpeeds[player.localPlayerID] != 0) {
  280.                 if (player.ySpeed < -31.f) {
  281.                         fastCustomSpringSpeeds[player.localPlayerID]--;
  282.                         player.ySpeed = -64.f;
  283.                 } else {
  284.                         fastCustomSpringSpeeds[player.localPlayerID] = 0;
  285.                 }
  286.         }
  287. }
  288.  
  289.