mirror of
https://github.com/revarbat/BOSL2.git
synced 2025-01-16 13:50:23 +01:00
attachments fixes
This commit is contained in:
parent
9671a8a171
commit
c2f5fa7352
@ -906,6 +906,7 @@ module attach(parent, child, overlap, align, spin=0, norot, inset=0, shiftout=0,
|
|||||||
|
|
||||||
two_d = _attach_geom_2d($parent_geom);
|
two_d = _attach_geom_2d($parent_geom);
|
||||||
basegeom = $parent_geom[0]=="conoid" ? attach_geom(r=2,h=2)
|
basegeom = $parent_geom[0]=="conoid" ? attach_geom(r=2,h=2)
|
||||||
|
: $parent_geom[0]=="spheroid" ? echo("here")attach_geom(r=2)
|
||||||
: attach_geom(size=[2,2,2]);
|
: attach_geom(size=[2,2,2]);
|
||||||
child_abstract_anchor = is_vector(child) && !two_d ? _find_anchor(child, basegeom) : undef;
|
child_abstract_anchor = is_vector(child) && !two_d ? _find_anchor(child, basegeom) : undef;
|
||||||
overlap = (overlap!=undef)? overlap : $overlap;
|
overlap = (overlap!=undef)? overlap : $overlap;
|
||||||
@ -939,7 +940,7 @@ module attach(parent, child, overlap, align, spin=0, norot, inset=0, shiftout=0,
|
|||||||
anchor_spin = two_d || !inside || anchor==TOP || anchor==BOT ? anchor_data[3]
|
anchor_spin = two_d || !inside || anchor==TOP || anchor==BOT ? anchor_data[3]
|
||||||
: let(spin_dir = rot(anchor_data[3],from=UP, to=-anchor_dir, p=BACK))
|
: let(spin_dir = rot(anchor_data[3],from=UP, to=-anchor_dir, p=BACK))
|
||||||
_compute_spin(anchor_dir,spin_dir);
|
_compute_spin(anchor_dir,spin_dir);
|
||||||
parent_abstract_anchor = is_vector(parent) && !two_d ? _find_anchor(parent,basegeom) : undef;
|
parent_abstract_anchor = is_vector(anchor) && !two_d ? _find_anchor(anchor,basegeom) : undef;
|
||||||
for(align_ind = idx(align_list)){
|
for(align_ind = idx(align_list)){
|
||||||
align = is_undef(align_list[align_ind]) ? undef
|
align = is_undef(align_list[align_ind]) ? undef
|
||||||
: assert(is_vector(align_list[align_ind],2) || is_vector(align_list[align_ind],3), "align direction must be a 2-vector or 3-vector")
|
: assert(is_vector(align_list[align_ind],2) || is_vector(align_list[align_ind],3), "align direction must be a 2-vector or 3-vector")
|
||||||
@ -953,7 +954,7 @@ module attach(parent, child, overlap, align, spin=0, norot, inset=0, shiftout=0,
|
|||||||
pos = is_undef(align) ? anchor_data[1] : _find_anchor(anchor+align, $parent_geom)[1];
|
pos = is_undef(align) ? anchor_data[1] : _find_anchor(anchor+align, $parent_geom)[1];
|
||||||
$attach_anchor = list_set(anchor_data, 1, pos); // Never used; For user informational use? Should this be set at all?
|
$attach_anchor = list_set(anchor_data, 1, pos); // Never used; For user informational use? Should this be set at all?
|
||||||
// Compute adjustment to the child anchor for position purposes. This adjustment
|
// Compute adjustment to the child anchor for position purposes. This adjustment
|
||||||
// accounts for the change in the anchor needed to to alignment.
|
// accounts for the change in the anchor needed to to alignment.
|
||||||
child_adjustment = is_undef(align)? CTR
|
child_adjustment = is_undef(align)? CTR
|
||||||
: two_d ? rot(to=child,from=-factor*anchor,p=align)
|
: two_d ? rot(to=child,from=-factor*anchor,p=align)
|
||||||
: apply( rot(to=child_abstract_anchor[2],from=UP)
|
: apply( rot(to=child_abstract_anchor[2],from=UP)
|
||||||
@ -3569,8 +3570,7 @@ function _attach_transform(anchor, spin, orient, geom, p) =
|
|||||||
// if $anchor_override is set it defines the object position anchor (but note not direction or spin).
|
// if $anchor_override is set it defines the object position anchor (but note not direction or spin).
|
||||||
// Otherwise we use the provided anchor for the object.
|
// Otherwise we use the provided anchor for the object.
|
||||||
pos = is_undef($anchor_override) ? anch[1]
|
pos = is_undef($anchor_override) ? anch[1]
|
||||||
: _find_anchor(_make_anchor_legal($anchor_override,geom),geom)[1],
|
: _find_anchor(_make_anchor_legal($anchor_override,geom),geom)[1]
|
||||||
f=is_undef($anchor_override) ? 0 : echo(geo=_find_anchor(_make_anchor_legal($anchor_override,geom),geom)[1])
|
|
||||||
)
|
)
|
||||||
two_d?
|
two_d?
|
||||||
assert(is_num(spin))
|
assert(is_num(spin))
|
||||||
@ -3861,7 +3861,8 @@ function _find_anchor(anchor, geom) =
|
|||||||
// may appear twice WITH DIFFERENT VERTEX INDICES if repeated points appear in the vnf.
|
// may appear twice WITH DIFFERENT VERTEX INDICES if repeated points appear in the vnf.
|
||||||
edges_faces = len(idxs)==2 ? // Simple case, no repeated points, [idxs] gives the edge
|
edges_faces = len(idxs)==2 ? // Simple case, no repeated points, [idxs] gives the edge
|
||||||
approx(vnf[0][idxs[0]],vnf[0][idxs[1]]) ? [] // Are edge points identical?
|
approx(vnf[0][idxs[0]],vnf[0][idxs[1]]) ? [] // Are edge points identical?
|
||||||
: [[idxs],_vnf_find_edge_faces(vnf,idxs)]
|
: let( facelist = _vnf_find_edge_faces(vnf,idxs))
|
||||||
|
len(facelist)==2 ? [[idxs], facelist] : []
|
||||||
: len(idxs)!=4 ? [] // If we don't have four points it's not an edge pair
|
: len(idxs)!=4 ? [] // If we don't have four points it's not an edge pair
|
||||||
: let(
|
: let(
|
||||||
pts = select(vnf[0],idxs),
|
pts = select(vnf[0],idxs),
|
||||||
@ -4784,7 +4785,6 @@ function _force_anchor_2d(anchor) =
|
|||||||
// direction and gives the spin angle that achieves it.
|
// direction and gives the spin angle that achieves it.
|
||||||
function _compute_spin(anchor_dir, spin_dir) =
|
function _compute_spin(anchor_dir, spin_dir) =
|
||||||
let(
|
let(
|
||||||
f=echo(ad=anchor_dir, spin_dir),
|
|
||||||
native_dir = rot(from=UP, to=anchor_dir, p=BACK),
|
native_dir = rot(from=UP, to=anchor_dir, p=BACK),
|
||||||
spin_dir = spin_dir - (spin_dir*anchor_dir)*anchor_dir, // component of spin_dir perpendicular to anchor_dir
|
spin_dir = spin_dir - (spin_dir*anchor_dir)*anchor_dir, // component of spin_dir perpendicular to anchor_dir
|
||||||
dummy = assert(!approx(spin_dir,[0,0,0]),"spin direction is parallel to anchor"),
|
dummy = assert(!approx(spin_dir,[0,0,0]),"spin direction is parallel to anchor"),
|
||||||
|
@ -2011,6 +2011,7 @@ value drived from the standard anchor will be used. Below we override
|
|||||||
position of the FWD anchor:
|
position of the FWD anchor:
|
||||||
|
|
||||||
```openscad-3D
|
```openscad-3D
|
||||||
|
include<BOSL2/std.scad>
|
||||||
module cubic_barbell(s=100, anchor=CENTER, spin=0, orient=UP) {
|
module cubic_barbell(s=100, anchor=CENTER, spin=0, orient=UP) {
|
||||||
override = [
|
override = [
|
||||||
[FWD, [[0,-s/8,0]]]
|
[FWD, [[0,-s/8,0]]]
|
||||||
@ -2031,6 +2032,7 @@ you wanted to also change its direction and spin you could do it like
|
|||||||
this:
|
this:
|
||||||
|
|
||||||
```openscad-3D
|
```openscad-3D
|
||||||
|
include<BOSL2/std.scad>
|
||||||
module cubic_barbell(s=100, anchor=CENTER, spin=0, orient=UP) {
|
module cubic_barbell(s=100, anchor=CENTER, spin=0, orient=UP) {
|
||||||
override = [
|
override = [
|
||||||
[FWD, [[0,-s/8,0], FWD+LEFT, 225]]
|
[FWD, [[0,-s/8,0], FWD+LEFT, 225]]
|
||||||
@ -2055,6 +2057,7 @@ the x=0 anchors to be on the cylinder, with their standard directions,
|
|||||||
you can do that by supplying a list:
|
you can do that by supplying a list:
|
||||||
|
|
||||||
```openscad-3D
|
```openscad-3D
|
||||||
|
include<BOSL2/std.scad>
|
||||||
module cubic_barbell(s=100, anchor=CENTER, spin=0, orient=UP) {
|
module cubic_barbell(s=100, anchor=CENTER, spin=0, orient=UP) {
|
||||||
override = [
|
override = [
|
||||||
for(j=[-1:1:1], k=[-1:1:1])
|
for(j=[-1:1:1], k=[-1:1:1])
|
||||||
@ -2079,6 +2082,7 @@ default. As before, you can omit values to keep their default.
|
|||||||
Here is the same example using a function literal for the override:
|
Here is the same example using a function literal for the override:
|
||||||
|
|
||||||
```openscad-3D
|
```openscad-3D
|
||||||
|
include<BOSL2/std.scad>
|
||||||
module cubic_barbell(s=100, anchor=CENTER, spin=0, orient=UP) {
|
module cubic_barbell(s=100, anchor=CENTER, spin=0, orient=UP) {
|
||||||
override = function (anchor)
|
override = function (anchor)
|
||||||
anchor.x!=0 || anchor==CTR ? undef // Keep these
|
anchor.x!=0 || anchor==CTR ? undef // Keep these
|
||||||
|
Loading…
x
Reference in New Issue
Block a user