mirror of
https://github.com/Anuken/Mindustry.git
synced 2025-02-06 00:49:14 +07:00
249 lines
10 KiB
Java
249 lines
10 KiB
Java
package mindustry.content;
|
|
|
|
import mindustry.ctype.*;
|
|
import mindustry.game.Objectives.*;
|
|
import mindustry.maps.generators.*;
|
|
import mindustry.type.*;
|
|
|
|
import static arc.struct.Array.with;
|
|
import static mindustry.content.Items.*;
|
|
import static mindustry.content.Planets.starter;
|
|
import static mindustry.type.ItemStack.list;
|
|
|
|
public class Zones implements ContentList{
|
|
public static SectorPreset
|
|
groundZero, desertWastes,
|
|
craters, frozenForest, ruinousShores, stainedMountains, tarFields, fungalPass,
|
|
saltFlats, overgrowth, impact0078, crags,
|
|
desolateRift, nuclearComplex;
|
|
|
|
@Override
|
|
public void load(){
|
|
|
|
groundZero = new SectorPreset("groundZero", starter, new FileMapGenerator("groundZero")){{
|
|
baseLaunchCost = list(copper, -60);
|
|
startingItems = list(copper, 60);
|
|
alwaysUnlocked = true;
|
|
conditionWave = 5;
|
|
launchPeriod = 5;
|
|
resources = with(copper, scrap, lead);
|
|
}};
|
|
|
|
//TODO remove
|
|
/*
|
|
desertWastes = new Zone("desertWastes", starter, new FileMapGenerator("groundZero")){{
|
|
startingItems = list(copper, 120);
|
|
conditionWave = 20;
|
|
launchPeriod = 10;
|
|
loadout = Loadouts.advancedShard;
|
|
resources = with(copper, lead, coal, sand);
|
|
rules = r -> {
|
|
r.waves = true;
|
|
r.waveTimer = true;
|
|
r.launchWaveMultiplier = 3f;
|
|
r.waveSpacing = 60 * 50f;
|
|
r.spawns = with(
|
|
new SpawnGroup(UnitTypes.crawler){{
|
|
unitScaling = 3f;
|
|
}},
|
|
new SpawnGroup(UnitTypes.dagger){{
|
|
unitScaling = 4f;
|
|
begin = 2;
|
|
spacing = 2;
|
|
}},
|
|
new SpawnGroup(UnitTypes.wraith){{
|
|
unitScaling = 3f;
|
|
begin = 11;
|
|
spacing = 3;
|
|
}},
|
|
new SpawnGroup(UnitTypes.eruptor){{
|
|
unitScaling = 3f;
|
|
begin = 22;
|
|
unitAmount = 1;
|
|
spacing = 4;
|
|
}},
|
|
new SpawnGroup(UnitTypes.titan){{
|
|
unitScaling = 3f;
|
|
begin = 37;
|
|
unitAmount = 2;
|
|
spacing = 4;
|
|
}},
|
|
new SpawnGroup(UnitTypes.fortress){{
|
|
unitScaling = 2f;
|
|
effect = StatusEffects.boss;
|
|
begin = 41;
|
|
spacing = 20;
|
|
}}
|
|
);
|
|
};
|
|
requirements = with(
|
|
new ZoneWave(groundZero, 20),
|
|
new Unlock(Blocks.combustionGenerator)
|
|
);
|
|
}};*/
|
|
|
|
saltFlats = new SectorPreset("saltFlats", starter, new FileMapGenerator("saltFlats")){{
|
|
startingItems = list(copper, 200, Items.silicon, 200, lead, 200);
|
|
loadout = Loadouts.basicFoundation;
|
|
conditionWave = 10;
|
|
launchPeriod = 5;
|
|
configureObjective = new Launched(this);
|
|
resources = with(copper, scrap, lead, coal, sand, titanium);
|
|
requirements = with(
|
|
new ZoneWave(desertWastes, 60),
|
|
//new Unlock(Blocks.daggerFactory),
|
|
//new Unlock(Blocks.draugFactory),
|
|
new Unlock(Blocks.door),
|
|
new Unlock(Blocks.waterExtractor)
|
|
);
|
|
}};
|
|
|
|
frozenForest = new SectorPreset("frozenForest", starter, new FileMapGenerator("frozenForest")){{
|
|
loadout = Loadouts.basicFoundation;
|
|
startingItems = list(copper, 250);
|
|
conditionWave = 10;
|
|
resources = with(copper, lead, coal);
|
|
requirements = with(
|
|
new ZoneWave(groundZero, 10),
|
|
new Unlock(Blocks.junction),
|
|
new Unlock(Blocks.router)
|
|
);
|
|
}};
|
|
|
|
craters = new SectorPreset("craters", starter, new FileMapGenerator("craters")){{
|
|
startingItems = list(copper, 100);
|
|
conditionWave = 10;
|
|
resources = with(copper, lead, coal, sand, scrap);
|
|
requirements = with(
|
|
new ZoneWave(frozenForest, 10),
|
|
new Unlock(Blocks.mender),
|
|
new Unlock(Blocks.combustionGenerator)
|
|
);
|
|
}};
|
|
|
|
ruinousShores = new SectorPreset("ruinousShores", starter, new FileMapGenerator("ruinousShores")){{
|
|
loadout = Loadouts.basicFoundation;
|
|
startingItems = list(copper, 140, lead, 50);
|
|
conditionWave = 20;
|
|
launchPeriod = 20;
|
|
resources = with(copper, scrap, lead, coal, sand);
|
|
requirements = with(
|
|
new ZoneWave(desertWastes, 20),
|
|
new ZoneWave(craters, 15),
|
|
new Unlock(Blocks.graphitePress),
|
|
new Unlock(Blocks.combustionGenerator),
|
|
new Unlock(Blocks.kiln),
|
|
new Unlock(Blocks.mechanicalPump)
|
|
);
|
|
}};
|
|
|
|
stainedMountains = new SectorPreset("stainedMountains", starter, new FileMapGenerator("stainedMountains")){{
|
|
loadout = Loadouts.basicFoundation;
|
|
startingItems = list(copper, 200, lead, 50);
|
|
conditionWave = 10;
|
|
launchPeriod = 10;
|
|
resources = with(copper, scrap, lead, coal, titanium, sand);
|
|
requirements = with(
|
|
new ZoneWave(frozenForest, 15),
|
|
new Unlock(Blocks.pneumaticDrill),
|
|
new Unlock(Blocks.powerNode),
|
|
new Unlock(Blocks.turbineGenerator)
|
|
);
|
|
}};
|
|
|
|
fungalPass = new SectorPreset("fungalPass", starter, new FileMapGenerator("fungalPass")){{
|
|
startingItems = list(copper, 250, lead, 250, Items.metaglass, 100, Items.graphite, 100);
|
|
resources = with(copper, lead, coal, titanium, sand);
|
|
configureObjective = new Launched(this);
|
|
requirements = with(
|
|
new ZoneWave(stainedMountains, 15),
|
|
//new Unlock(Blocks.daggerFactory),
|
|
//new Unlock(Blocks.crawlerFactory),
|
|
new Unlock(Blocks.door),
|
|
new Unlock(Blocks.siliconSmelter)
|
|
);
|
|
}};
|
|
|
|
overgrowth = new SectorPreset("overgrowth", starter, new FileMapGenerator("overgrowth")){{
|
|
startingItems = list(copper, 1500, lead, 1000, Items.silicon, 500, Items.metaglass, 250);
|
|
conditionWave = 12;
|
|
launchPeriod = 4;
|
|
loadout = Loadouts.basicNucleus;
|
|
configureObjective = new Launched(this);
|
|
resources = with(copper, lead, coal, titanium, sand, thorium, scrap);
|
|
requirements = with(
|
|
new ZoneWave(craters, 40),
|
|
new Launched(fungalPass),
|
|
new Unlock(Blocks.cultivator),
|
|
new Unlock(Blocks.sporePress)
|
|
//new Unlock(Blocks.titanFactory),
|
|
//new Unlock(Blocks.wraithFactory)
|
|
);
|
|
}};
|
|
|
|
tarFields = new SectorPreset("tarFields", starter, new FileMapGenerator("tarFields")){{
|
|
loadout = Loadouts.basicFoundation;
|
|
startingItems = list(copper, 250, lead, 100);
|
|
conditionWave = 15;
|
|
launchPeriod = 10;
|
|
resources = with(copper, scrap, lead, coal, titanium, thorium, sand);
|
|
requirements = with(
|
|
new ZoneWave(ruinousShores, 20),
|
|
new Unlock(Blocks.coalCentrifuge),
|
|
new Unlock(Blocks.conduit),
|
|
new Unlock(Blocks.wave)
|
|
);
|
|
}};
|
|
|
|
desolateRift = new SectorPreset("desolateRift", starter, new FileMapGenerator("desolateRift")){{
|
|
loadout = Loadouts.basicNucleus;
|
|
startingItems = list(copper, 1000, lead, 1000, Items.graphite, 250, titanium, 250, Items.silicon, 250);
|
|
conditionWave = 3;
|
|
launchPeriod = 2;
|
|
resources = with(copper, scrap, lead, coal, titanium, sand, thorium);
|
|
requirements = with(
|
|
new ZoneWave(tarFields, 20),
|
|
new Unlock(Blocks.thermalGenerator),
|
|
new Unlock(Blocks.thoriumReactor)
|
|
);
|
|
}};
|
|
|
|
/*
|
|
crags = new Zone("crags", new MapGenerator("crags").dist(2f)){{
|
|
loadout = Loadouts.basicFoundation;
|
|
baseLaunchCost = ItemStack.with();
|
|
startingItems = ItemStack.list(Items.copper, 2000, Items.lead, 2000, Items.graphite, 500, Items.titanium, 500, Items.silicon, 500);
|
|
conditionWave = 3;
|
|
launchPeriod = 2;
|
|
requirements = with(stainedMountains, 40);
|
|
blockRequirements = new Block[]{Blocks.thermalGenerator};
|
|
resources = Array.with(Items.copper, Items.scrap, Items.lead, Items.coal, Items.sand};
|
|
}};*/
|
|
|
|
nuclearComplex = new SectorPreset("nuclearComplex", starter, new FileMapGenerator("nuclearProductionComplex")){{
|
|
loadout = Loadouts.basicNucleus;
|
|
startingItems = list(copper, 1250, lead, 1500, Items.silicon, 400, Items.metaglass, 250);
|
|
conditionWave = 30;
|
|
launchPeriod = 15;
|
|
resources = with(copper, scrap, lead, coal, titanium, thorium, sand);
|
|
requirements = with(
|
|
new Launched(fungalPass),
|
|
new Unlock(Blocks.thermalGenerator),
|
|
new Unlock(Blocks.laserDrill)
|
|
);
|
|
}};
|
|
|
|
/*
|
|
impact0078 = new Zone("impact0078", new MapGenerator("impact0078").dist(2f)){{
|
|
loadout = Loadouts.basicNucleus;
|
|
baseLaunchCost = ItemStack.with();
|
|
startingItems = ItemStack.list(Items.copper, 2000, Items.lead, 2000, Items.graphite, 500, Items.titanium, 500, Items.silicon, 500);
|
|
conditionWave = 3;
|
|
launchPeriod = 2;
|
|
requirements = with(nuclearComplex, 40);
|
|
blockRequirements = new Block[]{Blocks.thermalGenerator};
|
|
resources = Array.with(Items.copper, Items.scrap, Items.lead, Items.coal, Items.titanium, Items.thorium};
|
|
}};*/
|
|
}
|
|
}
|