diff options
author | Nicholas Bishop <nicholasbishop@gmail.com> | 2012-12-30 22:22:21 +0400 |
---|---|---|
committer | Nicholas Bishop <nicholasbishop@gmail.com> | 2012-12-30 22:22:21 +0400 |
commit | 2d39e4641428d4557fb6f2fcb7f13c64aef3ff3e (patch) | |
tree | 2270c595c1e9e34df4adb3415defcc0b98d8f686 /source/blender/bmesh/intern | |
parent | a8811094ea9241ac8678a7d4c3fff4ab2ac5bf20 (diff) |
Add BM_edge_calc_squared_length() query function
Same as BM_edge_calc_length(), but avoids square root for cases where
only comparison is needed.
Diffstat (limited to 'source/blender/bmesh/intern')
-rw-r--r-- | source/blender/bmesh/intern/bmesh_queries.c | 10 | ||||
-rw-r--r-- | source/blender/bmesh/intern/bmesh_queries.h | 1 |
2 files changed, 10 insertions, 1 deletions
diff --git a/source/blender/bmesh/intern/bmesh_queries.c b/source/blender/bmesh/intern/bmesh_queries.c index 5f5c60dde3f..d723e6464df 100644 --- a/source/blender/bmesh/intern/bmesh_queries.c +++ b/source/blender/bmesh/intern/bmesh_queries.c @@ -468,7 +468,7 @@ BMEdge *BM_vert_other_disk_edge(BMVert *v, BMEdge *e_first) } /** - * Returms edge length + * Returns edge length */ float BM_edge_calc_length(BMEdge *e) { @@ -476,6 +476,14 @@ float BM_edge_calc_length(BMEdge *e) } /** + * Returns edge length squared (for comparisons) + */ +float BM_edge_calc_squared_length(BMEdge *e) +{ + return len_squared_v3v3(e->v1->co, e->v2->co); +} + +/** * Utility function, since enough times we have an edge * and want to access 2 connected faces. * diff --git a/source/blender/bmesh/intern/bmesh_queries.h b/source/blender/bmesh/intern/bmesh_queries.h index 9af792417bf..59c3fae8c5d 100644 --- a/source/blender/bmesh/intern/bmesh_queries.h +++ b/source/blender/bmesh/intern/bmesh_queries.h @@ -37,6 +37,7 @@ int BM_vert_in_edge(BMEdge *e, BMVert *v); int BM_verts_in_edge(BMVert *v1, BMVert *v2, BMEdge *e); float BM_edge_calc_length(BMEdge *e); +float BM_edge_calc_squared_length(BMEdge *e); int BM_edge_face_pair(BMEdge *e, BMFace **r_fa, BMFace **r_fb); int BM_edge_loop_pair(BMEdge *e, BMLoop **r_la, BMLoop **r_lb); BMVert *BM_edge_other_vert(BMEdge *e, BMVert *v); |