Add struct for pattern config, more helpers

This commit is contained in:
thewildmage
2023-05-31 22:51:27 -06:00
parent 7737ab526b
commit e59df82062
2 changed files with 100 additions and 7 deletions

View File

@@ -206,7 +206,7 @@ void CalibPressureAdvance::delta_scale_bed_ext(BoundingBoxf& bed_ext)
void CalibPressureAdvance::delta_modify_start(double& start_x, double& start_y, int count)
{
startx = -startx;
starty = -(count * m_space_y) / 2;
starty = -(count * m_space_y) / 2; // TODO fix for pattern
}
std::string CalibPressureAdvanceLine::generate_test(double start_pa /*= 0*/, double step_pa /*= 0.002*/, int count /*= 10*/)
@@ -302,7 +302,23 @@ std::string CalibPressureAdvancePattern::generate_test(double start_pa, double e
delta_modify_start(start_x, start_y, num_patterns);
}
return print_pa_pattern(start_x, start_y, start_pa, step_pa, num_patterns);
CalibPressureAdvancePattern::PatternConfig pattern_config(
start_pa,
step_pa,
num_patterns,
center_x,
center_y,
start_x,
start_y,
print_size_x(num_patterns, center_x),
frame_size_y(),
glyph_end_x(num_patterns, center_x)
);
return print_pa_pattern(pattern_config);
}
double CalibPressureAdvancePattern::get_distance(double cur_x, double cur_y, double to_x, double to_y)
@@ -352,6 +368,26 @@ double CalibPressureAdvancePattern::glyph_start_x(int num_patterns, double cente
;
}
double CalibPressureAdvancePattern::glyph_end_x(int num_patterns, double center_x)
{
return
center_x -
object_size_x(num_patterns) / 2 +
(num_patterns - 1) * (m_pattern_spacing + line_width()) +
(num_patterns - 1) * ((m_wall_count - 1) * line_spacing_angle()) +
4
;
}
double CalibPressureAdvancePattern::glyph_tab_max_x(int num_patterns, double center_x)
{
return
glyph_end_x(num_patterns, center_x) +
m_glyph_padding_horizontal +
line_width_anchor() / 2
;
}
double CalibPressureAdvancePattern::pattern_shift(int num_patterns, double center_x)
{
auto shift =
@@ -445,17 +481,22 @@ std::string CalibPressureAdvancePattern::draw_box(double min_x, double min_y, do
return gcode.str();
}
std::string CalibPressureAdvancePattern::print_pa_pattern(double start_x, double start_y, double start_pa, double step_pa, int num_patterns)
{
std::string CalibPressureAdvancePattern::print_pa_pattern(PatternConfig& config)
{
const auto& writer = mp_gcodegen->writer();
std::stringstream gcode;
gcode << writer.travel_to_z(m_height_first_layer, "Move to start layer height");
gcode << move_to(Vec2d(start_x, start_y), "Move to start position");
gcode << move_to(Vec2d(pattern_config.pattern_start_x, pattern_config.pattern_start_y), "Move to start position");
writer.set_pressure_advance(start_pa);
writer.set_pressure_advance(config.start_pa);
// create anchor and line numbering frame
gcode << draw_box(
config.pattern_start_x,
config.pattern_start_y,
config.print_size_x,
config.frame_size_y
);
}
} // namespace Slic3r

View File

@@ -145,6 +145,9 @@ private:
double frame_size_y() { return std::sin(to_radians(double(m_corner_angle) / 2)) * m_wall_side_length * 2; };
double glyph_start_x(int num_patterns, double center_x);
double glyph_end_x(int num_patterns, double center_x);
double glyph_tab_max_x(int num_patterns, double center_x);
double pattern_shift(int num_patterns, double center_x);
double print_size_x(int num_patterns, double center_x) { return object_size_x(num_patterns) + pattern_shift(num_patterns, center_x); };
double print_size_y(double start_pa, double step_pa, int num_patterns) { return object_size_y(start_pa, step_pa, num_patterns); };
@@ -157,6 +160,55 @@ private:
std::string print_pa_pattern(double start_x, double start_y, double start_pa, double step_pa, int num_patterns);
struct PatternConfig {
PatternConfig(
double start_pa,
double step_pa,
int num_patterns,
double center_x,
double center_y,
double pattern_start_x,
double pattern_start_y,
double print_size_x,
double frame_size_y,
double glyph_end_x,
double glyph_tab_max_x
) :
start_pa(start_pa),
step_pa(step_pa),
num_patterns(num_patterns),
center_x(center_x),
center_y(center_y),
pattern_start_x(pattern_start_x),
pattern_start_y(pattern_start_y),
print_size_x(print_size_x),
frame_size_y(frame_size_y),
glyph_end_x(glyph_end_x),
glyph_tab_max_x(glyph_tab_max_x)
{ };
double start_pa;
double step_pa;
int num_patterns;
double center_x;
double center_y;
double pattern_start_x;
double pattern_start_y;
double print_size_x;
double frame_size_y;
double glyph_end_x;
double glyph_tab_max_x;
};
double m_line_ratio;
double m_extrusion_multiplier;
double m_height_layer;