package org.geogebra.common.kernel.scripting;
import org.geogebra.common.kernel.Kernel;
import org.geogebra.common.kernel.arithmetic.Command;
import org.geogebra.common.kernel.commands.CmdScripting;
import org.geogebra.common.kernel.geos.GeoBoolean;
import org.geogebra.common.kernel.geos.GeoElement;
import org.geogebra.common.main.MyError;
/**
* StartAnimation
*/
public class CmdStartAnimation extends CmdScripting {
/**
* Create new command processor
*
* @param kernel
* kernel
*/
public CmdStartAnimation(Kernel kernel) {
super(kernel);
}
@Override
protected final GeoElement[] perform(Command c) throws MyError {
int n = c.getArgumentNumber();
// dummy
switch (n) {
case 0:
app.getKernel().getAnimatonManager().startAnimation();
return new GeoElement[0];
case 1:
GeoElement[] arg = resArgs(c);
if (arg[0].isAnimatable()) {
arg[0].setAnimating(true);
app.getKernel().getAnimatonManager().startAnimation();
return arg;
} else if (arg[0].isGeoBoolean()) {
GeoBoolean geo = (GeoBoolean) arg[0];
if (geo.getBoolean()) {
app.getKernel().getAnimatonManager().startAnimation();
} else {
app.getKernel().getAnimatonManager().stopAnimation();
}
return arg;
} else {
throw argErr(app, c, arg[0]);
}
default:
arg = resArgs(c);
boolean start = true;
int sliderCount = n;
if (arg[n - 1].isGeoBoolean()) {
start = ((GeoBoolean) arg[n - 1]).getBoolean();
sliderCount = n - 1;
}
for (int i = 0; i < sliderCount; i++) {
if (!arg[i].isAnimatable()) {
throw argErr(app, c, arg[i]);
}
}
for (int i = 0; i < sliderCount; i++) {
if (arg[i].isAnimatable()) {
arg[i].setAnimating(start);
}
if (start) {
app.getKernel().getAnimatonManager().startAnimation();
}
}
return arg;
}
}
}