Files
OrcaSlicer/src/libslic3r/calib.hpp
2023-06-08 09:00:40 -06:00

273 lines
8.1 KiB
C++

#pragma once
#define calib_pressure_advance_dd
#include <string>
#include "Point.hpp"
namespace Slic3r {
class GCode;
enum class CalibMode : int {
Calib_None = 0,
Calib_PA_Line,
Calib_PA_Pattern,
Calib_PA_Tower,
Calib_Temp_Tower,
Calib_Vol_speed_Tower,
Calib_VFA_Tower,
Calib_Retraction_tower
};
struct Calib_Params
{
Calib_Params();
double start, end, step;
bool print_numbers;
CalibMode mode;
};
class CalibPressureAdvance {
protected:
CalibPressureAdvance(GCode* gcodegen);
~CalibPressureAdvance() { };
enum class DrawDigitMode {
Left_To_Right = 0,
Bottom_To_Top
};
std::string move_to(Vec2d pt, std::string comment = std::string());
std::string convert_number_to_string(double num);
std::string draw_digit(double startx, double starty, char c, CalibPressureAdvance::DrawDigitMode mode);
std::string draw_number(double startx, double starty, double value, CalibPressureAdvance::DrawDigitMode mode);
bool is_delta();
void delta_scale_bed_ext(BoundingBoxf& bed_ext);
GCode* mp_gcodegen;
double m_nozzle_diameter;
double m_digit_segment_len;
std::string::size_type m_max_number_length;
double m_number_spacing;
};
class CalibPressureAdvanceLine : public CalibPressureAdvance {
public:
CalibPressureAdvanceLine(GCode* gcodegen) :
CalibPressureAdvance(gcodegen),
m_length_short(20.0),
m_length_long(40.0),
m_space_y(3.5),
m_line_width(0.6),
m_draw_numbers(true)
{ }
;
~CalibPressureAdvanceLine() { };
std::string generate_test(double start_pa = 0, double step_pa = 0.002, int count = 50);
void set_speed(double fast = 100.0, double slow = 20.0) {
m_slow_speed = slow;
m_fast_speed = fast;
}
double& line_width() { return m_line_width; };
bool& draw_numbers() { return m_draw_numbers; }
private:
void delta_modify_start(double& startx, double& starty, int count);
std::string print_pa_lines(double start_x, double start_y, double start_pa, double step_pa, int num);
double m_length_short, m_length_long;
double m_space_y;
double m_slow_speed, m_fast_speed;
double m_line_width;
bool m_draw_numbers;
};
class CalibPressureAdvancePattern : public CalibPressureAdvance {
public:
CalibPressureAdvancePattern(GCode* gcodegen) :
CalibPressureAdvance(gcodegen),
m_line_ratio(112.5),
m_extrusion_multiplier(0.98),
m_num_layers(4),
m_height_layer(0.2),
m_height_first_layer(0.25),
m_speed_first_layer(30),
m_speed_perimeter(100),
m_anchor_perimeters(4),
m_anchor_layer_line_ratio(140),
m_prime_zone_buffer(10.0),
m_wall_count(3),
m_wall_side_length(30.0),
m_corner_angle(90),
m_pattern_spacing(2),
m_encroachment(1. / 3.),
m_glyph_padding_horizontal(1),
m_glyph_padding_vertical(1)
{
m_max_layer_z = m_height_first_layer + ((m_num_layers - 1) * m_height_layer);
}
;
~CalibPressureAdvancePattern() { };
std::vector<std::string> generate_test(
double start_pa = 0,
double end_pa = 0.08,
double step_pa = 0.005
);
int& num_layers() { return m_num_layers; };
std::vector<double> layer_z();
double& max_layer_z() { return m_max_layer_z; }
private:
struct PatternCalc {
PatternCalc(
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;
};
struct PatternSettings {
PatternSettings();
double anchor_line_width;
int anchor_perimeters;
double encroachment;
double extrusion_multiplier;
double first_layer_height;
int first_layer_speed;
double layer_height;
double line_width;
int perim_speed;
};
struct DrawLineOptArgs : PatternSettings {
DrawLineOptArgs();
double extrusion_multiplier;
double height;
double line_width;
int speed;
std::string comment;
};
struct DrawBoxOptArgs : PatternSettings {
DrawBoxOptArgs();
bool is_filled;
int num_perimeters;
double height;
double line_width;
double speed;
};
void delta_modify_start(PatternCalc& pc);
double speed_adjust(int speed) const { return speed * 60; };
double to_radians(double degrees) { return degrees * M_PI / 180; };
double get_distance(double cur_x, double cur_y, double to_x, double to_y);
double line_width() const { return m_nozzle_diameter * m_line_ratio / 100; };
double line_width_anchor() const { return m_nozzle_diameter * m_anchor_layer_line_ratio / 100; };
// from slic3r documentation: spacing = extrusion_width - layer_height * (1 - PI/4)
double line_spacing() { return line_width() - m_height_layer * (1 - M_PI / 4); };
double line_spacing_anchor() { return line_width_anchor() - m_height_first_layer * (1 - M_PI / 4); };
double line_spacing_angle() { return line_spacing() / std::sin(to_radians(m_corner_angle) / 2); };
double max_numbering_height(double start_pa, double step_pa, int num_patterns);
double object_size_x(int num_patterns);
double object_size_y(double start_pa, double step_pa, int num_patterns);
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); };
double pattern_start_x(int num_patterns, double center_x) { return center_x - (object_size_x(num_patterns) + pattern_shift(num_patterns, center_x)) / 2; };
double pattern_start_y(double start_pa, double step_pa, int num_patterns, double center_y) { return center_y - object_size_y(start_pa, step_pa, num_patterns) / 2; };
std::string draw_line(double to_x, double to_y, DrawLineOptArgs opt_args = DrawLineOptArgs());
std::string draw_box(double min_x, double min_y, double size_x, double size_y, DrawBoxOptArgs opt_args = DrawBoxOptArgs());
std::vector<std::string> print_pa_pattern(PatternCalc& calc);
double m_line_ratio;
double m_extrusion_multiplier;
int m_num_layers;
double m_height_layer;
double m_height_first_layer;
double m_max_layer_z;
double m_speed_first_layer;
double m_speed_perimeter;
int m_anchor_perimeters;
int m_anchor_layer_line_ratio;
double m_prime_zone_buffer;
int m_wall_count;
double m_wall_side_length;
int m_corner_angle;
int m_pattern_spacing;
double m_encroachment;
double m_glyph_padding_horizontal;
double m_glyph_padding_vertical;
};
} // namespace Slic3r