package org.jboss.errai.demo.mobile.client.local;
import org.jboss.errai.demo.mobile.client.shared.OrientationEvent;
import com.google.gwt.dom.client.Element;
public class PerspectiveAnimator {
private static final double MAX_CHANGE_PER_FRAME = 5;
private final Element element;
private double x;
private double y;
private double z;
private double targetX;
private double targetY;
private double targetZ;
public PerspectiveAnimator(Element element) {
this.element = element;
}
public void updateTargets(OrientationEvent e) {
targetX = e.getX();
targetY = e.getY();
targetZ = e.getZ();
}
public void nextFrame() {
x += Math.min(MAX_CHANGE_PER_FRAME, targetX - x);
y += Math.min(MAX_CHANGE_PER_FRAME, targetY - y);
z += Math.min(MAX_CHANGE_PER_FRAME, targetZ - z);
String transform = "rotateX(" + (x - 90.0) + "deg) " + "rotateY(" + (-y) + "deg)";
String compassTransform = "rotate( " + (360.0 - z) + "deg)";
element.getStyle().setProperty("MozTransform", transform);
element.getStyle().setProperty("WebkitTransform", transform);
element.getStyle().setProperty("transform", transform);
Element rotateMeCompass = element.getFirstChildElement().getNextSiblingElement();
rotateMeCompass.getStyle().setProperty("MozTransform", compassTransform);
rotateMeCompass.getStyle().setProperty("WebkitTransform", compassTransform);
rotateMeCompass.getStyle().setProperty("transform", compassTransform);
}
}