historical/toontown-classic.git/panda/include/particleCommonFuncs.h
2024-01-16 11:20:27 -06:00

37 lines
1.2 KiB
C

/**
* PANDA 3D SOFTWARE
* Copyright (c) Carnegie Mellon University. All rights reserved.
*
* All use of this software is subject to the terms of the revised BSD
* license. You should have received a copy of this license along
* with this source code in a file named "LICENSE."
*
* @file particleCommonFuncs.h
* @author darren
* @date 2000-10-02
*/
#ifndef PARTICLECOMMONFUNCS_H
#define PARTICLECOMMONFUNCS_H
// evaluates to a float in the range [0,1]
#define NORMALIZED_RAND() ((PN_stdfloat)rand() / (PN_stdfloat)RAND_MAX)
// linear interpolation t is in [0,1] result is in [X0,X1]
#define LERP(t,X0,X1) ((X0) + ((t) * ((X1) - (X0))))
// linear t -> cubic t t is in [0,1] result is in [0,1]
#define CUBIC_T(t) ((t)*(t)*(3-(2*(t))))
// cubic interpolation t is in [0,1] result is in [X0,X1]
#define CLERP(t,X0,X1) LERP(CUBIC_T(t), (X0), (X1))
// spread calculator spread is non-negative spread magnitude result is in
// [-spread,spread]
#define SPREAD(magnitude) ((magnitude) - (NORMALIZED_RAND() * 2.0f * (magnitude)))
// integer spread calculator spread is non-negative spread magnitude (integer)
// result is in [-spread,spread]
#define I_SPREAD(magnitude) ((magnitude) - ((int)rand() % ((2*(magnitude))+1)))
#endif // PARTICLECOMMONFUNCS_H