public override void RunEvent(EventManager callingEventManager) { if (!nextToTree) { if (seekingTree) { focusElement.SetStatusMessage("Couldn't get to a tree"); //reset on success seekingTree = false; this.SetComplete(); } else { //check if next to tree Vector2 testLocation = new Vector2(-1, -1); for (int i = 0; i < 4; i++) { if (i == 0) { testLocation = new Vector2(focusElement.getWorldPositionX() + 1, focusElement.getWorldPositionY()); } if (i == 1) { testLocation = new Vector2(focusElement.getWorldPositionX() - 1, focusElement.getWorldPositionY()); } if (i == 2) { testLocation = new Vector2(focusElement.getWorldPositionX(), focusElement.getWorldPositionY() + 1); } if (i == 3) { testLocation = new Vector2(focusElement.getWorldPositionX(), focusElement.getWorldPositionY() - 1); } if (associatedMap.checkOccupied(testLocation, "Tree")) { nextToTree = true; treeLocation.X = testLocation.X; treeLocation.Y = testLocation.Y; } } } //if not, find tree if (!nextToTree) { seekingTree = true; Vector2 treeToTarget = associatedMap.FindNearestPathable(focusElement.getWorldPositionVector(), "Tree", true); //check if a real tree was found if (treeToTarget.X == -1 && treeToTarget.Y == -1) { //couldn't find a tree focusElement.SetStatusMessage("Can't see any trees!"); this.SetComplete(); } else { EventMoveTo movingEvent = new EventMoveTo(associatedGame, associatedMap, focusElement, treeToTarget, gameTime); if (focusElement.Moving()) { focusElement.ReplaceLinkedMovement(movingEvent); associatedEventManager.AddEvent(movingEvent); this.Suspend(movingEvent); } else { focusElement.LinkToMoveEvent(movingEvent); associatedEventManager.AddEvent(movingEvent); this.Suspend(movingEvent); } } } } else { focusElement.SetStatusMessage("Getting ready to harvest tree"); //hit tree if (associatedMap.getOccupied(treeLocation)) { //success, reset retry counter if (associatedMap.getOccupyingElement(treeLocation).GetElementName() == "Tree") { associatedMap.getOccupyingElement(treeLocation).UpdateCurrentHealth(1); if (associatedMap.getOccupyingElement(treeLocation).currentHealth <= 0) { //Tree is out of HP - generate the logs associatedMap.setOccupyingElement(treeLocation, new woodResourceElement(associatedGame, (int)treeLocation.X, (int)treeLocation.Y, (treeElement)associatedMap.getOccupyingElement(treeLocation))); this.SetComplete(); } } else { this.SetComplete(); } } else { this.SetComplete(); } } }