mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 10:11:10 -06:00 
			
		
		
		
	#2922 - Port of commit: f42edd35ce by jschuh
				
					
				
			This commit is contained in:
		
							parent
							
								
									a6f5fe7bea
								
							
						
					
					
						commit
						82a52e8b21
					
				
					 7 changed files with 98 additions and 15 deletions
				
			
		|  | @ -121,17 +121,19 @@ public: | |||
|     unsigned int extruder_id; | ||||
|     // Id of the color, used for visualization purposes in the color printing case.
 | ||||
|     unsigned int cp_color_id; | ||||
|     // Fan speed for the extrusion, used for visualization purposes.
 | ||||
|     float fan_speed; | ||||
| 
 | ||||
|     ExtrusionPath(ExtrusionRole role) : mm3_per_mm(-1), width(-1), height(-1), feedrate(0.0f), extruder_id(0), cp_color_id(0), m_role(role) {} | ||||
|     ExtrusionPath(ExtrusionRole role, double mm3_per_mm, float width, float height) : mm3_per_mm(mm3_per_mm), width(width), height(height), feedrate(0.0f), extruder_id(0), cp_color_id(0), m_role(role) {} | ||||
|     ExtrusionPath(const ExtrusionPath &rhs) : polyline(rhs.polyline), mm3_per_mm(rhs.mm3_per_mm), width(rhs.width), height(rhs.height), feedrate(rhs.feedrate), extruder_id(rhs.extruder_id), cp_color_id(rhs.cp_color_id), m_role(rhs.m_role) {} | ||||
| 	ExtrusionPath(const Polyline &polyline, const ExtrusionPath &rhs) : polyline(polyline), mm3_per_mm(rhs.mm3_per_mm), width(rhs.width), height(rhs.height), feedrate(rhs.feedrate), extruder_id(rhs.extruder_id), cp_color_id(rhs.cp_color_id), m_role(rhs.m_role) {} | ||||
| 	ExtrusionPath(ExtrusionPath &&rhs) : polyline(std::move(rhs.polyline)), mm3_per_mm(rhs.mm3_per_mm), width(rhs.width), height(rhs.height), feedrate(rhs.feedrate), extruder_id(rhs.extruder_id), cp_color_id(rhs.cp_color_id), m_role(rhs.m_role) {} | ||||
| 	ExtrusionPath(Polyline &&polyline, const ExtrusionPath &rhs) : polyline(std::move(polyline)), mm3_per_mm(rhs.mm3_per_mm), width(rhs.width), height(rhs.height), feedrate(rhs.feedrate), extruder_id(rhs.extruder_id), cp_color_id(rhs.cp_color_id), m_role(rhs.m_role) {} | ||||
|     ExtrusionPath(ExtrusionRole role) : mm3_per_mm(-1), width(-1), height(-1), feedrate(0.0f), extruder_id(0), cp_color_id(0), fan_speed(0.0f), m_role(role) {}; | ||||
|     ExtrusionPath(ExtrusionRole role, double mm3_per_mm, float width, float height) : mm3_per_mm(mm3_per_mm), width(width), height(height), feedrate(0.0f), extruder_id(0), cp_color_id(0), fan_speed(0.0f), m_role(role) {}; | ||||
|     ExtrusionPath(const ExtrusionPath& rhs) : polyline(rhs.polyline), mm3_per_mm(rhs.mm3_per_mm), width(rhs.width), height(rhs.height), feedrate(rhs.feedrate), extruder_id(rhs.extruder_id), cp_color_id(rhs.cp_color_id), fan_speed(rhs.fan_speed), m_role(rhs.m_role) {} | ||||
|     ExtrusionPath(ExtrusionPath&& rhs) : polyline(std::move(rhs.polyline)), mm3_per_mm(rhs.mm3_per_mm), width(rhs.width), height(rhs.height), feedrate(rhs.feedrate), extruder_id(rhs.extruder_id), cp_color_id(rhs.cp_color_id), fan_speed(rhs.fan_speed), m_role(rhs.m_role) {} | ||||
|     ExtrusionPath(const Polyline &polyline, const ExtrusionPath &rhs) : polyline(polyline), mm3_per_mm(rhs.mm3_per_mm), width(rhs.width), height(rhs.height), feedrate(rhs.feedrate), extruder_id(rhs.extruder_id), cp_color_id(rhs.cp_color_id), fan_speed(rhs.fan_speed), m_role(rhs.m_role) {} | ||||
|     ExtrusionPath(Polyline &&polyline, const ExtrusionPath &rhs) : polyline(std::move(polyline)), mm3_per_mm(rhs.mm3_per_mm), width(rhs.width), height(rhs.height), feedrate(rhs.feedrate), extruder_id(rhs.extruder_id), cp_color_id(rhs.cp_color_id), fan_speed(rhs.fan_speed), m_role(rhs.m_role) {} | ||||
| //    ExtrusionPath(ExtrusionRole role, const Flow &flow) : m_role(role), mm3_per_mm(flow.mm3_per_mm()), width(flow.width), height(flow.height), feedrate(0.0f), extruder_id(0) {};
 | ||||
| 
 | ||||
|     ExtrusionPath& operator=(const ExtrusionPath &rhs) { m_role = rhs.m_role; this->mm3_per_mm = rhs.mm3_per_mm; this->width = rhs.width; this->height = rhs.height; this->feedrate = rhs.feedrate; this->extruder_id = rhs.extruder_id; this->cp_color_id = rhs.cp_color_id; this->polyline = rhs.polyline; return *this; } | ||||
|     ExtrusionPath& operator=(ExtrusionPath &&rhs) { m_role = rhs.m_role; this->mm3_per_mm = rhs.mm3_per_mm; this->width = rhs.width; this->height = rhs.height; this->feedrate = rhs.feedrate; this->extruder_id = rhs.extruder_id; this->cp_color_id = rhs.cp_color_id; this->polyline = std::move(rhs.polyline); return *this; } | ||||
|     ExtrusionPath& operator=(const ExtrusionPath& rhs) { m_role = rhs.m_role; this->mm3_per_mm = rhs.mm3_per_mm; this->width = rhs.width; this->height = rhs.height; this->feedrate = rhs.feedrate, this->extruder_id = rhs.extruder_id, this->cp_color_id = rhs.cp_color_id, this->fan_speed = rhs.fan_speed, this->polyline = rhs.polyline; return *this; } | ||||
|     ExtrusionPath& operator=(ExtrusionPath&& rhs) { m_role = rhs.m_role; this->mm3_per_mm = rhs.mm3_per_mm; this->width = rhs.width; this->height = rhs.height; this->feedrate = rhs.feedrate, this->extruder_id = rhs.extruder_id, this->cp_color_id = rhs.cp_color_id, this->fan_speed = rhs.fan_speed, this->polyline = std::move(rhs.polyline); return *this; } | ||||
| 
 | ||||
| 	ExtrusionEntity* clone() const override { return new ExtrusionPath(*this); } | ||||
|     // Create a new object, initialize it with this object using the move semantics.
 | ||||
|  |  | |||
|  | @ -20,6 +20,7 @@ static const unsigned int DEFAULT_EXTRUDER_ID = 0; | |||
| static const unsigned int DEFAULT_COLOR_PRINT_ID = 0; | ||||
| static const Slic3r::Vec3d DEFAULT_START_POSITION = Slic3r::Vec3d(0.0f, 0.0f, 0.0f); | ||||
| static const float DEFAULT_START_EXTRUSION = 0.0f; | ||||
| static const float DEFAULT_FAN_SPEED = 0.0f; | ||||
| 
 | ||||
| namespace Slic3r { | ||||
| 
 | ||||
|  | @ -36,21 +37,23 @@ const float GCodeAnalyzer::Default_Height = 0.0f; | |||
| GCodeAnalyzer::Metadata::Metadata() | ||||
|     : extrusion_role(erNone) | ||||
|     , extruder_id(DEFAULT_EXTRUDER_ID) | ||||
|     , cp_color_id(DEFAULT_COLOR_PRINT_ID) | ||||
|     , mm3_per_mm(GCodeAnalyzer::Default_mm3_per_mm) | ||||
|     , width(GCodeAnalyzer::Default_Width) | ||||
|     , height(GCodeAnalyzer::Default_Height) | ||||
|     , feedrate(DEFAULT_FEEDRATE) | ||||
|     , fan_speed(DEFAULT_FAN_SPEED) | ||||
|     , cp_color_id(DEFAULT_COLOR_PRINT_ID) | ||||
| { | ||||
| } | ||||
| 
 | ||||
| GCodeAnalyzer::Metadata::Metadata(ExtrusionRole extrusion_role, unsigned int extruder_id, double mm3_per_mm, float width, float height, float feedrate, unsigned int cp_color_id/* = 0*/) | ||||
| GCodeAnalyzer::Metadata::Metadata(ExtrusionRole extrusion_role, unsigned int extruder_id, double mm3_per_mm, float width, float height, float feedrate, float fan_speed, unsigned int cp_color_id/* = 0*/) | ||||
|     : extrusion_role(extrusion_role) | ||||
|     , extruder_id(extruder_id) | ||||
|     , mm3_per_mm(mm3_per_mm) | ||||
|     , width(width) | ||||
|     , height(height) | ||||
|     , feedrate(feedrate) | ||||
|     , fan_speed(fan_speed) | ||||
|     , cp_color_id(cp_color_id) | ||||
| { | ||||
| } | ||||
|  | @ -75,15 +78,18 @@ bool GCodeAnalyzer::Metadata::operator != (const GCodeAnalyzer::Metadata& other) | |||
|     if (feedrate != other.feedrate) | ||||
|         return true; | ||||
| 
 | ||||
|     if (fan_speed != other.fan_speed) | ||||
|         return true; | ||||
| 
 | ||||
|     if (cp_color_id != other.cp_color_id) | ||||
|         return true; | ||||
| 
 | ||||
|     return false; | ||||
| } | ||||
| 
 | ||||
| GCodeAnalyzer::GCodeMove::GCodeMove(GCodeMove::EType type, ExtrusionRole extrusion_role, unsigned int extruder_id, double mm3_per_mm, float width, float height, float feedrate, const Vec3d& start_position, const Vec3d& end_position, float delta_extruder, unsigned int cp_color_id/* = 0*/) | ||||
| GCodeAnalyzer::GCodeMove::GCodeMove(GCodeMove::EType type, ExtrusionRole extrusion_role, unsigned int extruder_id, double mm3_per_mm, float width, float height, float feedrate, const Vec3d& start_position, const Vec3d& end_position, float delta_extruder, float fan_speed, unsigned int cp_color_id/* = 0*/) | ||||
|     : type(type) | ||||
|     , data(extrusion_role, extruder_id, mm3_per_mm, width, height, feedrate, cp_color_id) | ||||
|     , data(extrusion_role, extruder_id, mm3_per_mm, width, height, feedrate, fan_speed, cp_color_id) | ||||
|     , start_position(start_position) | ||||
|     , end_position(end_position) | ||||
|     , delta_extruder(delta_extruder) | ||||
|  | @ -133,6 +139,7 @@ void GCodeAnalyzer::reset() | |||
|     _set_feedrate(DEFAULT_FEEDRATE); | ||||
|     _set_start_position(DEFAULT_START_POSITION); | ||||
|     _set_start_extrusion(DEFAULT_START_EXTRUSION); | ||||
|     _set_fan_speed(DEFAULT_FAN_SPEED); | ||||
|     _reset_axes_position(); | ||||
|     _reset_cached_position(); | ||||
| 
 | ||||
|  | @ -259,6 +266,16 @@ void GCodeAnalyzer::_process_gcode_line(GCodeReader&, const GCodeReader::GCodeLi | |||
|                         _processM83(line); | ||||
|                         break; | ||||
|                     } | ||||
|                 case 106: // Set fan speed
 | ||||
|                     { | ||||
|                         _processM106(line); | ||||
|                         break; | ||||
|                     } | ||||
|                 case 107: // Disable fan
 | ||||
|                     { | ||||
|                         _processM107(line); | ||||
|                         break; | ||||
|                     } | ||||
|                 case 108: | ||||
|                 case 135: | ||||
|                     { | ||||
|  | @ -448,6 +465,24 @@ void GCodeAnalyzer::_processM83(const GCodeReader::GCodeLine& line) | |||
|     _set_e_local_positioning_type(Relative); | ||||
| } | ||||
| 
 | ||||
| void GCodeAnalyzer::_processM106(const GCodeReader::GCodeLine& line) | ||||
| { | ||||
|     if (!line.has('P')) | ||||
|     { | ||||
|         // The absence of P means the print cooling fan, so ignore anything else.
 | ||||
|         float new_fan_speed; | ||||
|         if (line.has_value('S', new_fan_speed)) | ||||
|             _set_fan_speed((100.0f / 256.0f) * new_fan_speed); | ||||
|         else | ||||
|             _set_fan_speed(100.0f); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| void GCodeAnalyzer::_processM107(const GCodeReader::GCodeLine& line) | ||||
| { | ||||
|     _set_fan_speed(0.0f); | ||||
| } | ||||
| 
 | ||||
| void GCodeAnalyzer::_processM108orM135(const GCodeReader::GCodeLine& line) | ||||
| { | ||||
|     // These M-codes are used by MakerWare and Sailfish to change active tool.
 | ||||
|  | @ -726,6 +761,16 @@ float GCodeAnalyzer::_get_feedrate() const | |||
|     return m_state.data.feedrate; | ||||
| } | ||||
| 
 | ||||
| void GCodeAnalyzer::_set_fan_speed(float fan_speed_percentage) | ||||
| { | ||||
|     m_state.data.fan_speed = fan_speed_percentage; | ||||
| } | ||||
| 
 | ||||
| float GCodeAnalyzer::_get_fan_speed() const | ||||
| { | ||||
|     return m_state.data.fan_speed; | ||||
| } | ||||
| 
 | ||||
| void GCodeAnalyzer::_set_axis_position(EAxis axis, float position) | ||||
| { | ||||
|     m_state.position[axis] = position; | ||||
|  | @ -798,7 +843,7 @@ void GCodeAnalyzer::_store_move(GCodeAnalyzer::GCodeMove::EType type) | |||
| 
 | ||||
|     Vec3d start_position = _get_start_position() + extruder_offset; | ||||
|     Vec3d end_position = _get_end_position() + extruder_offset; | ||||
|     it->second.emplace_back(type, _get_extrusion_role(), extruder_id, _get_mm3_per_mm(), _get_width(), _get_height(), _get_feedrate(), start_position, end_position, _get_delta_extrusion(), _get_cp_color_id()); | ||||
|     it->second.emplace_back(type, _get_extrusion_role(), extruder_id, _get_mm3_per_mm(), _get_width(), _get_height(), _get_feedrate(), start_position, end_position, _get_delta_extrusion(), _get_fan_speed(), _get_cp_color_id()); | ||||
| } | ||||
| 
 | ||||
| bool GCodeAnalyzer::_is_valid_extrusion_role(int value) const | ||||
|  | @ -834,6 +879,7 @@ void GCodeAnalyzer::_calc_gcode_preview_extrusion_layers(GCodePreviewData& previ | |||
|                 path.polyline = polyline; | ||||
|                 path.feedrate = data.feedrate; | ||||
|                 path.extruder_id = data.extruder_id; | ||||
|                 path.fan_speed = data.fan_speed; | ||||
|                 path.cp_color_id = data.cp_color_id; | ||||
| 
 | ||||
|                 get_layer_at_z(preview_data.extrusion.layers, z).paths.push_back(path); | ||||
|  | @ -854,6 +900,7 @@ void GCodeAnalyzer::_calc_gcode_preview_extrusion_layers(GCodePreviewData& previ | |||
|     GCodePreviewData::Range width_range; | ||||
|     GCodePreviewData::Range feedrate_range; | ||||
|     GCodePreviewData::Range volumetric_rate_range; | ||||
|     GCodePreviewData::Range fan_speed_range; | ||||
| 
 | ||||
|     // to avoid to call the callback too often
 | ||||
|     unsigned int cancel_callback_threshold = (unsigned int)std::max((int)extrude_moves->second.size() / 25, 1); | ||||
|  | @ -888,6 +935,7 @@ void GCodeAnalyzer::_calc_gcode_preview_extrusion_layers(GCodePreviewData& previ | |||
|             width_range.update_from(move.data.width); | ||||
|             feedrate_range.update_from(move.data.feedrate); | ||||
|             volumetric_rate_range.update_from(volumetric_rate); | ||||
|             fan_speed_range.update_from(move.data.fan_speed); | ||||
|         } | ||||
|         else | ||||
|             // append end vertex of the move to current polyline
 | ||||
|  | @ -906,6 +954,7 @@ void GCodeAnalyzer::_calc_gcode_preview_extrusion_layers(GCodePreviewData& previ | |||
|     preview_data.ranges.width.update_from(width_range); | ||||
|     preview_data.ranges.feedrate.update_from(feedrate_range); | ||||
|     preview_data.ranges.volumetric_rate.update_from(volumetric_rate_range); | ||||
|     preview_data.ranges.fan_speed.update_from(fan_speed_range); | ||||
| 
 | ||||
|     // we need to sort the layers by their z as they can be shuffled in case of sequential prints
 | ||||
|     std::sort(preview_data.extrusion.layers.begin(), preview_data.extrusion.layers.end(), [](const GCodePreviewData::Extrusion::Layer& l1, const GCodePreviewData::Extrusion::Layer& l2)->bool { return l1.z < l2.z; }); | ||||
|  |  | |||
|  | @ -54,10 +54,11 @@ public: | |||
|         float width;     // mm
 | ||||
|         float height;    // mm
 | ||||
|         float feedrate;  // mm/s
 | ||||
|         float fan_speed; // percentage
 | ||||
|         unsigned int cp_color_id; | ||||
| 
 | ||||
|         Metadata(); | ||||
|         Metadata(ExtrusionRole extrusion_role, unsigned int extruder_id, double mm3_per_mm, float width, float height, float feedrate, unsigned int cp_color_id = 0); | ||||
|         Metadata(ExtrusionRole extrusion_role, unsigned int extruder_id, double mm3_per_mm, float width, float height, float feedrate, float fan_speed, unsigned int cp_color_id = 0); | ||||
| 
 | ||||
|         bool operator != (const Metadata& other) const; | ||||
|     }; | ||||
|  | @ -81,7 +82,7 @@ public: | |||
|         Vec3d end_position; | ||||
|         float delta_extruder; | ||||
| 
 | ||||
|         GCodeMove(EType type, ExtrusionRole extrusion_role, unsigned int extruder_id, double mm3_per_mm, float width, float height, float feedrate, const Vec3d& start_position, const Vec3d& end_position, float delta_extruder, unsigned int cp_color_id = 0); | ||||
|         GCodeMove(EType type, ExtrusionRole extrusion_role, unsigned int extruder_id, double mm3_per_mm, float width, float height, float feedrate, const Vec3d& start_position, const Vec3d& end_position, float delta_extruder, float fan_speed, unsigned int cp_color_id = 0); | ||||
|         GCodeMove(EType type, const Metadata& data, const Vec3d& start_position, const Vec3d& end_position, float delta_extruder); | ||||
|     }; | ||||
| 
 | ||||
|  | @ -171,6 +172,12 @@ private: | |||
|     // Set extruder to relative mode
 | ||||
|     void _processM83(const GCodeReader::GCodeLine& line); | ||||
| 
 | ||||
|     // Set fan speed
 | ||||
|     void _processM106(const GCodeReader::GCodeLine& line); | ||||
| 
 | ||||
|     // Disable fan
 | ||||
|     void _processM107(const GCodeReader::GCodeLine& line); | ||||
| 
 | ||||
|     // Set tool (MakerWare and Sailfish flavor)
 | ||||
|     void _processM108orM135(const GCodeReader::GCodeLine& line); | ||||
| 
 | ||||
|  | @ -233,6 +240,9 @@ private: | |||
|     void _set_feedrate(float feedrate_mm_sec); | ||||
|     float _get_feedrate() const; | ||||
| 
 | ||||
|     void _set_fan_speed(float fan_speed_percentage); | ||||
|     float _get_fan_speed() const; | ||||
| 
 | ||||
|     void _set_axis_position(EAxis axis, float position); | ||||
|     float _get_axis_position(EAxis axis) const; | ||||
| 
 | ||||
|  |  | |||
|  | @ -241,6 +241,7 @@ void GCodePreviewData::set_default() | |||
|     ::memcpy((void*)ranges.height.colors, (const void*)Range::Default_Colors, Range::Colors_Count * sizeof(Color)); | ||||
|     ::memcpy((void*)ranges.width.colors, (const void*)Range::Default_Colors, Range::Colors_Count * sizeof(Color)); | ||||
|     ::memcpy((void*)ranges.feedrate.colors, (const void*)Range::Default_Colors, Range::Colors_Count * sizeof(Color)); | ||||
|     ::memcpy((void*)ranges.fan_speed.colors, (const void*)Range::Default_Colors, Range::Colors_Count * sizeof(Color)); | ||||
|     ::memcpy((void*)ranges.volumetric_rate.colors, (const void*)Range::Default_Colors, Range::Colors_Count * sizeof(Color)); | ||||
| 
 | ||||
|     extrusion.set_default(); | ||||
|  | @ -287,6 +288,11 @@ GCodePreviewData::Color GCodePreviewData::get_feedrate_color(float feedrate) con | |||
|     return ranges.feedrate.get_color_at(feedrate); | ||||
| } | ||||
| 
 | ||||
| GCodePreviewData::Color GCodePreviewData::get_fan_speed_color(float fan_speed) const | ||||
| { | ||||
|     return ranges.fan_speed.get_color_at(fan_speed); | ||||
| } | ||||
| 
 | ||||
| GCodePreviewData::Color GCodePreviewData::get_volumetric_rate_color(float rate) const | ||||
| { | ||||
|     return ranges.volumetric_rate.get_color_at(rate); | ||||
|  | @ -358,6 +364,8 @@ std::string GCodePreviewData::get_legend_title() const | |||
|         return L("Width (mm)"); | ||||
|     case Extrusion::Feedrate: | ||||
|         return L("Speed (mm/s)"); | ||||
|     case Extrusion::FanSpeed: | ||||
|         return L("Fan Speed (%)"); | ||||
|     case Extrusion::VolumetricRate: | ||||
|         return L("Volumetric flow rate (mm³/s)"); | ||||
|     case Extrusion::Tool: | ||||
|  | @ -421,6 +429,11 @@ GCodePreviewData::LegendItemsList GCodePreviewData::get_legend_items(const std:: | |||
|             Helper::FillListFromRange(items, ranges.feedrate, 1, 1.0f); | ||||
|             break; | ||||
|         } | ||||
|     case Extrusion::FanSpeed: | ||||
|         { | ||||
|             Helper::FillListFromRange(items, ranges.fan_speed, 0, 1.0f); | ||||
|             break; | ||||
|         } | ||||
|     case Extrusion::VolumetricRate: | ||||
|         { | ||||
|             Helper::FillListFromRange(items, ranges.volumetric_rate, 3, 1.0f); | ||||
|  |  | |||
|  | @ -52,6 +52,8 @@ public: | |||
|         Range width; | ||||
|         // Color mapping by feedrate.
 | ||||
|         Range feedrate; | ||||
|         // Color mapping by fan speed.
 | ||||
|         Range fan_speed; | ||||
|         // Color mapping by volumetric extrusion rate.
 | ||||
|         Range volumetric_rate; | ||||
|     }; | ||||
|  | @ -74,6 +76,7 @@ public: | |||
|             Height, | ||||
|             Width, | ||||
|             Feedrate, | ||||
|             FanSpeed, | ||||
|             VolumetricRate, | ||||
|             Tool, | ||||
|             ColorPrint, | ||||
|  | @ -205,6 +208,7 @@ public: | |||
|     Color get_height_color(float height) const; | ||||
|     Color get_width_color(float width) const; | ||||
|     Color get_feedrate_color(float feedrate) const; | ||||
|     Color get_fan_speed_color(float fan_speed) const; | ||||
|     Color get_volumetric_rate_color(float rate) const; | ||||
| 
 | ||||
|     void set_extrusion_role_color(const std::string& role_name, float red, float green, float blue, float alpha); | ||||
|  |  | |||
|  | @ -5001,6 +5001,8 @@ void GLCanvas3D::_load_gcode_extrusion_paths(const GCodePreviewData& preview_dat | |||
|                 return path.width; | ||||
|             case GCodePreviewData::Extrusion::Feedrate: | ||||
|                 return path.feedrate; | ||||
|             case GCodePreviewData::Extrusion::FanSpeed: | ||||
|                 return path.fan_speed; | ||||
|             case GCodePreviewData::Extrusion::VolumetricRate: | ||||
|                 return path.feedrate * (float)path.mm3_per_mm; | ||||
|             case GCodePreviewData::Extrusion::Tool: | ||||
|  | @ -5026,6 +5028,8 @@ void GLCanvas3D::_load_gcode_extrusion_paths(const GCodePreviewData& preview_dat | |||
|                 return data.get_width_color(value); | ||||
|             case GCodePreviewData::Extrusion::Feedrate: | ||||
|                 return data.get_feedrate_color(value); | ||||
|             case GCodePreviewData::Extrusion::FanSpeed: | ||||
|                 return data.get_fan_speed_color(value); | ||||
|             case GCodePreviewData::Extrusion::VolumetricRate: | ||||
|                 return data.get_volumetric_rate_color(value); | ||||
|             case GCodePreviewData::Extrusion::Tool: | ||||
|  |  | |||
|  | @ -221,6 +221,7 @@ bool Preview::init(wxWindow* parent, Bed3D& bed, Camera& camera, GLToolbar& view | |||
|     m_choice_view_type->Append(_(L("Height"))); | ||||
|     m_choice_view_type->Append(_(L("Width"))); | ||||
|     m_choice_view_type->Append(_(L("Speed"))); | ||||
|     m_choice_view_type->Append(_(L("Fan speed"))); | ||||
|     m_choice_view_type->Append(_(L("Volumetric flow rate"))); | ||||
|     m_choice_view_type->Append(_(L("Tool"))); | ||||
|     m_choice_view_type->Append(_(L("Color Print"))); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Enrico Turri
						Enrico Turri