Bugfix for vec3 spin values.

This commit is contained in:
Revar Desmera 2020-03-30 14:46:30 -07:00
parent b22cd9e1d8
commit f2decb3873
2 changed files with 20 additions and 8 deletions

View file

@ -307,7 +307,6 @@ function attach_geom_size(geom) =
// p = If given as a VNF, path, or point, applies the affine3d transformation matrix to it and returns the result. // p = If given as a VNF, path, or point, applies the affine3d transformation matrix to it and returns the result.
function attach_transform(anchor=CENTER, spin=0, orient=UP, geom, p) = function attach_transform(anchor=CENTER, spin=0, orient=UP, geom, p) =
assert(is_string(anchor) || is_vector(anchor)) assert(is_string(anchor) || is_vector(anchor))
assert(is_num(spin) || is_vector(spin,3))
assert(is_vector(orient)) assert(is_vector(orient))
let( let(
two_d = attach_geom_2d(geom), two_d = attach_geom_2d(geom),
@ -316,36 +315,49 @@ function attach_transform(anchor=CENTER, spin=0, orient=UP, geom, p) =
anch = find_anchor($attach_to, geom), anch = find_anchor($attach_to, geom),
pos = anch[1] pos = anch[1]
) two_d? ( ) two_d? (
assert(two_d && is_num(spin))
let( let(
ang = vector_angle(anch[2], BACK) ang = vector_angle(anch[2], BACK)
) )
affine3d_zrot(ang+spin) * affine3d_zrot(ang+spin) *
affine3d_translate(point3d(-pos)) affine3d_translate(point3d(-pos))
) : ( ) : (
assert(is_num(spin) || is_vector(spin,3))
let( let(
ang = vector_angle(anch[2], DOWN), ang = vector_angle(anch[2], DOWN),
axis = vector_axis(anch[2], DOWN), axis = vector_axis(anch[2], DOWN),
ang2 = (anch[2]==UP || anch[2]==DOWN)? 0 : 180-anch[3], ang2 = (anch[2]==UP || anch[2]==DOWN)? 0 : 180-anch[3],
axis2 = rot(p=axis,[0,0,ang2]) axis2 = rot(p=axis,[0,0,ang2])
) )
affine3d_rot_by_axis(axis2,ang) * affine3d_rot_by_axis(axis2,ang) * (
affine3d_zrot(ang2+spin) * is_num(spin)? affine3d_zrot(ang2+spin) : (
affine3d_translate(point3d(-pos)) affine3d_zrot(spin.z) *
affine3d_yrot(spin.y) *
affine3d_xrot(spin.x) *
affine3d_zrot(ang2)
)
) * affine3d_translate(point3d(-pos))
) )
) : ( ) : (
let( let(
pos = find_anchor(anchor, geom)[1] pos = find_anchor(anchor, geom)[1]
) two_d? ( ) two_d? (
assert(two_d && is_num(spin))
affine3d_zrot(spin) * affine3d_zrot(spin) *
affine3d_translate(point3d(-pos)) affine3d_translate(point3d(-pos))
) : ( ) : (
assert(is_num(spin) || is_vector(spin,3))
let( let(
axis = vector_axis(UP,orient), axis = vector_axis(UP,orient),
ang = vector_angle(UP,orient) ang = vector_angle(UP,orient)
) )
affine3d_rot_by_axis(axis,ang) * affine3d_rot_by_axis(axis,ang) * (
affine3d_zrot(spin) * is_num(spin)? affine3d_zrot(spin) : (
affine3d_translate(point3d(-pos)) affine3d_zrot(spin.z) *
affine3d_yrot(spin.y) *
affine3d_xrot(spin.x)
)
) * affine3d_translate(point3d(-pos))
) )
) )
) is_undef(p)? m : ) is_undef(p)? m :

View file

@ -8,7 +8,7 @@
////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////
BOSL_VERSION = [2,0,242]; BOSL_VERSION = [2,0,243];
// Section: BOSL Library Version Functions // Section: BOSL Library Version Functions