/*
* Copyright 2014 MovingBlocks
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.terasology.logic.behavior.tree;
import org.terasology.rendering.nui.properties.Range;
/**
* Starts the decorated node.<br>
* <br>
* <b>SUCCESS</b>: as soon as decorated node finishes with <b>SUCCESS</b>.<br>
* <b>FAILURE</b>: after x seconds.<br>
* <br>
* Auto generated javadoc - modify README.markdown instead!
*/
public class TimerNode extends DecoratorNode {
@Range(min = 0, max = 20)
private float time;
@Override
public Task createTask() {
return new TimerTask(this);
}
public static class TimerTask extends DecoratorTask {
private float remainingTime;
public TimerTask(Node node) {
super(node);
}
@Override
public void onInitialize() {
remainingTime = getNode().time;
if (getNode().child != null) {
start(getNode().child);
}
}
@Override
public Status update(float dt) {
remainingTime -= dt;
if (remainingTime <= 0) {
return Status.FAILURE;
}
return Status.RUNNING;
}
@Override
public void handle(Status result) {
if (result == Status.SUCCESS) {
stop(result);
}
}
@Override
public TimerNode getNode() {
return (TimerNode) super.getNode();
}
}
}