com.artemis.BaseSystem Maven / Gradle / Ivy
package com.artemis;
public abstract class BaseSystem {
/** The world this system belongs to. */
protected World world;
/** If the system is passive or not. */
boolean passive;
/** If the system is enabled or not. */
boolean enabled = true;
public BaseSystem() {}
/**
* Called before system processing begins.
*
* Nota Bene: Any entities created in this method
* won't become active until the next system starts processing
* or when a new processing rounds begins, whichever comes first.
*
*/
protected void begin() {}
public final void process() {
if(enabled && checkProcessing()) {
begin();
processSystem();
end();
}
}
/**
* Any implementing entity system must implement this method.
*/
protected abstract void processSystem();
/**
* Called after the systems has finished processing.
*/
protected void end() {}
/**
* Check if the system should be processed.
*
* @return true if the system should be processed, false if not.
*/
@SuppressWarnings("static-method")
protected boolean checkProcessing() {
return true;
}
/**
* Override to implement code that gets executed when systems are
* initialized.
*/
protected void initialize() {}
/**
* Returns true if the system is enabled.
*
* @return {@code true} if enabled, otherwise false
*/
public boolean isEnabled() {
return enabled;
}
/**
* Enabled systems are run during {@link #process()}.
*
* Systems are enabled by default.
*
*
* @param enabled
* system will not run when set to false
*/
public void setEnabled(boolean enabled) {
this.enabled = enabled;
}
/**
* Set the world this manager works on.
*
* @param world
* the world to set
*/
protected void setWorld(World world) {
this.world = world;
}
/**
* Check if this system is passive.
*
* A passive system will not process when {@link com.artemis.World#process()}
* is called.
*
*
* @return {@code true} if the system is passive
*/
public boolean isPassive() {
return passive;
}
/**
* Set if the system is passive or not.
*
* A passive system will not process when {@link com.artemis.World#process()}
* is called.
*
*
* @param passive
* {@code true} if passive, {@code false} if not
*/
protected void setPassive(boolean passive) {
this.passive = passive;
}
/**
* see {@link World#dispose()}
*/
protected void dispose() {}
/**
* Creates a flyweight entity, not registered by the world
* the way normal entities are. It is intended to be used
* for cases where storing full object entity references aren't
* desirable, in the interest of reducing memory footprint
* and/or maintaining a clean API.
*
* You are expected to manually set the entity id before
* operating on the entity. It is created with id == -1.
*
* @return Unbound entity with entityId -1.
*/
protected final Entity createFlyweightEntity() {
return Entity.createFlyweight(world);
}
}