mirror of
https://github.com/MarlinFirmware/Marlin.git
synced 2025-01-17 23:18:34 +00:00
Move apply_rotation_xyz into matrix_3x3
This commit is contained in:
parent
8d083eb248
commit
be775ed72d
5 changed files with 10 additions and 12 deletions
|
@ -1592,7 +1592,7 @@ void unified_bed_leveling::smart_fill_mesh() {
|
|||
DEBUG_DELAY(20);
|
||||
}
|
||||
|
||||
apply_rotation_xyz(rotation, mx, my, mz);
|
||||
rotation.apply_rotation_xyz(mx, my, mz);
|
||||
|
||||
if (DEBUGGING(LEVELING)) {
|
||||
DEBUG_ECHOPAIR_F("after rotation = [", mx, 7);
|
||||
|
|
|
@ -794,7 +794,7 @@ G29_TYPE GcodeSuite::G29() {
|
|||
const int ind = abl.indexIntoAB[xx][yy];
|
||||
xyz_float_t tmp = { abl.eqnAMatrix[ind + 0 * abl.abl_points],
|
||||
abl.eqnAMatrix[ind + 1 * abl.abl_points], 0 };
|
||||
apply_rotation_xyz(planner.bed_level_matrix, tmp);
|
||||
planner.bed_level_matrix.apply_rotation_xyz(tmp);
|
||||
if (get_min) NOMORE(min_diff, abl.eqnBVector[ind] - tmp.z);
|
||||
const float subval = get_min ? abl.mean : tmp.z + min_diff,
|
||||
diff = abl.eqnBVector[ind] - subval;
|
||||
|
|
|
@ -87,8 +87,8 @@ void vector_3::debug(PGM_P const title) {
|
|||
* matrix_3x3
|
||||
*/
|
||||
|
||||
void apply_rotation_xyz(const matrix_3x3 &matrix, float &_x, float &_y, float &_z) {
|
||||
vector_3 vec = vector_3(_x, _y, _z); vec.apply_rotation(matrix);
|
||||
void matrix_3x3::apply_rotation_xyz(float &_x, float &_y, float &_z) {
|
||||
vector_3 vec = vector_3(_x, _y, _z); vec.apply_rotation(*this);
|
||||
_x = vec.x; _y = vec.y; _z = vec.z;
|
||||
}
|
||||
|
||||
|
|
|
@ -45,7 +45,6 @@
|
|||
class matrix_3x3;
|
||||
|
||||
struct vector_3 : xyz_float_t {
|
||||
|
||||
vector_3(const float &_x, const float &_y, const float &_z) { set(_x, _y, _z); }
|
||||
vector_3(const xy_float_t &in) { set(in.x, in.y); }
|
||||
vector_3(const xyz_float_t &in) { set(in.x, in.y, in.z); }
|
||||
|
@ -82,9 +81,8 @@ struct matrix_3x3 {
|
|||
void set_to_identity();
|
||||
|
||||
void debug(PGM_P const title);
|
||||
};
|
||||
|
||||
void apply_rotation_xyz(const matrix_3x3 &rotationMatrix, float &x, float &y, float &z);
|
||||
FORCE_INLINE void apply_rotation_xyz(const matrix_3x3 &rotationMatrix, xyz_pos_t &pos) {
|
||||
apply_rotation_xyz(rotationMatrix, pos.x, pos.y, pos.z);
|
||||
}
|
||||
void apply_rotation_xyz(float &x, float &y, float &z);
|
||||
|
||||
FORCE_INLINE void apply_rotation_xyz(xyz_pos_t &pos) { apply_rotation_xyz(pos.x, pos.y, pos.z); }
|
||||
};
|
||||
|
|
|
@ -1534,7 +1534,7 @@ void Planner::check_axes_activity() {
|
|||
#if ABL_PLANAR
|
||||
|
||||
xy_pos_t d = raw - level_fulcrum;
|
||||
apply_rotation_xyz(bed_level_matrix, d.x, d.y, raw.z);
|
||||
bed_level_matrix.apply_rotation_xyz(d.x, d.y, raw.z);
|
||||
raw = d + level_fulcrum;
|
||||
|
||||
#elif HAS_MESH
|
||||
|
@ -1571,7 +1571,7 @@ void Planner::check_axes_activity() {
|
|||
matrix_3x3 inverse = matrix_3x3::transpose(bed_level_matrix);
|
||||
|
||||
xy_pos_t d = raw - level_fulcrum;
|
||||
apply_rotation_xyz(inverse, d.x, d.y, raw.z);
|
||||
inverse.apply_rotation_xyz(d.x, d.y, raw.z);
|
||||
raw = d + level_fulcrum;
|
||||
|
||||
#elif HAS_MESH
|
||||
|
|
Loading…
Reference in a new issue