v1.1.0: fixed various errors with mass sheep spawning
This commit is contained in:
+9
-1
@@ -27,6 +27,7 @@ import com.shatteredpixel.shatteredpixeldungeon.actors.Actor;
|
|||||||
import com.shatteredpixel.shatteredpixeldungeon.actors.mobs.npcs.Sheep;
|
import com.shatteredpixel.shatteredpixeldungeon.actors.mobs.npcs.Sheep;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.effects.CellEmitter;
|
import com.shatteredpixel.shatteredpixeldungeon.effects.CellEmitter;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.effects.Speck;
|
import com.shatteredpixel.shatteredpixeldungeon.effects.Speck;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.Trap;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.scenes.GameScene;
|
import com.shatteredpixel.shatteredpixeldungeon.scenes.GameScene;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.sprites.ItemSpriteSheet;
|
import com.shatteredpixel.shatteredpixeldungeon.sprites.ItemSpriteSheet;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.utils.BArray;
|
import com.shatteredpixel.shatteredpixeldungeon.utils.BArray;
|
||||||
@@ -34,6 +35,8 @@ import com.watabou.noosa.audio.Sample;
|
|||||||
import com.watabou.utils.PathFinder;
|
import com.watabou.utils.PathFinder;
|
||||||
import com.watabou.utils.Random;
|
import com.watabou.utils.Random;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
|
||||||
public class WoollyBomb extends Bomb {
|
public class WoollyBomb extends Bomb {
|
||||||
|
|
||||||
{
|
{
|
||||||
@@ -45,8 +48,14 @@ public class WoollyBomb extends Bomb {
|
|||||||
super.explode(cell);
|
super.explode(cell);
|
||||||
|
|
||||||
PathFinder.buildDistanceMap( cell, BArray.not( Dungeon.level.solid, null ), 4 );
|
PathFinder.buildDistanceMap( cell, BArray.not( Dungeon.level.solid, null ), 4 );
|
||||||
|
ArrayList<Integer> spawnPoints = new ArrayList<>();
|
||||||
for (int i = 0; i < PathFinder.distance.length; i++) {
|
for (int i = 0; i < PathFinder.distance.length; i++) {
|
||||||
if (PathFinder.distance[i] < Integer.MAX_VALUE) {
|
if (PathFinder.distance[i] < Integer.MAX_VALUE) {
|
||||||
|
spawnPoints.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i : spawnPoints){
|
||||||
if (Dungeon.level.insideMap(i)
|
if (Dungeon.level.insideMap(i)
|
||||||
&& Actor.findChar(i) == null
|
&& Actor.findChar(i) == null
|
||||||
&& !(Dungeon.level.pit[i])) {
|
&& !(Dungeon.level.pit[i])) {
|
||||||
@@ -58,7 +67,6 @@ public class WoollyBomb extends Bomb {
|
|||||||
CellEmitter.get(i).burst(Speck.factory(Speck.WOOL), 4);
|
CellEmitter.get(i).burst(Speck.factory(Speck.WOOL), 4);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
Sample.INSTANCE.play(Assets.Sounds.PUFF);
|
Sample.INSTANCE.play(Assets.Sounds.PUFF);
|
||||||
Sample.INSTANCE.play(Assets.Sounds.SHEEP);
|
Sample.INSTANCE.play(Assets.Sounds.SHEEP);
|
||||||
|
|||||||
+10
-1
@@ -27,6 +27,7 @@ import com.shatteredpixel.shatteredpixeldungeon.actors.Actor;
|
|||||||
import com.shatteredpixel.shatteredpixeldungeon.actors.mobs.npcs.Sheep;
|
import com.shatteredpixel.shatteredpixeldungeon.actors.mobs.npcs.Sheep;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.effects.CellEmitter;
|
import com.shatteredpixel.shatteredpixeldungeon.effects.CellEmitter;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.effects.Speck;
|
import com.shatteredpixel.shatteredpixeldungeon.effects.Speck;
|
||||||
|
import com.shatteredpixel.shatteredpixeldungeon.levels.traps.Trap;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.scenes.GameScene;
|
import com.shatteredpixel.shatteredpixeldungeon.scenes.GameScene;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.sprites.ItemSpriteSheet;
|
import com.shatteredpixel.shatteredpixeldungeon.sprites.ItemSpriteSheet;
|
||||||
import com.shatteredpixel.shatteredpixeldungeon.utils.BArray;
|
import com.shatteredpixel.shatteredpixeldungeon.utils.BArray;
|
||||||
@@ -34,6 +35,8 @@ import com.watabou.noosa.audio.Sample;
|
|||||||
import com.watabou.utils.PathFinder;
|
import com.watabou.utils.PathFinder;
|
||||||
import com.watabou.utils.Random;
|
import com.watabou.utils.Random;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
|
||||||
public class StoneOfFlock extends Runestone {
|
public class StoneOfFlock extends Runestone {
|
||||||
|
|
||||||
{
|
{
|
||||||
@@ -47,8 +50,14 @@ public class StoneOfFlock extends Runestone {
|
|||||||
protected void activate(int cell) {
|
protected void activate(int cell) {
|
||||||
|
|
||||||
PathFinder.buildDistanceMap( cell, BArray.not( Dungeon.level.solid, null ), 2 );
|
PathFinder.buildDistanceMap( cell, BArray.not( Dungeon.level.solid, null ), 2 );
|
||||||
|
ArrayList<Integer> spawnPoints = new ArrayList<>();
|
||||||
for (int i = 0; i < PathFinder.distance.length; i++) {
|
for (int i = 0; i < PathFinder.distance.length; i++) {
|
||||||
if (PathFinder.distance[i] < Integer.MAX_VALUE) {
|
if (PathFinder.distance[i] < Integer.MAX_VALUE) {
|
||||||
|
spawnPoints.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i : spawnPoints){
|
||||||
if (Dungeon.level.insideMap(i)
|
if (Dungeon.level.insideMap(i)
|
||||||
&& Actor.findChar(i) == null
|
&& Actor.findChar(i) == null
|
||||||
&& !(Dungeon.level.pit[i])) {
|
&& !(Dungeon.level.pit[i])) {
|
||||||
@@ -60,7 +69,7 @@ public class StoneOfFlock extends Runestone {
|
|||||||
CellEmitter.get(i).burst(Speck.factory(Speck.WOOL), 4);
|
CellEmitter.get(i).burst(Speck.factory(Speck.WOOL), 4);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
CellEmitter.get(cell).burst(Speck.factory(Speck.WOOL), 4);
|
CellEmitter.get(cell).burst(Speck.factory(Speck.WOOL), 4);
|
||||||
Sample.INSTANCE.play(Assets.Sounds.PUFF);
|
Sample.INSTANCE.play(Assets.Sounds.PUFF);
|
||||||
Sample.INSTANCE.play(Assets.Sounds.SHEEP);
|
Sample.INSTANCE.play(Assets.Sounds.SHEEP);
|
||||||
|
|||||||
+9
-2
@@ -33,6 +33,8 @@ import com.watabou.noosa.audio.Sample;
|
|||||||
import com.watabou.utils.PathFinder;
|
import com.watabou.utils.PathFinder;
|
||||||
import com.watabou.utils.Random;
|
import com.watabou.utils.Random;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
|
||||||
public class FlockTrap extends Trap {
|
public class FlockTrap extends Trap {
|
||||||
|
|
||||||
{
|
{
|
||||||
@@ -44,9 +46,15 @@ public class FlockTrap extends Trap {
|
|||||||
@Override
|
@Override
|
||||||
public void activate() {
|
public void activate() {
|
||||||
PathFinder.buildDistanceMap( pos, BArray.not( Dungeon.level.solid, null ), 2 );
|
PathFinder.buildDistanceMap( pos, BArray.not( Dungeon.level.solid, null ), 2 );
|
||||||
|
ArrayList<Integer> spawnPoints = new ArrayList<>();
|
||||||
for (int i = 0; i < PathFinder.distance.length; i++) {
|
for (int i = 0; i < PathFinder.distance.length; i++) {
|
||||||
Trap t;
|
|
||||||
if (PathFinder.distance[i] < Integer.MAX_VALUE) {
|
if (PathFinder.distance[i] < Integer.MAX_VALUE) {
|
||||||
|
spawnPoints.add(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i : spawnPoints){
|
||||||
|
Trap t;
|
||||||
if (Dungeon.level.insideMap(i)
|
if (Dungeon.level.insideMap(i)
|
||||||
&& Actor.findChar(i) == null
|
&& Actor.findChar(i) == null
|
||||||
&& !(Dungeon.level.pit[i])) {
|
&& !(Dungeon.level.pit[i])) {
|
||||||
@@ -67,6 +75,5 @@ public class FlockTrap extends Trap {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user