/*
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 TransformationPostAffineStep extends AbstractTransformationStep {
private static final long serialVersionUID = 1L;
public TransformationPostAffineStep(XForm pXForm) {
super(pXForm);
}
@Override
public void transform(FlameTransformationContext pContext, XYZPoint pAffineT, XYZPoint pVarT, XYZPoint pSrcPoint, XYZPoint pDstPoint) {
double px, py, pz;
if (xform.hasXYPostCoeffs) {
px = xform.xyPostCoeff00 * pVarT.x + xform.xyPostCoeff10 * pVarT.y;
py = xform.xyPostCoeff01 * pVarT.x + xform.xyPostCoeff11 * pVarT.y;
pz = pVarT.z;
}
else {
px = pVarT.x;
py = pVarT.y;
pz = pVarT.z;
}
if (xform.hasYZPostCoeffs) {
double ny = xform.yzPostCoeff00 * py + xform.yzPostCoeff10 * pz;
double nz = xform.yzPostCoeff01 * py + xform.yzPostCoeff11 * pz;
py = ny;
pz = nz;
}
if (xform.hasZXPostCoeffs) {
double nx = xform.zxPostCoeff00 * px + xform.zxPostCoeff10 * pz;
double nz = xform.zxPostCoeff01 * px + xform.zxPostCoeff11 * pz;
px = nx;
pz = nz;
}
pDstPoint.x = px + xform.xyPostCoeff20 + xform.zxPostCoeff20;
pDstPoint.y = py + xform.xyPostCoeff21 + xform.yzPostCoeff20;
pDstPoint.z = pz + xform.yzPostCoeff21 + xform.zxPostCoeff21;
}
}