v0.2.4: made potions susceptible to cold, refactored a bit of buff logic.

This commit is contained in:
Evan Debenham 2015-02-10 02:09:57 -05:00
parent ae2ba8be0e
commit 72975a49cc
9 changed files with 101 additions and 61 deletions

View File

@ -36,7 +36,6 @@ import com.shatteredpixel.shatteredpixeldungeon.levels.Level;
import com.shatteredpixel.shatteredpixeldungeon.scenes.GameScene; import com.shatteredpixel.shatteredpixeldungeon.scenes.GameScene;
import com.shatteredpixel.shatteredpixeldungeon.ui.BuffIndicator; import com.shatteredpixel.shatteredpixeldungeon.ui.BuffIndicator;
import com.shatteredpixel.shatteredpixeldungeon.utils.GLog; import com.shatteredpixel.shatteredpixeldungeon.utils.GLog;
import com.shatteredpixel.shatteredpixeldungeon.utils.Utils;
import com.watabou.utils.Bundle; import com.watabou.utils.Bundle;
import com.watabou.utils.Random; import com.watabou.utils.Random;
@ -76,24 +75,25 @@ public class Burning extends Buff implements Hero.Doom {
if (target instanceof Hero) { if (target instanceof Hero) {
Item item = ((Hero)target).belongings.randomUnequipped(); Hero hero = (Hero)target;
Item item = hero.belongings.randomUnequipped();
if (item instanceof Scroll) { if (item instanceof Scroll) {
item = item.detach( ((Hero)target).belongings.backpack ); item = item.detach( hero.belongings.backpack );
GLog.w( TXT_BURNS_UP, item.toString() ); GLog.w( TXT_BURNS_UP, item.toString() );
Heap.burnFX( target.pos ); Heap.burnFX( hero.pos );
} else if (item instanceof MysteryMeat) { } else if (item instanceof MysteryMeat) {
item = item.detach( ((Hero)target).belongings.backpack ); item = item.detach( hero.belongings.backpack );
ChargrilledMeat steak = new ChargrilledMeat(); ChargrilledMeat steak = new ChargrilledMeat();
if (!steak.collect( ((Hero)target).belongings.backpack )) { if (!steak.collect( hero.belongings.backpack )) {
Dungeon.level.drop( steak, target.pos ).sprite.drop(); Dungeon.level.drop( steak, hero.pos ).sprite.drop();
} }
GLog.w( TXT_BURNS_UP, item.toString() ); GLog.w( TXT_BURNS_UP, item.toString() );
Heap.burnFX( target.pos ); Heap.burnFX( hero.pos );
} }

View File

@ -20,14 +20,19 @@ package com.shatteredpixel.shatteredpixeldungeon.actors.buffs;
import com.shatteredpixel.shatteredpixeldungeon.Dungeon; import com.shatteredpixel.shatteredpixeldungeon.Dungeon;
import com.shatteredpixel.shatteredpixeldungeon.actors.Char; import com.shatteredpixel.shatteredpixeldungeon.actors.Char;
import com.shatteredpixel.shatteredpixeldungeon.actors.hero.Hero; import com.shatteredpixel.shatteredpixeldungeon.actors.hero.Hero;
import com.shatteredpixel.shatteredpixeldungeon.actors.mobs.Thief;
import com.shatteredpixel.shatteredpixeldungeon.items.Item; import com.shatteredpixel.shatteredpixeldungeon.items.Item;
import com.shatteredpixel.shatteredpixeldungeon.items.food.FrozenCarpaccio; import com.shatteredpixel.shatteredpixeldungeon.items.food.FrozenCarpaccio;
import com.shatteredpixel.shatteredpixeldungeon.items.food.MysteryMeat; import com.shatteredpixel.shatteredpixeldungeon.items.food.MysteryMeat;
import com.shatteredpixel.shatteredpixeldungeon.items.potions.Potion;
import com.shatteredpixel.shatteredpixeldungeon.items.rings.RingOfElements.Resistance; import com.shatteredpixel.shatteredpixeldungeon.items.rings.RingOfElements.Resistance;
import com.shatteredpixel.shatteredpixeldungeon.ui.BuffIndicator; import com.shatteredpixel.shatteredpixeldungeon.ui.BuffIndicator;
import com.shatteredpixel.shatteredpixeldungeon.utils.GLog;
public class Frost extends FlavourBuff { public class Frost extends FlavourBuff {
private static final String TXT_FREEZES = "%s freezes!";
private static final float DURATION = 5f; private static final float DURATION = 5f;
@Override @Override
@ -36,18 +41,35 @@ public class Frost extends FlavourBuff {
target.paralysed = true; target.paralysed = true;
Burning.detach( target, Burning.class ); Burning.detach( target, Burning.class );
if (target instanceof Hero) { if (target instanceof Hero) {
Hero hero = (Hero)target; Hero hero = (Hero)target;
Item item = hero.belongings.randomUnequipped(); Item item = hero.belongings.randomUnequipped();
if (item instanceof MysteryMeat) { if (item instanceof Potion) {
item = item.detach( hero.belongings.backpack );
GLog.w(TXT_FREEZES, item.toString());
((Potion) item).shatter(hero.pos);
} else if (item instanceof MysteryMeat) {
item = item.detach( hero.belongings.backpack ); item = item.detach( hero.belongings.backpack );
FrozenCarpaccio carpaccio = new FrozenCarpaccio(); FrozenCarpaccio carpaccio = new FrozenCarpaccio();
if (!carpaccio.collect( hero.belongings.backpack )) { if (!carpaccio.collect( hero.belongings.backpack )) {
Dungeon.level.drop( carpaccio, target.pos ).sprite.drop(); Dungeon.level.drop( carpaccio, target.pos ).sprite.drop();
} }
GLog.w(TXT_FREEZES, item.toString());
} }
} else if (target instanceof Thief && ((Thief)target).item instanceof Potion) {
((Potion) ((Thief)target).item).shatter( target.pos );
((Thief) target).item = null;
} }
return true; return true;
} else { } else {
return false; return false;

View File

@ -218,10 +218,12 @@ public class Potion extends Item {
shatter( hero.pos ); shatter( hero.pos );
} }
protected void shatter( int cell ) { public void shatter( int cell ) {
GLog.i( "The flask shatters and " + color() + " liquid splashes harmlessly" ); if (Dungeon.visible[cell]) {
Sample.INSTANCE.play( Assets.SND_SHATTER ); GLog.i( "The flask shatters and " + color() + " liquid splashes harmlessly" );
splash( cell ); Sample.INSTANCE.play( Assets.SND_SHATTER );
splash( cell );
}
} }
@Override @Override

View File

@ -35,22 +35,25 @@ public class PotionOfFrost extends Potion {
} }
@Override @Override
protected void shatter( int cell ) { public void shatter( int cell ) {
PathFinder.buildDistanceMap( cell, BArray.not( Level.losBlocking, null ), DISTANCE ); PathFinder.buildDistanceMap( cell, BArray.not( Level.losBlocking, null ), DISTANCE );
Fire fire = (Fire)Dungeon.level.blobs.get( Fire.class ); Fire fire = (Fire)Dungeon.level.blobs.get( Fire.class );
boolean visible = false;
for (int i=0; i < Level.LENGTH; i++) { for (int i=0; i < Level.LENGTH; i++) {
if (PathFinder.distance[i] < Integer.MAX_VALUE) { if (PathFinder.distance[i] < Integer.MAX_VALUE) {
Freezing.affect( i, fire ); visible = Freezing.affect( i, fire ) || visible;
} }
} }
splash( cell ); if (visible) {
Sample.INSTANCE.play( Assets.SND_SHATTER ); splash( cell );
Sample.INSTANCE.play( Assets.SND_SHATTER );
setKnown(); setKnown();
}
} }
@Override @Override

View File

@ -18,6 +18,7 @@
package com.shatteredpixel.shatteredpixeldungeon.items.potions; package com.shatteredpixel.shatteredpixeldungeon.items.potions;
import com.shatteredpixel.shatteredpixeldungeon.Assets; import com.shatteredpixel.shatteredpixeldungeon.Assets;
import com.shatteredpixel.shatteredpixeldungeon.Dungeon;
import com.shatteredpixel.shatteredpixeldungeon.actors.blobs.Blob; import com.shatteredpixel.shatteredpixeldungeon.actors.blobs.Blob;
import com.shatteredpixel.shatteredpixeldungeon.actors.blobs.ConfusionGas; import com.shatteredpixel.shatteredpixeldungeon.actors.blobs.ConfusionGas;
import com.shatteredpixel.shatteredpixeldungeon.actors.buffs.Buff; import com.shatteredpixel.shatteredpixeldungeon.actors.buffs.Buff;
@ -34,14 +35,16 @@ public class PotionOfLevitation extends Potion {
} }
@Override @Override
protected void shatter( int cell ) { public void shatter( int cell ) {
setKnown(); if (Dungeon.visible[cell]) {
setKnown();
splash( cell ); splash( cell );
Sample.INSTANCE.play( Assets.SND_SHATTER ); Sample.INSTANCE.play( Assets.SND_SHATTER );
}
GameScene.add( Blob.seed( cell, 1000, ConfusionGas.class ) ); GameScene.add( Blob.seed( cell, 1000, ConfusionGas.class ) );
} }
@Override @Override

View File

@ -17,6 +17,7 @@
*/ */
package com.shatteredpixel.shatteredpixeldungeon.items.potions; package com.shatteredpixel.shatteredpixeldungeon.items.potions;
import com.shatteredpixel.shatteredpixeldungeon.Dungeon;
import com.watabou.noosa.audio.Sample; import com.watabou.noosa.audio.Sample;
import com.shatteredpixel.shatteredpixeldungeon.Assets; import com.shatteredpixel.shatteredpixeldungeon.Assets;
import com.shatteredpixel.shatteredpixeldungeon.actors.blobs.Blob; import com.shatteredpixel.shatteredpixeldungeon.actors.blobs.Blob;
@ -30,15 +31,16 @@ public class PotionOfLiquidFlame extends Potion {
} }
@Override @Override
protected void shatter( int cell ) { public void shatter( int cell ) {
setKnown(); if (Dungeon.visible[cell]) {
setKnown();
splash( cell ); splash( cell );
Sample.INSTANCE.play( Assets.SND_SHATTER ); Sample.INSTANCE.play( Assets.SND_SHATTER );
}
Fire fire = Blob.seed( cell, 2, Fire.class ); GameScene.add( Blob.seed( cell, 2, Fire.class ) );
GameScene.add( fire );
} }
@Override @Override

View File

@ -17,6 +17,7 @@
*/ */
package com.shatteredpixel.shatteredpixeldungeon.items.potions; package com.shatteredpixel.shatteredpixeldungeon.items.potions;
import com.shatteredpixel.shatteredpixeldungeon.Dungeon;
import com.watabou.noosa.audio.Sample; import com.watabou.noosa.audio.Sample;
import com.shatteredpixel.shatteredpixeldungeon.Assets; import com.shatteredpixel.shatteredpixeldungeon.Assets;
import com.shatteredpixel.shatteredpixeldungeon.actors.blobs.Blob; import com.shatteredpixel.shatteredpixeldungeon.actors.blobs.Blob;
@ -30,12 +31,14 @@ public class PotionOfParalyticGas extends Potion {
} }
@Override @Override
protected void shatter( int cell ) { public void shatter( int cell ) {
setKnown(); if (Dungeon.visible[cell]) {
setKnown();
splash( cell ); splash( cell );
Sample.INSTANCE.play( Assets.SND_SHATTER ); Sample.INSTANCE.play( Assets.SND_SHATTER );
}
GameScene.add( Blob.seed( cell, 1000, ParalyticGas.class ) ); GameScene.add( Blob.seed( cell, 1000, ParalyticGas.class ) );
} }

View File

@ -47,7 +47,7 @@ public class PotionOfPurity extends Potion {
} }
@Override @Override
protected void shatter( int cell ) { public void shatter( int cell ) {
PathFinder.buildDistanceMap( cell, BArray.not( Level.losBlocking, null ), DISTANCE ); PathFinder.buildDistanceMap( cell, BArray.not( Level.losBlocking, null ), DISTANCE );
@ -77,7 +77,9 @@ public class PotionOfPurity extends Potion {
blob.volume -= value; blob.volume -= value;
procd = true; procd = true;
CellEmitter.get( i ).burst( Speck.factory( Speck.DISCOVER ), 1 ); if (Dungeon.visible[i]) {
CellEmitter.get( i ).burst( Speck.factory( Speck.DISCOVER ), 1 );
}
} }
} }
@ -88,8 +90,10 @@ public class PotionOfPurity extends Potion {
if (procd) { if (procd) {
splash( cell ); if (Dungeon.visible[cell]) {
Sample.INSTANCE.play( Assets.SND_SHATTER ); splash( cell );
Sample.INSTANCE.play( Assets.SND_SHATTER );
}
setKnown(); setKnown();

View File

@ -17,6 +17,7 @@
*/ */
package com.shatteredpixel.shatteredpixeldungeon.items.potions; package com.shatteredpixel.shatteredpixeldungeon.items.potions;
import com.shatteredpixel.shatteredpixeldungeon.Dungeon;
import com.watabou.noosa.audio.Sample; import com.watabou.noosa.audio.Sample;
import com.shatteredpixel.shatteredpixeldungeon.Assets; import com.shatteredpixel.shatteredpixeldungeon.Assets;
import com.shatteredpixel.shatteredpixeldungeon.actors.Actor; import com.shatteredpixel.shatteredpixeldungeon.actors.Actor;
@ -31,16 +32,16 @@ public class PotionOfToxicGas extends Potion {
} }
@Override @Override
protected void shatter( int cell ) { public void shatter( int cell ) {
setKnown(); if (Dungeon.visible[cell]) {
setKnown();
splash( cell ); splash( cell );
Sample.INSTANCE.play( Assets.SND_SHATTER ); Sample.INSTANCE.play( Assets.SND_SHATTER );
}
ToxicGas gas = Blob.seed( cell, 1000, ToxicGas.class ); GameScene.add( Blob.seed( cell, 1000, ToxicGas.class ) );
Actor.add( gas );
GameScene.add( gas );
} }
@Override @Override