Physically based defaults for Eevee Bloom and Shutter
[blender.git] / source / blender / blenkernel / BKE_mesh_tangent.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  * ***** END GPL LICENSE BLOCK *****
19  */
20 #ifndef __BKE_MESH_TANGENT_H__
21 #define __BKE_MESH_TANGENT_H__
22
23 /** \file BKE_mesh_tangent.h
24  *  \ingroup bke
25  */
26
27 void BKE_mesh_calc_loop_tangent_single_ex(
28         const struct MVert *mverts, const int numVerts, const struct MLoop *mloops,
29         float (*r_looptangent)[4], float (*loopnors)[3], const struct MLoopUV *loopuv,
30         const int numLoops, const struct MPoly *mpolys, const int numPolys,
31         struct ReportList *reports);
32 void BKE_mesh_calc_loop_tangent_single(
33         struct Mesh *mesh, const char *uvmap, float (*r_looptangents)[4], struct ReportList *reports);
34
35 void BKE_mesh_calc_loop_tangent_ex(
36         const struct MVert *mvert,
37         const struct MPoly *mpoly, const uint mpoly_len,
38         const struct MLoop *mloop,
39         const struct MLoopTri *looptri, const uint looptri_len,
40
41         struct CustomData *loopdata,
42         bool calc_active_tangent,
43         const char (*tangent_names)[64], int tangent_names_len,
44         const float (*poly_normals)[3],
45         const float (*loop_normals)[3],
46         const float (*vert_orco)[3],
47         /* result */
48         struct CustomData *loopdata_out,
49         const uint  loopdata_out_len,
50         short *tangent_mask_curr_p);
51
52 void BKE_mesh_calc_loop_tangents(
53         struct Mesh *me_eval, bool calc_active_tangent,
54         const char (*tangent_names)[MAX_NAME], int tangent_names_len);
55
56 /* Helpers */
57 void BKE_mesh_add_loop_tangent_named_layer_for_uv(
58         struct CustomData *uv_data, struct CustomData *tan_data, int numLoopData,
59         const char *layer_name);
60
61 #define DM_TANGENT_MASK_ORCO (1 << 9)
62 void BKE_mesh_calc_loop_tangent_step_0(
63         const struct CustomData *loopData, bool calc_active_tangent,
64         const char (*tangent_names)[64], int tangent_names_count,
65         bool *rcalc_act, bool *rcalc_ren, int *ract_uv_n, int *rren_uv_n,
66         char *ract_uv_name, char *rren_uv_name, short *rtangent_mask);
67
68 #endif /* __BKE_MESH_TANGENT_H__ */