2019-05-02 09:19:37 +08:00
|
|
|
# m_shearing
|
|
|
|
|
2019-06-24 07:29:42 +08:00
|
|
|
The dir changed since 2.0.
|
|
|
|
|
2019-05-02 09:19:37 +08:00
|
|
|
Generate a 4x4 transformation matrix which can pass into `multmatrix` to shear all child elements along the X-axis, Y-axis, or Z-axis in 3D.
|
|
|
|
|
2019-05-02 10:44:19 +08:00
|
|
|
**Since:** 1.1
|
|
|
|
|
2019-05-02 09:19:37 +08:00
|
|
|
## Parameters
|
|
|
|
|
|
|
|
- `sx` : An array `[SHy, SHz]`. The new coordinates of child elements are `(x + SHy * y + SHz * z, y, z)`.
|
|
|
|
- `sy` : An array `[SHx, SHz]`. The new coordinates of child elements are `(x, y + SHx * x + SHz * z, z)`.
|
|
|
|
- `sz` : An array `[SHx, SHy]`. The new coordinates of child elements are `(x, y, z + SHx * x + SHy * y)`.
|
|
|
|
|
|
|
|
## Examples
|
|
|
|
|
2020-01-28 17:51:20 +08:00
|
|
|
use <matrix/m_shearing.scad>;
|
2019-05-02 09:19:37 +08:00
|
|
|
|
|
|
|
color("red") {
|
|
|
|
multmatrix(m_shearing(sx = [1, 0]))
|
|
|
|
cube(1);
|
|
|
|
|
|
|
|
translate([2, 0, 0]) multmatrix(m_shearing(sx = [0, 1]))
|
|
|
|
cube(1);
|
|
|
|
|
|
|
|
translate([4, 0, 0]) multmatrix(m_shearing(sx = [1, 1]))
|
|
|
|
cube(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
translate([0, -3, 0]) color("green") {
|
|
|
|
multmatrix(m_shearing(sy = [1, 0]))
|
|
|
|
cube(1);
|
|
|
|
|
|
|
|
translate([2, 0, 0]) multmatrix(m_shearing(sy = [0, 1]))
|
|
|
|
cube(1);
|
|
|
|
|
|
|
|
translate([4, 0, 0]) multmatrix(m_shearing(sy = [1, 1]))
|
|
|
|
cube(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
translate([0, -5, 0]) color("blue") {
|
|
|
|
multmatrix(m_shearing(sz = [1, 0]))
|
|
|
|
cube(1);
|
|
|
|
|
|
|
|
translate([2, 0, 0]) multmatrix(m_shearing(sz = [0, 1]))
|
|
|
|
cube(1);
|
|
|
|
|
|
|
|
translate([4, 0, 0]) multmatrix(m_shearing(sz = [1, 1]))
|
|
|
|
cube(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
![m_shearing](images/lib-m_shearing-1.JPG)
|
|
|
|
|