Attack speed overclocking, improve research builder

This commit is contained in:
DBotThePony 2021-08-23 14:52:12 +07:00
parent 899723eeb5
commit 3098a08d6e
Signed by: DBot
GPG Key ID: DCC23B5715498507
5 changed files with 66 additions and 24 deletions

View File

@ -2,6 +2,7 @@ package ru.dbotthepony.mc.otm;
import net.minecraft.client.gui.screens.MenuScreens; import net.minecraft.client.gui.screens.MenuScreens;
import net.minecraft.network.chat.TextComponent; import net.minecraft.network.chat.TextComponent;
import net.minecraft.network.chat.TranslatableComponent;
import net.minecraft.resources.ResourceLocation; import net.minecraft.resources.ResourceLocation;
import net.minecraft.world.damagesource.DamageSource; import net.minecraft.world.damagesource.DamageSource;
import net.minecraft.world.food.FoodProperties; import net.minecraft.world.food.FoodProperties;
@ -381,6 +382,8 @@ public class Registry {
.setExperienceCost(24 + i * 8) .setExperienceCost(24 + i * 8)
.withIconText(new TextComponent(String.valueOf(i + 1))) .withIconText(new TextComponent(String.valueOf(i + 1)))
.withIcon(ICON_LIMB_OVERCLOCKING) .withIcon(ICON_LIMB_OVERCLOCKING)
.withName(new TranslatableComponent("android_research.overdrive_that_matters.limb_overclocking", i + 1))
.withDescription(new TranslatableComponent("android_research.overdrive_that_matters.limb_overclocking.description", (i + 1) * 8, (i + 1) * 6))
.addFeatureResult(Names.LIMB_OVERCLOCKING, i); .addFeatureResult(Names.LIMB_OVERCLOCKING, i);
if (i > 0) { if (i > 0) {

View File

@ -56,15 +56,29 @@ public abstract class AndroidResearch implements INBTSerializable<CompoundTag> {
return null; return null;
} }
public Component getDisplayName() {
return type.getDisplayName();
}
public List<Component> getTooltip() { public List<Component> getTooltip() {
return List.of(type.getDisplayName()); return List.of(getDisplayName());
}
public boolean canResearch() {
for (var preq : getPrerequisites()) {
if (!capability.getResearch(preq).isResearched()) {
return false;
}
}
return canAfford();
} }
public boolean research(boolean force) { public boolean research(boolean force) {
if (researched) if (researched)
return false; return false;
if (!force && !canAfford()) if (!force && !canResearch())
return false; return false;
consumeCost(); consumeCost();
@ -121,6 +135,8 @@ public abstract class AndroidResearch implements INBTSerializable<CompoundTag> {
public int experience = 0; public int experience = 0;
public Component text; public Component text;
public boolean has_description = false; public boolean has_description = false;
public Component custom_description;
public Component custom_name;
public final ArrayList<DeferredItemStack> items = new ArrayList<>(); public final ArrayList<DeferredItemStack> items = new ArrayList<>();
public final ArrayList<ResourceLocation> prerequisites = new ArrayList<>(); public final ArrayList<ResourceLocation> prerequisites = new ArrayList<>();
public final ArrayList<DeferredFeature> feature_results = new ArrayList<>(); public final ArrayList<DeferredFeature> feature_results = new ArrayList<>();
@ -176,6 +192,17 @@ public abstract class AndroidResearch implements INBTSerializable<CompoundTag> {
return this; return this;
} }
public Builder withDescription(Component text) {
this.has_description = true;
this.custom_description = text;
return this;
}
public Builder withName(Component text) {
this.custom_name = text;
return this;
}
public Builder withIcon(SkinElement icon) { public Builder withIcon(SkinElement icon) {
this.icon = icon; this.icon = icon;
return this; return this;
@ -232,8 +259,17 @@ public abstract class AndroidResearch implements INBTSerializable<CompoundTag> {
public AndroidResearchType.AndroidResearchFactory<AndroidResearch> build() { public AndroidResearchType.AndroidResearchFactory<AndroidResearch> build() {
return (type, capability) -> { return (type, capability) -> {
resolve(); resolve();
final var list_cp = List.copyOf(resolved_preq);
return new AndroidResearch(type, capability) { return new AndroidResearch(type, capability) {
@Override
public Component getDisplayName() {
if (custom_name != null)
return custom_name;
return super.getDisplayName();
}
@Nullable @Nullable
@Override @Override
public SkinElement getIcon() { public SkinElement getIcon() {
@ -250,7 +286,9 @@ public abstract class AndroidResearch implements INBTSerializable<CompoundTag> {
public List<Component> getTooltip() { public List<Component> getTooltip() {
var list = new ArrayList<>(super.getTooltip()); var list = new ArrayList<>(super.getTooltip());
if (has_description) { if (custom_description != null) {
list.add(custom_description);
} else if (has_description) {
list.add(new TranslatableComponent("android_research." + type.getRegistryName().getNamespace() + "." + type.getRegistryName().getPath() + ".description")); list.add(new TranslatableComponent("android_research." + type.getRegistryName().getNamespace() + "." + type.getRegistryName().getPath() + ".description"));
} }
@ -295,7 +333,7 @@ public abstract class AndroidResearch implements INBTSerializable<CompoundTag> {
@Override @Override
public List<AndroidResearchType<?>> getPrerequisites() { public List<AndroidResearchType<?>> getPrerequisites() {
return List.copyOf(resolved_preq); return list_cp;
} }
@Override @Override
@ -314,12 +352,6 @@ public abstract class AndroidResearch implements INBTSerializable<CompoundTag> {
@Override @Override
public boolean canAfford() { public boolean canAfford() {
for (var preq : resolved_preq) {
if (!capability.getResearch(preq).isResearched()) {
return false;
}
}
if (capability.ply.experienceLevel < experience) if (capability.ply.experienceLevel < experience)
return false; return false;

View File

@ -9,7 +9,7 @@ import ru.dbotthepony.mc.otm.capability.IAndroidCapability;
import java.util.UUID; import java.util.UUID;
public class AndroidLimbOverclocking extends AndroidFeature { public class AndroidLimbOverclocking extends AndroidFeature {
public static final UUID MODIFIER_NAME = UUID.fromString("4a3fae46-e57b-4e20-857d-f5c2b2c8f2f2"); public static final UUID MODIFIER_ID = UUID.fromString("4a3fae46-e57b-4e20-857d-f5c2b2c8f2f2");
public AndroidLimbOverclocking(AndroidFeatureType<?> type, IAndroidCapability capability) { public AndroidLimbOverclocking(AndroidFeatureType<?> type, IAndroidCapability capability) {
super(type, capability); super(type, capability);
@ -20,8 +20,15 @@ public class AndroidLimbOverclocking extends AndroidFeature {
var speed = capability.getEntity().getAttribute(Attributes.MOVEMENT_SPEED); var speed = capability.getEntity().getAttribute(Attributes.MOVEMENT_SPEED);
if (speed != null) { if (speed != null) {
speed.removePermanentModifier(MODIFIER_NAME); speed.removePermanentModifier(MODIFIER_ID);
speed.addPermanentModifier(new AttributeModifier(MODIFIER_NAME, type.getDisplayName().toString(), 0.08d * (level + 1), AttributeModifier.Operation.MULTIPLY_TOTAL)); speed.addPermanentModifier(new AttributeModifier(MODIFIER_ID, type.getDisplayName().toString(), 0.08d * (level + 1), AttributeModifier.Operation.MULTIPLY_TOTAL));
}
var attack_speed = capability.getEntity().getAttribute(Attributes.ATTACK_SPEED);
if (attack_speed != null) {
attack_speed.removePermanentModifier(MODIFIER_ID);
attack_speed.addPermanentModifier(new AttributeModifier(MODIFIER_ID, type.getDisplayName().toString(), 0.06d * (level + 1), AttributeModifier.Operation.MULTIPLY_TOTAL));
} }
} }
@ -30,7 +37,13 @@ public class AndroidLimbOverclocking extends AndroidFeature {
var speed = capability.getEntity().getAttribute(Attributes.MOVEMENT_SPEED); var speed = capability.getEntity().getAttribute(Attributes.MOVEMENT_SPEED);
if (speed != null) { if (speed != null) {
speed.removePermanentModifier(MODIFIER_NAME); speed.removePermanentModifier(MODIFIER_ID);
}
var attack_speed = capability.getEntity().getAttribute(Attributes.ATTACK_SPEED);
if (attack_speed != null) {
attack_speed.removePermanentModifier(MODIFIER_ID);
} }
} }
} }

View File

@ -37,7 +37,7 @@ public class AndroidStationScreen extends MatteryScreen<AndroidStationMenu> {
if (_cap instanceof AndroidCapabilityPlayer cap) { if (_cap instanceof AndroidCapabilityPlayer cap) {
if (node.isResearched()) { if (node.isResearched()) {
RESEARCHED.setSystemColor(); RESEARCHED.setSystemColor();
} else if (node.canAfford()) { } else if (node.canResearch()) {
CAN_BE_RESEARCHED.setSystemColor(); CAN_BE_RESEARCHED.setSystemColor();
} else { } else {
CAN_NOT_BE_RESEARCHED.setSystemColor(); CAN_NOT_BE_RESEARCHED.setSystemColor();
@ -73,7 +73,7 @@ public class AndroidStationScreen extends MatteryScreen<AndroidStationMenu> {
if (node.isResearched()) { if (node.isResearched()) {
list.add(new TranslatableComponent("otm.android_station.research.researched").withStyle(ChatFormatting.DARK_AQUA)); list.add(new TranslatableComponent("otm.android_station.research.researched").withStyle(ChatFormatting.DARK_AQUA));
} else if (node.canAfford()) { } else if (node.canResearch()) {
list.add(new TranslatableComponent("otm.android_station.research.can_be_researched").withStyle(ChatFormatting.DARK_GREEN)); list.add(new TranslatableComponent("otm.android_station.research.can_be_researched").withStyle(ChatFormatting.DARK_GREEN));
} else { } else {
list.add(new TranslatableComponent("otm.android_station.research.can_not_be_researched").withStyle(ChatFormatting.DARK_RED)); list.add(new TranslatableComponent("otm.android_station.research.can_not_be_researched").withStyle(ChatFormatting.DARK_RED));

View File

@ -49,15 +49,9 @@
"android_feature.overdrive_that_matters.limb_overclocking_3": "Limb overclocking 3", "android_feature.overdrive_that_matters.limb_overclocking_3": "Limb overclocking 3",
"android_feature.overdrive_that_matters.limb_overclocking_4": "Limb overclocking 4", "android_feature.overdrive_that_matters.limb_overclocking_4": "Limb overclocking 4",
"android_research.overdrive_that_matters.limb_overclocking_1": "Limb overclocking 1", "android_research.overdrive_that_matters.limb_overclocking": "Limb overclocking %s",
"android_research.overdrive_that_matters.limb_overclocking_2": "Limb overclocking 2",
"android_research.overdrive_that_matters.limb_overclocking_3": "Limb overclocking 3",
"android_research.overdrive_that_matters.limb_overclocking_4": "Limb overclocking 4",
"android_research.overdrive_that_matters.limb_overclocking_1.description": "Boosts unit mobility by 8%% and attack speed by 4%%", "android_research.overdrive_that_matters.limb_overclocking.description": "Boosts unit mobility by %s%% and attack speed by %s%%",
"android_research.overdrive_that_matters.limb_overclocking_2.description": "Boosts unit mobility by 16%% and attack speed by 8%%",
"android_research.overdrive_that_matters.limb_overclocking_3.description": "Boosts unit mobility by 24%% and attack speed by 12%%",
"android_research.overdrive_that_matters.limb_overclocking_4.description": "Boosts unit mobility by 32%% and attack speed by 16%%",
"android_research.overdrive_that_matters.air_bags": "Air bags", "android_research.overdrive_that_matters.air_bags": "Air bags",
"android_research.overdrive_that_matters.air_bags.description": "Allows unit to swim in water", "android_research.overdrive_that_matters.air_bags.description": "Allows unit to swim in water",