mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-09 03:43:40 +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.Material;
|
||||
import org.bukkit.attribute.Attributable;
|
||||
import org.bukkit.block.Block;
|
||||
import org.bukkit.inventory.EntityEquipment;
|
||||
import org.bukkit.potion.PotionEffect;
|
||||
|
@ -16,7 +17,7 @@ import org.bukkit.projectiles.ProjectileSource;
|
|||
/**
|
||||
* 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.
|
||||
|
|
Loading…
Reference in a new issue