mirror of
https://github.com/4jcraft/4jcraft.git
synced 2026-04-24 19:53:39 +00:00
# Conflicts: # Minecraft.Client/Network/PlayerChunkMap.cpp # Minecraft.Client/Network/PlayerList.cpp # Minecraft.Client/Network/ServerChunkCache.cpp # Minecraft.Client/Platform/Common/Consoles_App.cpp # Minecraft.Client/Platform/Common/DLC/DLCManager.cpp # Minecraft.Client/Platform/Common/GameRules/LevelGenerationOptions.cpp # Minecraft.Client/Platform/Common/GameRules/LevelRuleset.cpp # Minecraft.Client/Platform/Common/Tutorial/Tutorial.cpp # Minecraft.Client/Platform/Common/Tutorial/TutorialTask.cpp # Minecraft.Client/Platform/Common/UI/IUIScene_CreativeMenu.cpp # Minecraft.Client/Platform/Common/UI/UIComponent_Panorama.cpp # Minecraft.Client/Platform/Common/UI/UIController.cpp # Minecraft.Client/Platform/Common/UI/UIController.h # Minecraft.Client/Platform/Extrax64Stubs.cpp # Minecraft.Client/Platform/Windows64/4JLibs/inc/4J_Input.h # Minecraft.Client/Platform/Windows64/4JLibs/inc/4J_Storage.h # Minecraft.Client/Player/EntityTracker.cpp # Minecraft.Client/Player/ServerPlayer.cpp # Minecraft.Client/Rendering/EntityRenderers/PlayerRenderer.cpp # Minecraft.Client/Textures/Packs/DLCTexturePack.cpp # Minecraft.Client/Textures/Stitching/StitchedTexture.cpp # Minecraft.Client/Textures/Stitching/TextureMap.cpp # Minecraft.Client/Textures/Textures.cpp # Minecraft.World/Blocks/NotGateTile.cpp # Minecraft.World/Blocks/PressurePlateTile.cpp # Minecraft.World/Blocks/TileEntities/PotionBrewing.cpp # Minecraft.World/Enchantments/EnchantmentHelper.cpp # Minecraft.World/Entities/HangingEntity.cpp # Minecraft.World/Entities/LeashFenceKnotEntity.cpp # Minecraft.World/Entities/LivingEntity.cpp # Minecraft.World/Entities/Mobs/Boat.cpp # Minecraft.World/Entities/Mobs/Minecart.cpp # Minecraft.World/Entities/Mobs/Witch.cpp # Minecraft.World/Entities/SyncedEntityData.cpp # Minecraft.World/Items/LeashItem.cpp # Minecraft.World/Items/PotionItem.cpp # Minecraft.World/Level/BaseMobSpawner.cpp # Minecraft.World/Level/CustomLevelSource.cpp # Minecraft.World/Level/Level.cpp # Minecraft.World/Level/Storage/DirectoryLevelStorage.cpp # Minecraft.World/Level/Storage/McRegionLevelStorage.cpp # Minecraft.World/Level/Storage/RegionFileCache.cpp # Minecraft.World/Player/Player.cpp # Minecraft.World/WorldGen/Biomes/BiomeCache.cpp # Minecraft.World/WorldGen/Features/RandomScatteredLargeFeature.cpp # Minecraft.World/WorldGen/Layers/BiomeOverrideLayer.cpp
160 lines
4.8 KiB
C++
160 lines
4.8 KiB
C++
#include "../../Platform/stdafx.h"
|
|
#include "../../Headers/net.minecraft.world.entity.ai.attributes.h"
|
|
#include "ModifiableAttributeInstance.h"
|
|
|
|
ModifiableAttributeInstance::ModifiableAttributeInstance(
|
|
BaseAttributeMap* attributeMap, Attribute* attribute) {
|
|
this->attributeMap = attributeMap;
|
|
this->attribute = attribute;
|
|
|
|
dirty = true;
|
|
cachedValue = 0.0;
|
|
|
|
baseValue = attribute->getDefaultValue();
|
|
}
|
|
|
|
ModifiableAttributeInstance::~ModifiableAttributeInstance() {
|
|
for (int i = 0; i < AttributeModifier::TOTAL_OPERATIONS; i++) {
|
|
for (auto it = modifiers[i].begin(); it != modifiers[i].end();
|
|
++it) {
|
|
// Delete all modifiers
|
|
delete *it;
|
|
}
|
|
}
|
|
}
|
|
|
|
Attribute* ModifiableAttributeInstance::getAttribute() { return attribute; }
|
|
|
|
double ModifiableAttributeInstance::getBaseValue() { return baseValue; }
|
|
|
|
void ModifiableAttributeInstance::setBaseValue(double baseValue) {
|
|
if (baseValue == this->getBaseValue()) return;
|
|
this->baseValue = baseValue;
|
|
setDirty();
|
|
}
|
|
|
|
// Returns a pointer to an internally managed vector of modifers by operation
|
|
std::unordered_set<AttributeModifier*>*
|
|
ModifiableAttributeInstance::getModifiers(int operation) {
|
|
return &modifiers[operation];
|
|
}
|
|
|
|
// Returns a pointer to a new vector of all modifiers
|
|
void ModifiableAttributeInstance::getModifiers(
|
|
std::unordered_set<AttributeModifier*>& result) {
|
|
for (int i = 0; i < AttributeModifier::TOTAL_OPERATIONS; i++) {
|
|
std::unordered_set<AttributeModifier*>* opModifiers = &modifiers[i];
|
|
|
|
for (auto it = opModifiers->begin(); it != opModifiers->end();
|
|
++it) {
|
|
result.insert(*it);
|
|
}
|
|
}
|
|
}
|
|
|
|
AttributeModifier* ModifiableAttributeInstance::getModifier(eMODIFIER_ID id) {
|
|
AttributeModifier* modifier = nullptr;
|
|
|
|
auto it = modifierById.find(id);
|
|
if (it != modifierById.end()) {
|
|
modifier = it->second;
|
|
}
|
|
|
|
return modifier;
|
|
}
|
|
|
|
void ModifiableAttributeInstance::addModifiers(
|
|
std::unordered_set<AttributeModifier*>* modifiers) {
|
|
for (auto it = modifiers->begin(); it != modifiers->end(); ++it) {
|
|
addModifier(*it);
|
|
}
|
|
}
|
|
|
|
// Add new modifier to attribute instance (takes ownership of modifier)
|
|
void ModifiableAttributeInstance::addModifier(AttributeModifier* modifier) {
|
|
// Can't add modifiers with the same ID (unless the modifier is anonymous)
|
|
if (modifier->getId() != eModifierId_ANONYMOUS &&
|
|
getModifier(modifier->getId()) != nullptr) {
|
|
assert(0);
|
|
// throw new IllegalArgumentException("Modifier is already applied on
|
|
// this attribute!");
|
|
return;
|
|
}
|
|
|
|
modifiers[modifier->getOperation()].insert(modifier);
|
|
modifierById[modifier->getId()] = modifier;
|
|
|
|
setDirty();
|
|
}
|
|
|
|
void ModifiableAttributeInstance::setDirty() {
|
|
dirty = true;
|
|
attributeMap->onAttributeModified(this);
|
|
}
|
|
|
|
void ModifiableAttributeInstance::removeModifier(AttributeModifier* modifier) {
|
|
for (int i = 0; i < AttributeModifier::TOTAL_OPERATIONS; i++) {
|
|
for (auto it = modifiers[i].begin(); it != modifiers[i].end();
|
|
++it) {
|
|
if (modifier->equals(*it)) {
|
|
modifiers[i].erase(it);
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
modifierById.erase(modifier->getId());
|
|
|
|
setDirty();
|
|
}
|
|
|
|
void ModifiableAttributeInstance::removeModifier(eMODIFIER_ID id) {
|
|
AttributeModifier* modifier = getModifier(id);
|
|
if (modifier != nullptr) removeModifier(modifier);
|
|
}
|
|
|
|
void ModifiableAttributeInstance::removeModifiers() {
|
|
std::unordered_set<AttributeModifier*> removingModifiers;
|
|
getModifiers(removingModifiers);
|
|
|
|
for (auto it = removingModifiers.begin(); it != removingModifiers.end();
|
|
++it) {
|
|
removeModifier(*it);
|
|
}
|
|
}
|
|
|
|
double ModifiableAttributeInstance::getValue() {
|
|
if (dirty) {
|
|
cachedValue = calculateValue();
|
|
dirty = false;
|
|
}
|
|
|
|
return cachedValue;
|
|
}
|
|
|
|
double ModifiableAttributeInstance::calculateValue() {
|
|
double base = getBaseValue();
|
|
std::unordered_set<AttributeModifier*>* modifiers;
|
|
|
|
modifiers = getModifiers(AttributeModifier::OPERATION_ADDITION);
|
|
for (auto it = modifiers->begin(); it != modifiers->end(); ++it) {
|
|
AttributeModifier* modifier = *it;
|
|
base += modifier->getAmount();
|
|
}
|
|
|
|
double result = base;
|
|
|
|
modifiers = getModifiers(AttributeModifier::OPERATION_MULTIPLY_BASE);
|
|
for (auto it = modifiers->begin(); it != modifiers->end(); ++it) {
|
|
AttributeModifier* modifier = *it;
|
|
result += base * modifier->getAmount();
|
|
}
|
|
|
|
modifiers = getModifiers(AttributeModifier::OPERATION_MULTIPLY_TOTAL);
|
|
for (auto it = modifiers->begin(); it != modifiers->end(); ++it) {
|
|
AttributeModifier* modifier = *it;
|
|
result *= 1 + modifier->getAmount();
|
|
}
|
|
|
|
return attribute->sanitizeValue(result);
|
|
} |