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

com.artemis.managers.GroupManager Maven / Gradle / Ivy

package com.artemis.managers;

import java.util.HashMap;
import java.util.Map;

import com.artemis.Entity;
import com.artemis.Manager;
import com.artemis.utils.Bag;
import com.artemis.utils.ImmutableBag;


/**
 * If you need to group your entities together, e.g tanks going into "units"
 * group or explosions into "effects", then use this manager.
 * 

* You must retrieve it using world instance. *

* A entity can be assigned to more than one group. *

* * @author Arni Arent */ public class GroupManager extends Manager { private static final ImmutableBag EMPTY_BAG = new Bag(); /** All entities and groups mapped with group names as key. */ private final Map> entitiesByGroup; /** All entities and groups mapped with entities as key. */ private final Map> groupsByEntity; private Entity flyweight; /** * Creates a new GroupManager instance. */ public GroupManager() { entitiesByGroup = new HashMap>(); groupsByEntity = new HashMap>(); } @Override protected void initialize() { flyweight = Entity.createFlyweight(world); } /** * Set the group of the entity. * * @param group * group to add the entity into * @param e * entity to add into the group */ public void add(Entity e, String group) { Bag entities = entitiesByGroup.get(group); if(entities == null) { entities = new Bag(); entitiesByGroup.put(group, entities); } if (!entities.contains(e)) entities.add(e); Bag groups = groupsByEntity.get(e); if(groups == null) { groups = new Bag(); groupsByEntity.put(e, groups); } if (!groups.contains(group)) groups.add(group); } /** * Remove the entity from the specified group. * * @param e * entity to remove from group * @param group * group to remove the entity from */ public void remove(Entity e, String group) { Bag entities = entitiesByGroup.get(group); if(entities != null) { entities.remove(e); } Bag groups = groupsByEntity.get(e); if(groups != null) { groups.remove(group); if (groups.size() == 0) groupsByEntity.remove(e); } } /** * Remove the entity from all groups. * * @param e * the entity to remove */ public void removeFromAllGroups(Entity e) { Bag groups = groupsByEntity.get(e); if(groups == null) return; for(int i = 0, s = groups.size(); s > i; i++) { Bag entities = entitiesByGroup.get(groups.get(i)); if(entities != null) { entities.remove(world.getEntity(e.id)); } } groupsByEntity.remove(e); } /** * Get all entities that belong to the provided group. * * @param group * name of the group * * @return read-only bag of entities belonging to the group */ public ImmutableBag getEntities(String group) { Bag entities = entitiesByGroup.get(group); if(entities == null) { entities = new Bag(); entitiesByGroup.put(group, entities); } return entities; } /** * Get all groups the entity belongs to. An empty Bag is returned * if the entity doesn't belong to any groups. * * @param e * the entity * * @return the groups the entity belongs to. */ public ImmutableBag getGroups(Entity e) { Bag groups = groupsByEntity.get(e); return groups != null ? groups : EMPTY_BAG; } /** * Checks if the entity belongs to any group. * * @param e * the entity to check * * @return true. if it is in any group, false if none */ public boolean isInAnyGroup(Entity e) { return getGroups(e).size() > 0; } /** * Check if the entity is in the supplied group. * * @param group * the group to check in * @param e * the entity to check for * * @return true if the entity is in the supplied group, false if not */ public boolean isInGroup(Entity e, String group) { if(group != null) { Bag bag = groupsByEntity.get(e); if (bag != null) { Object[] groups = bag.getData(); for(int i = 0, s = bag.size(); s > i; i++) { String g = (String)groups[i]; if(group.equals(g)) { return true; } } } } return false; } /** * Removes the entity from all groups. * * @param entityId * the deleted entity */ @Override public void deleted(int entityId) { flyweight.id = entityId; removeFromAllGroups(flyweight); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy