X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;ds=sidebyside;f=org.simantics.g3d%2Fsrc%2Forg%2Fsimantics%2Fproconf%2Fg3d%2Fanimation%2FSlerpInterpolator.java;fp=org.simantics.g3d%2Fsrc%2Forg%2Fsimantics%2Fproconf%2Fg3d%2Fanimation%2FSlerpInterpolator.java;h=f6c1913f6ca54903d654edc46bf75a7fae90b477;hb=10f144a2bb2d7bec98b812b83acecb333fd098ea;hp=0000000000000000000000000000000000000000;hpb=3055b543aa5afc0cca4bb3b341704e7c5103fa6a;p=simantics%2F3d.git diff --git a/org.simantics.g3d/src/org/simantics/proconf/g3d/animation/SlerpInterpolator.java b/org.simantics.g3d/src/org/simantics/proconf/g3d/animation/SlerpInterpolator.java new file mode 100644 index 00000000..f6c1913f --- /dev/null +++ b/org.simantics.g3d/src/org/simantics/proconf/g3d/animation/SlerpInterpolator.java @@ -0,0 +1,47 @@ +/******************************************************************************* + * Copyright (c) 2007- VTT Technical Research Centre of Finland. + * All rights reserved. This program and the accompanying materials + * are made available under the terms of the Eclipse Public License v1.0 + * which accompanies this distribution, and is available at + * http://www.eclipse.org/legal/epl-v10.html + * + * Contributors: + * VTT Technical Research Centre of Finland - initial API and implementation + *******************************************************************************/ +package org.simantics.proconf.g3d.animation; + +import javax.vecmath.Quat4d; + +import org.simantics.proconf.g3d.base.VecmathJmeTools; + + +import com.jme.scene.Node; + +import org.simantics.animation.curve.SlerpCurve; + + +public class SlerpInterpolator implements Interpolator{ + private SlerpCurve curve; + + //private TransformGroup group; + //private Transform3D transform; + private Node node = null; + + public SlerpInterpolator(SlerpCurve curve) { + this.curve = curve; + //transform = new Transform3D(); + } + + public void interpolate(double delta) { + Quat4d q = curve.evaluate(delta); + //transform.set(new Quat4f(q)); + //group.setTransform(transform); + node.setLocalRotation(VecmathJmeTools.get(q)); + } + + public void setTarget(Object target) { + //group = (TransformGroup)target; + node = (Node)target; + } + +}