26 if (layer_index == -1) {
27 return {-1, -1, -1, -1};
49 return {-1, -1, -1, -1};
55 const float aspect[2],
56 const int cd_loop_uv_offset,
60 r_uv[0] = uv[0] * aspect[0];
61 r_uv[1] = uv[1] * aspect[1];
68#define UV_ASPECT(l, r_uv) uv_aspect(l, aspect, cd_loop_uv_offset, r_uv)
71 const float aspect[2],
72 const int cd_loop_uv_offset,
84 float uv_prev[2], uv_curr[2];
91 const float w_curr =
len_v2v2(uv_curr, uv_next);
92 const float w = (w_curr + w_prev);
97 }
while ((l_iter = l_iter->
next) != l_first);
103 r_cent[0] /= aspect[0];
104 r_cent[1] /= aspect[1];
118 }
while ((l_iter = l_iter->
next) != l_first);
132 }
while ((l_iter = l_iter->
next) != l_first);
144 }
while ((l_iter = l_iter->
next) != l_first);
154 if (l_a->
v !=
l_b->
v) {
155 std::swap(luv_b_curr, luv_b_next);
const char * BKE_uv_map_pin_name_get(const char *uv_map_name, char *buffer)
const char * BKE_uv_map_vert_select_name_get(const char *uv_map_name, char *buffer)
const char * BKE_uv_map_edge_select_name_get(const char *uv_map_name, char *buffer)
CustomData interface, see also DNA_customdata_types.h.
int CustomData_get_layer_index_n(const CustomData *data, eCustomDataType type, int n)
int CustomData_get_offset_named(const CustomData *data, eCustomDataType type, blender::StringRef name)
int CustomData_get_active_layer(const CustomData *data, eCustomDataType type)
bool isect_point_poly_v2(const float pt[2], const float verts[][2], unsigned int nr)
float cross_poly_v2(const float verts[][2], unsigned int nr)
MINLINE void madd_v2_v2fl(float r[2], const float a[2], float f)
MINLINE float len_v2v2(const float v1[2], const float v2[2]) ATTR_WARN_UNUSED_RESULT
MINLINE void mul_v2_fl(float r[2], float f)
MINLINE void copy_v2_v2(float r[2], const float a[2])
void minmax_v2v2_v2(float min[2], float max[2], const float vec[2])
MINLINE void add_v2_v2(float r[2], const float a[2])
MINLINE bool equals_v2v2(const float v1[2], const float v2[2]) ATTR_WARN_UNUSED_RESULT
MINLINE void zero_v2(float r[2])
#define MAX_CUSTOMDATA_LAYER_NAME
Read Guarded memory(de)allocation.
#define BM_ELEM_CD_GET_FLOAT2_P(ele, offset)
#define BM_FACE_FIRST_LOOP(p)
#define BM_ELEM_CD_GET_FLOAT_P(ele, offset)
ATTR_WARN_UNUSED_RESULT BMesh * bm
bool BM_face_is_normal_valid(const BMFace *f)
BMLoop * BM_loop_other_vert_loop_by_edge(BMLoop *l, BMEdge *e)
ATTR_WARN_UNUSED_RESULT const BMLoop * l
ATTR_WARN_UNUSED_RESULT const BMVert const BMEdge * e
ATTR_WARN_UNUSED_RESULT const BMLoop * l_b
bool BM_edge_uv_share_vert_check(BMEdge *e, BMLoop *l_a, BMLoop *l_b, const int cd_loop_uv_offset)
static void uv_aspect(const BMLoop *l, const float aspect[2], const int cd_loop_uv_offset, float r_uv[2])
BMUVOffsets BM_uv_map_get_offsets_from_layer(const BMesh *bm, const int layer)
BMUVOffsets BM_uv_map_get_offsets(const BMesh *bm)
bool BM_loop_uv_share_vert_check(BMLoop *l_a, BMLoop *l_b, const int cd_loop_uv_offset)
bool BM_loop_uv_share_edge_check(BMLoop *l_a, BMLoop *l_b, const int cd_loop_uv_offset)
void BM_face_uv_minmax(const BMFace *f, float min[2], float max[2], const int cd_loop_uv_offset)
void BM_face_uv_calc_center_median(const BMFace *f, const int cd_loop_uv_offset, float r_cent[2])
bool BM_face_uv_point_inside_test(const BMFace *f, const float co[2], const int cd_loop_uv_offset)
float BM_face_uv_calc_cross(const BMFace *f, const int cd_loop_uv_offset)
void BM_face_uv_calc_center_median_weighted(const BMFace *f, const float aspect[2], const int cd_loop_uv_offset, float r_cent[2])
#define UV_ASPECT(l, r_uv)
SIMD_FORCE_INLINE const btScalar & w() const
Return the w value.