/**
* Copyright 2008 - 2012
*
* 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.
*
* @project loon
* @author cping
* @email:javachenpeng@yahoo.com
* @version 0.3.3
*/
package loon.action.sprite.node;
import loon.core.geom.Vector2f;
import loon.utils.MathUtils;
public class LNJumpBy extends LNAction {
LNJumpBy() {
}
protected Vector2f _delta;
protected float _height;
protected int _jumps;
protected Vector2f _orgPos;
public static LNJumpBy Action(float duration, float d, float height,
int jumps) {
return Action(duration, new Vector2f(d, d), height, jumps);
}
public static LNJumpBy Action(float duration, Vector2f delta, float height,
int jumps) {
LNJumpBy by = new LNJumpBy();
by._duration = duration;
by._delta = delta;
by._height = height;
by._jumps = jumps;
return by;
}
public void setTarget(LNNode node) {
super._firstTick = true;
super._isEnd = false;
super._target = node;
this._orgPos = node.getPosition();
}
public void update(float t) {
if (t == 1f) {
super._isEnd = true;
super._target.setPosition(this._delta.x + this._orgPos.x,
this._delta.y + this._orgPos.y);
} else {
float num = this._height
* MathUtils.abs(MathUtils
.sin(((t * 3.141593f) * this._jumps)));
num += this._delta.y * t;
float num2 = this._delta.x * t;
super._target.setPosition(num2 + this._orgPos.x, num
+ this._orgPos.y);
}
}
public LNAction copy() {
return Action(_duration, _delta, _height, _jumps);
}
public LNJumpBy reverse() {
return Action(_duration, _delta.negate(), _height, _jumps);
}
}