Merge branch 'blender2.7'
[blender.git] / source / blender / blenkernel / particle_private.h
1 /*
2  * ***** BEGIN GPL LICENSE BLOCK *****
3  *
4  * This program is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU General Public License
6  * as published by the Free Software Foundation; either version 2
7  * of the License, or (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software Foundation,
16  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17  *
18  * The Original Code is Copyright (C) 2018 Blender Foundation.
19  * All rights reserved.
20  *
21  * Contributor(s): Blender Foundation,
22  *                 Sergey Sharybin
23  *
24  * ***** END GPL LICENSE BLOCK *****
25  */
26
27 /** \file blender/blenkernel/particle_private.h
28  *  \ingroup bke
29  */
30
31 #ifndef __PARTICLE_PRIVATE_H__
32 #define __PARTICLE_PRIVATE_H__
33
34 typedef struct ParticleChildModifierContext {
35         ParticleThreadContext *thread_ctx;
36         ParticleSimulationData *sim;
37         ParticleTexture *ptex;
38         ChildParticle *cpa;
39         const float *par_co;    /* float3 */
40         const float *par_vel;   /* float3 */
41         const float *par_rot;   /* float4 */
42         const float *par_orco;  /* float3 */
43         const float *orco;      /* float3 */
44         ParticleCacheKey *parent_keys;
45 } ParticleChildModifierContext;
46
47 void do_kink(ParticleKey *state, const float par_co[3], const float par_vel[3], const float par_rot[4], float time, float freq, float shape, float amplitude, float flat,
48              short type, short axis, float obmat[4][4], int smooth_start);
49 float do_clump(ParticleKey *state, const float par_co[3], float time, const float orco_offset[3], float clumpfac, float clumppow, float pa_clump,
50                bool use_clump_noise, float clump_noise_size, CurveMapping *clumpcurve);
51 void do_child_modifiers(const ParticleChildModifierContext *modifier_ctx,
52                         float mat[4][4], ParticleKey *state, float t);
53
54 #endif /* __PARTICLE_PRIVATE_H__ */