38 lines
1.2 KiB
C
38 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
|