All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy