apophysis7x/Plugin/dc_ztransl.c

70 lines
2.2 KiB
C
Raw Normal View History

/*
Apophysis Plugin
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
Written by Georg Kiehne
--> http://xyrus-worx.net, http://xyrus02.deviantart.com
If you find any bugs / nags - keep them :)
*/
typedef struct {
double dc_ztransl_x0;
double dc_ztransl_x1;
double dc_ztransl_factor;
double x0_, x1_, x1_m_x0;
int dc_ztransl_overwrite;
int dc_ztransl_clamp;
} Variables;
#include "apoplugin.h"
APO_PLUGIN("dc_ztransl");
APO_VARIABLES(
VAR_REAL_RANGE(dc_ztransl_x0, 0.0, 1.0, 0.0),
VAR_REAL_RANGE(dc_ztransl_x1, 0.0, 1.0, 1.0),
VAR_REAL(dc_ztransl_factor, 1.0),
VAR_INTEGER_RANGE(dc_ztransl_overwrite, 0, 1, 1),
VAR_INTEGER_RANGE(dc_ztransl_clamp, 0, 1, 0)
);
int PluginVarPrepare(Variation* vp)
{
vp->var.x0_ = vp->var.dc_ztransl_x0 < vp->var.dc_ztransl_x1 ? vp->var.dc_ztransl_x0 : vp->var.dc_ztransl_x1;
vp->var.x1_ = vp->var.dc_ztransl_x0 > vp->var.dc_ztransl_x1 ? vp->var.dc_ztransl_x0 : vp->var.dc_ztransl_x1;
vp->var.x1_m_x0 = vp->var.x1_ - vp->var.x0_ == 0 ? EPS : vp->var.x1_ - vp->var.x0_;
return 1;
}
inline double flip(double a, double b, double c){return (c*(b-a)+a);}
int PluginVarCalc(Variation* vp)
{
double zf = vp->var.dc_ztransl_factor * (*(vp->pColor) - vp->var.x0_) / vp->var.x1_m_x0;
if (vp->var.dc_ztransl_clamp != 0)
zf = zf < 0 ? 0 : zf > 1 ? 1 : zf;
*(vp->pFPx) += vp->vvar*(*(vp->pFTx));
*(vp->pFPy) += vp->vvar*(*(vp->pFTy));
if (vp->var.dc_ztransl_overwrite == 0)
*(vp->pFPz) += vp->vvar*(*(vp->pFTz))*zf;
else *(vp->pFPz) += vp->vvar*zf;
return 1;
}