mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-10 03:52:45 +01:00
Add Attribute and AttributeModifier API.
Thanks to __0x277F and Meeh on #spigot-dev for implementation advice. By: md_5 <git@md-5.net>
This commit is contained in:
parent
128ff503e9
commit
95de3820b4
5 changed files with 229 additions and 1 deletions
|
@ -0,0 +1,16 @@
|
||||||
|
package org.bukkit.attribute;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Represents an object which may contain attributes.
|
||||||
|
*/
|
||||||
|
public interface Attributable {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the specified attribute instance from the object. This instance will
|
||||||
|
* be backed directly to the object and any changes will be visible at once.
|
||||||
|
*
|
||||||
|
* @param attribute the attribute to get
|
||||||
|
* @return the attribute instance or null if not applicable to this object
|
||||||
|
*/
|
||||||
|
AttributeInstance getAttribute(Attribute attribute);
|
||||||
|
}
|
48
paper-api/src/main/java/org/bukkit/attribute/Attribute.java
Normal file
48
paper-api/src/main/java/org/bukkit/attribute/Attribute.java
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
package org.bukkit.attribute;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Types of attributes which may be present on an {@link Attributable}.
|
||||||
|
*/
|
||||||
|
public enum Attribute {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Maximum health of an Entity.
|
||||||
|
*/
|
||||||
|
GENERIC_MAX_HEALTH,
|
||||||
|
/**
|
||||||
|
* Range at which an Entity will follow others.
|
||||||
|
*/
|
||||||
|
GENERIC_FOLLOW_RANGE,
|
||||||
|
/**
|
||||||
|
* Resistance of an Entity to knockback.
|
||||||
|
*/
|
||||||
|
GENERIC_KNOCKBACK_RESISTANCE,
|
||||||
|
/**
|
||||||
|
* Movement speed of an Entity.
|
||||||
|
*/
|
||||||
|
GENERIC_MOVEMENT_SPEED,
|
||||||
|
/**
|
||||||
|
* Attack damage of an Entity.
|
||||||
|
*/
|
||||||
|
GENERIC_ATTACK_DAMAGE,
|
||||||
|
/**
|
||||||
|
* Attack speed of an Entity.
|
||||||
|
*/
|
||||||
|
GENERIC_ATTACK_SPEED,
|
||||||
|
/**
|
||||||
|
* Armor bonus of an Entity.
|
||||||
|
*/
|
||||||
|
GENERIC_ARMOR,
|
||||||
|
/**
|
||||||
|
* Luck bonus of an Entity.
|
||||||
|
*/
|
||||||
|
GENERIC_LUCK,
|
||||||
|
/**
|
||||||
|
* Strength with which a horse will jump.
|
||||||
|
*/
|
||||||
|
HORSE_JUMP_STRENGTH,
|
||||||
|
/**
|
||||||
|
* Chance of a zombie to spawn reinforcements.
|
||||||
|
*/
|
||||||
|
ZOMBIE_SPAWN_REINFORCEMENTS;
|
||||||
|
}
|
|
@ -0,0 +1,60 @@
|
||||||
|
package org.bukkit.attribute;
|
||||||
|
|
||||||
|
import java.util.Collection;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Represents a mutable instance of an attribute and its associated modifiers
|
||||||
|
* and values.
|
||||||
|
*/
|
||||||
|
public interface AttributeInstance {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The attribute pertaining to this instance.
|
||||||
|
*
|
||||||
|
* @return the attribute
|
||||||
|
*/
|
||||||
|
Attribute getAttribute();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Base value of this instance before modifiers are applied.
|
||||||
|
*
|
||||||
|
* @return base value
|
||||||
|
*/
|
||||||
|
double getBaseValue();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the base value of this instance.
|
||||||
|
*
|
||||||
|
* @param value new base value
|
||||||
|
*/
|
||||||
|
void setBaseValue(double value);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get all modifiers present on this instance.
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
Collection<AttributeModifier> getModifiers();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add a modifier to this instance.
|
||||||
|
*
|
||||||
|
* @param modifier to add
|
||||||
|
*/
|
||||||
|
void addModifier(AttributeModifier modifier);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove a modifier from this instance.
|
||||||
|
*
|
||||||
|
* @param modifier to remove
|
||||||
|
*/
|
||||||
|
void removeModifier(AttributeModifier modifier);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the value of this instance after all associated modifiers have been
|
||||||
|
* applied.
|
||||||
|
*
|
||||||
|
* @return the total attribute value
|
||||||
|
*/
|
||||||
|
double getValue();
|
||||||
|
}
|
|
@ -0,0 +1,103 @@
|
||||||
|
package org.bukkit.attribute;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.UUID;
|
||||||
|
import org.apache.commons.lang.Validate;
|
||||||
|
import org.bukkit.configuration.serialization.ConfigurationSerializable;
|
||||||
|
import org.bukkit.util.NumberConversions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Concrete implementation of an attribute modifier.
|
||||||
|
*/
|
||||||
|
public class AttributeModifier implements ConfigurationSerializable {
|
||||||
|
|
||||||
|
private final UUID uuid;
|
||||||
|
private final String name;
|
||||||
|
private final double amount;
|
||||||
|
private final Operation operation;
|
||||||
|
|
||||||
|
public AttributeModifier(String name, double amount, Operation operation) {
|
||||||
|
this(UUID.randomUUID(), name, amount, operation);
|
||||||
|
}
|
||||||
|
|
||||||
|
public AttributeModifier(UUID uuid, String name, double amount, Operation operation) {
|
||||||
|
Validate.notNull(uuid, "uuid");
|
||||||
|
Validate.notEmpty(name, "Name cannot be empty");
|
||||||
|
Validate.notNull(operation, "operation");
|
||||||
|
|
||||||
|
this.uuid = uuid;
|
||||||
|
this.name = name;
|
||||||
|
this.amount = amount;
|
||||||
|
this.operation = operation;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the unique ID for this modifier.
|
||||||
|
*
|
||||||
|
* @return unique id
|
||||||
|
*/
|
||||||
|
public UUID getUniqueId() {
|
||||||
|
return uuid;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the name of this modifier.
|
||||||
|
*
|
||||||
|
* @return name
|
||||||
|
*/
|
||||||
|
public String getName() {
|
||||||
|
return name;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the amount by which this modifier will apply its {@link Operation}.
|
||||||
|
*
|
||||||
|
* @return modification amount
|
||||||
|
*/
|
||||||
|
public double getAmount() {
|
||||||
|
return amount;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the operation this modifier will apply.
|
||||||
|
*
|
||||||
|
* @return operation
|
||||||
|
*/
|
||||||
|
public Operation getOperation() {
|
||||||
|
return operation;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Map<String, Object> serialize() {
|
||||||
|
Map<String, Object> data = new HashMap<String, Object>();
|
||||||
|
data.put("uuid", uuid);
|
||||||
|
data.put("name", name);
|
||||||
|
data.put("operation", operation.ordinal());
|
||||||
|
data.put("amount", amount);
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static AttributeModifier deserialize(Map<String, Object> args) {
|
||||||
|
return new AttributeModifier((UUID) args.get("uuid"), (String) args.get("name"), NumberConversions.toDouble(args.get("amount")), Operation.values()[NumberConversions.toInt(args.get("operation"))]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Enumerable operation to be applied.
|
||||||
|
*/
|
||||||
|
public enum Operation {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds (or subtracts) the specified amount to the base value.
|
||||||
|
*/
|
||||||
|
ADD_NUMBER,
|
||||||
|
/**
|
||||||
|
* Adds this scalar of amount to the base value.
|
||||||
|
*/
|
||||||
|
ADD_SCALAR,
|
||||||
|
/**
|
||||||
|
* Multiply amount by this value, after adding 1 to it.
|
||||||
|
*/
|
||||||
|
MULTIPLY_SCALAR_1;
|
||||||
|
}
|
||||||
|
}
|
|
@ -7,6 +7,7 @@ import java.util.Set;
|
||||||
|
|
||||||
import org.bukkit.Location;
|
import org.bukkit.Location;
|
||||||
import org.bukkit.Material;
|
import org.bukkit.Material;
|
||||||
|
import org.bukkit.attribute.Attributable;
|
||||||
import org.bukkit.block.Block;
|
import org.bukkit.block.Block;
|
||||||
import org.bukkit.inventory.EntityEquipment;
|
import org.bukkit.inventory.EntityEquipment;
|
||||||
import org.bukkit.potion.PotionEffect;
|
import org.bukkit.potion.PotionEffect;
|
||||||
|
@ -16,7 +17,7 @@ import org.bukkit.projectiles.ProjectileSource;
|
||||||
/**
|
/**
|
||||||
* Represents a living entity, such as a monster or player
|
* Represents a living entity, such as a monster or player
|
||||||
*/
|
*/
|
||||||
public interface LivingEntity extends Entity, Damageable, ProjectileSource {
|
public interface LivingEntity extends Attributable, Entity, Damageable, ProjectileSource {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the height of the living entity's eyes above its Location.
|
* Gets the height of the living entity's eyes above its Location.
|
||||||
|
|
Loading…
Reference in a new issue