forked from bartvdbraak/blender
fix for own error in normal-recalc r58077, initial face flipping wasn't checking against face-island center.
This commit is contained in:
parent
14ab39c5e0
commit
bd5cb6fb3b
@ -56,7 +56,7 @@ static bool bmo_recalc_normal_edge_filter_cb(BMEdge *e, void *UNUSED(user_data))
|
|||||||
*/
|
*/
|
||||||
static void bmo_recalc_face_normals_array(BMesh *bm, BMFace **faces, const int faces_len, const short oflag)
|
static void bmo_recalc_face_normals_array(BMesh *bm, BMFace **faces, const int faces_len, const short oflag)
|
||||||
{
|
{
|
||||||
float cent[3];
|
float cent[3], tvec[3];
|
||||||
float (*faces_center)[3] = MEM_mallocN(sizeof(*faces_center) * faces_len, __func__);
|
float (*faces_center)[3] = MEM_mallocN(sizeof(*faces_center) * faces_len, __func__);
|
||||||
const float cent_fac = 1.0f / (float)faces_len;
|
const float cent_fac = 1.0f / (float)faces_len;
|
||||||
int i, f_start_index;
|
int i, f_start_index;
|
||||||
@ -91,7 +91,8 @@ static void bmo_recalc_face_normals_array(BMesh *bm, BMFace **faces, const int f
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* make sure the starting face has the correct winding */
|
/* make sure the starting face has the correct winding */
|
||||||
if (dot_v3v3(faces_center[f_start_index], faces[f_start_index]->no) < 0.0f) {
|
sub_v3_v3v3(tvec, faces_center[f_start_index], cent);
|
||||||
|
if (dot_v3v3(tvec, faces[f_start_index]->no) < 0.0f) {
|
||||||
BMO_elem_flag_enable(bm, faces[f_start_index], FACE_FLIP);
|
BMO_elem_flag_enable(bm, faces[f_start_index], FACE_FLIP);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user