/*
JWildfire - an image and animation processor written in Java
Copyright (C) 1995-2014 Andreas Maschke
This is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser
General Public License as published by the Free Software Foundation; either version 2.1 of the
License, or (at your option) any later version.
This software is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without
even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License along with this software;
if not, write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.jwildfire.create.tina.base;
import org.jwildfire.create.tina.variation.FlameTransformationContext;
public final class TransformationAffineFullStep extends AbstractTransformationStep {
private static final long serialVersionUID = 1L;
public TransformationAffineFullStep(XForm pXForm) {
super(pXForm);
}
@Override
public void transform(FlameTransformationContext pContext, XYZPoint pAffineT, XYZPoint pVarT, XYZPoint pSrcPoint, XYZPoint pDstPoint) {
double x, y, z;
if (xform.hasXYCoeffs) {
x = xform.xyCoeff00 * pSrcPoint.x + xform.xyCoeff10 * pSrcPoint.y;
y = xform.xyCoeff01 * pSrcPoint.x + xform.xyCoeff11 * pSrcPoint.y;
z = pSrcPoint.z;
}
else {
x = pSrcPoint.x;
y = pSrcPoint.y;
z = pSrcPoint.z;
}
if (xform.hasYZCoeffs) {
double ny = xform.yzCoeff00 * y + xform.yzCoeff10 * z;
double nz = xform.yzCoeff01 * y + xform.yzCoeff11 * z;
y = ny;
z = nz;
}
if (xform.hasZXCoeffs) {
double nx = xform.zxCoeff00 * x + xform.zxCoeff10 * z;
double nz = xform.zxCoeff01 * x + xform.zxCoeff11 * z;
x = nx;
z = nz;
}
pAffineT.x = x + xform.xyCoeff20 + xform.zxCoeff20;
pAffineT.y = y + xform.xyCoeff21 + xform.yzCoeff20;
pAffineT.z = z + xform.yzCoeff21 + xform.zxCoeff21;
}
}