mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-07-11 08:47:52 -06:00
GCodeViewer -> Imgui slider for sequential view replaced by DoubleSlider::Control (wip)
This commit is contained in:
parent
32529b66ac
commit
5be901547e
12 changed files with 463 additions and 52 deletions
|
@ -24,7 +24,9 @@ class Print;
|
||||||
class PrintObject;
|
class PrintObject;
|
||||||
class ModelObject;
|
class ModelObject;
|
||||||
class GCode;
|
class GCode;
|
||||||
|
#if !ENABLE_GCODE_VIEWER
|
||||||
class GCodePreviewData;
|
class GCodePreviewData;
|
||||||
|
#endif // !ENABLE_GCODE_VIEWER
|
||||||
enum class SlicingMode : uint32_t;
|
enum class SlicingMode : uint32_t;
|
||||||
|
|
||||||
// Print step IDs for keeping track of the print state.
|
// Print step IDs for keeping track of the print state.
|
||||||
|
|
|
@ -55,6 +55,7 @@
|
||||||
|
|
||||||
// Enable G-Code viewer
|
// Enable G-Code viewer
|
||||||
#define ENABLE_GCODE_VIEWER (1 && ENABLE_2_3_0_ALPHA1)
|
#define ENABLE_GCODE_VIEWER (1 && ENABLE_2_3_0_ALPHA1)
|
||||||
|
#define ENABLE_GCODE_USE_WXWIDGETS_SLIDER (1 && ENABLE_GCODE_VIEWER)
|
||||||
#define ENABLE_GCODE_VIEWER_STATISTICS (0 && ENABLE_GCODE_VIEWER)
|
#define ENABLE_GCODE_VIEWER_STATISTICS (0 && ENABLE_GCODE_VIEWER)
|
||||||
|
|
||||||
#endif // _prusaslicer_technologies_h_
|
#endif // _prusaslicer_technologies_h_
|
||||||
|
|
|
@ -17,7 +17,9 @@
|
||||||
namespace Slic3r {
|
namespace Slic3r {
|
||||||
|
|
||||||
class DynamicPrintConfig;
|
class DynamicPrintConfig;
|
||||||
|
#if !ENABLE_GCODE_VIEWER
|
||||||
class GCodePreviewData;
|
class GCodePreviewData;
|
||||||
|
#endif // !ENABLE_GCODE_VIEWER
|
||||||
class Model;
|
class Model;
|
||||||
class SLAPrint;
|
class SLAPrint;
|
||||||
class SL1Archive;
|
class SL1Archive;
|
||||||
|
|
|
@ -20,7 +20,9 @@
|
||||||
#include <wx/bmpcbox.h>
|
#include <wx/bmpcbox.h>
|
||||||
#include <wx/statline.h>
|
#include <wx/statline.h>
|
||||||
#include <wx/dcclient.h>
|
#include <wx/dcclient.h>
|
||||||
|
#if !ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
#include <wx/numformatter.h>
|
#include <wx/numformatter.h>
|
||||||
|
#endif // !ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
#include <wx/colordlg.h>
|
#include <wx/colordlg.h>
|
||||||
|
|
||||||
#include <cmath>
|
#include <cmath>
|
||||||
|
@ -408,22 +410,22 @@ void Control::render()
|
||||||
// draw line
|
// draw line
|
||||||
draw_scroll_line(dc, lower_pos, higher_pos);
|
draw_scroll_line(dc, lower_pos, higher_pos);
|
||||||
|
|
||||||
//draw color print ticks
|
// draw color print ticks
|
||||||
draw_ticks(dc);
|
draw_ticks(dc);
|
||||||
|
|
||||||
// draw both sliders
|
// draw both sliders
|
||||||
draw_thumbs(dc, lower_pos, higher_pos);
|
draw_thumbs(dc, lower_pos, higher_pos);
|
||||||
|
|
||||||
//draw lock/unlock
|
// draw lock/unlock
|
||||||
draw_one_layer_icon(dc);
|
draw_one_layer_icon(dc);
|
||||||
|
|
||||||
//draw revert bitmap (if it's shown)
|
// draw revert bitmap (if it's shown)
|
||||||
draw_revert_icon(dc);
|
draw_revert_icon(dc);
|
||||||
|
|
||||||
//draw cog bitmap (if it's shown)
|
// draw cog bitmap (if it's shown)
|
||||||
draw_cog_icon(dc);
|
draw_cog_icon(dc);
|
||||||
|
|
||||||
//draw mouse position
|
// draw mouse position
|
||||||
draw_tick_on_mouse_position(dc);
|
draw_tick_on_mouse_position(dc);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -535,10 +537,21 @@ wxString Control::get_label(int tick) const
|
||||||
if (value >= m_values.size())
|
if (value >= m_values.size())
|
||||||
return "ErrVal";
|
return "ErrVal";
|
||||||
|
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
if (m_draw_mode == dmSequentialGCodeView)
|
||||||
|
return wxString::Format("%d", static_cast<unsigned int>(m_values[value]));
|
||||||
|
else {
|
||||||
const wxString str = m_values.empty() ?
|
const wxString str = m_values.empty() ?
|
||||||
wxNumberFormatter::ToString(m_label_koef*value, 2, wxNumberFormatter::Style_None) :
|
wxString::Format("%.*f", 2, m_label_koef * value) :
|
||||||
|
wxString::Format("%.*f", 2, m_values[value]);
|
||||||
|
return format_wxstr("%1%\n(%2%)", str, m_values.empty() ? value : value + 1);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
const wxString str = m_values.empty() ?
|
||||||
|
wxNumberFormatter::ToString(m_label_koef * value, 2, wxNumberFormatter::Style_None) :
|
||||||
wxNumberFormatter::ToString(m_values[value], 2, wxNumberFormatter::Style_None);
|
wxNumberFormatter::ToString(m_values[value], 2, wxNumberFormatter::Style_None);
|
||||||
return format_wxstr("%1%\n(%2%)", str, m_values.empty() ? value : value+1);
|
return format_wxstr("%1%\n(%2%)", str, m_values.empty() ? value : value + 1);
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
}
|
}
|
||||||
|
|
||||||
void Control::draw_tick_text(wxDC& dc, const wxPoint& pos, int tick, bool right_side/*=true*/) const
|
void Control::draw_tick_text(wxDC& dc, const wxPoint& pos, int tick, bool right_side/*=true*/) const
|
||||||
|
@ -779,6 +792,11 @@ void Control::draw_colored_band(wxDC& dc)
|
||||||
|
|
||||||
void Control::draw_one_layer_icon(wxDC& dc)
|
void Control::draw_one_layer_icon(wxDC& dc)
|
||||||
{
|
{
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
if (m_draw_mode == dmSequentialGCodeView)
|
||||||
|
return;
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
|
||||||
const wxBitmap& icon = m_is_one_layer ?
|
const wxBitmap& icon = m_is_one_layer ?
|
||||||
m_focus == fiOneLayerIcon ? m_bmp_one_layer_lock_off.bmp() : m_bmp_one_layer_lock_on.bmp() :
|
m_focus == fiOneLayerIcon ? m_bmp_one_layer_lock_off.bmp() : m_bmp_one_layer_lock_on.bmp() :
|
||||||
m_focus == fiOneLayerIcon ? m_bmp_one_layer_unlock_off.bmp() : m_bmp_one_layer_unlock_on.bmp();
|
m_focus == fiOneLayerIcon ? m_bmp_one_layer_unlock_off.bmp() : m_bmp_one_layer_unlock_on.bmp();
|
||||||
|
@ -1284,7 +1302,11 @@ void Control::OnWheel(wxMouseEvent& event)
|
||||||
ssLower : ssHigher;
|
ssLower : ssHigher;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
move_current_thumb((m_draw_mode == dmSequentialGCodeView) ? event.GetWheelRotation() < 0 : event.GetWheelRotation() > 0);
|
||||||
|
#else
|
||||||
move_current_thumb(event.GetWheelRotation() > 0);
|
move_current_thumb(event.GetWheelRotation() > 0);
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
}
|
}
|
||||||
|
|
||||||
void Control::OnKeyDown(wxKeyEvent &event)
|
void Control::OnKeyDown(wxKeyEvent &event)
|
||||||
|
@ -1306,20 +1328,34 @@ void Control::OnKeyDown(wxKeyEvent &event)
|
||||||
UseDefaultColors(false);
|
UseDefaultColors(false);
|
||||||
else if (is_horizontal())
|
else if (is_horizontal())
|
||||||
{
|
{
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
if (m_is_focused)
|
||||||
|
{
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
if (key == WXK_LEFT || key == WXK_RIGHT)
|
if (key == WXK_LEFT || key == WXK_RIGHT)
|
||||||
move_current_thumb(key == WXK_LEFT);
|
move_current_thumb(key == WXK_LEFT);
|
||||||
else if (key == WXK_UP || key == WXK_DOWN) {
|
else if (key == WXK_UP || key == WXK_DOWN) {
|
||||||
m_selection = key == WXK_UP ? ssHigher : ssLower;
|
m_selection = key == WXK_UP ? ssHigher : ssLower;
|
||||||
Refresh();
|
Refresh();
|
||||||
}
|
}
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
}
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
if (m_is_focused)
|
||||||
|
{
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
if (key == WXK_LEFT || key == WXK_RIGHT) {
|
if (key == WXK_LEFT || key == WXK_RIGHT) {
|
||||||
m_selection = key == WXK_LEFT ? ssHigher : ssLower;
|
m_selection = key == WXK_LEFT ? ssHigher : ssLower;
|
||||||
Refresh();
|
Refresh();
|
||||||
}
|
}
|
||||||
else if (key == WXK_UP || key == WXK_DOWN)
|
else if (key == WXK_UP || key == WXK_DOWN)
|
||||||
move_current_thumb(key == WXK_UP);
|
move_current_thumb(key == WXK_UP);
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
}
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
}
|
}
|
||||||
|
|
||||||
event.Skip(); // !Needed to have EVT_CHAR generated as well
|
event.Skip(); // !Needed to have EVT_CHAR generated as well
|
||||||
|
|
|
@ -73,6 +73,9 @@ enum DrawMode
|
||||||
dmRegular,
|
dmRegular,
|
||||||
dmSlaPrint,
|
dmSlaPrint,
|
||||||
dmSequentialFffPrint,
|
dmSequentialFffPrint,
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
dmSequentialGCodeView,
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
};
|
};
|
||||||
|
|
||||||
using t_mode = CustomGCode::Mode;
|
using t_mode = CustomGCode::Mode;
|
||||||
|
@ -211,6 +214,9 @@ public:
|
||||||
void SetTicksValues(const Slic3r::CustomGCode::Info &custom_gcode_per_print_z);
|
void SetTicksValues(const Slic3r::CustomGCode::Info &custom_gcode_per_print_z);
|
||||||
|
|
||||||
void SetDrawMode(bool is_sla_print, bool is_sequential_print);
|
void SetDrawMode(bool is_sla_print, bool is_sequential_print);
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
void SetDrawMode(DrawMode mode) { m_draw_mode = mode; }
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
|
||||||
void SetManipulationMode(t_mode mode) { m_mode = mode; }
|
void SetManipulationMode(t_mode mode) { m_mode = mode; }
|
||||||
t_mode GetManipulationMode() const { return m_mode; }
|
t_mode GetManipulationMode() const { return m_mode; }
|
||||||
|
@ -223,7 +229,7 @@ public:
|
||||||
bool is_higher_at_max() const { return m_higher_value == m_max_value; }
|
bool is_higher_at_max() const { return m_higher_value == m_max_value; }
|
||||||
bool is_full_span() const { return this->is_lower_at_min() && this->is_higher_at_max(); }
|
bool is_full_span() const { return this->is_lower_at_min() && this->is_higher_at_max(); }
|
||||||
|
|
||||||
void OnPaint(wxPaintEvent& ) { render();}
|
void OnPaint(wxPaintEvent& ) { render(); }
|
||||||
void OnLeftDown(wxMouseEvent& event);
|
void OnLeftDown(wxMouseEvent& event);
|
||||||
void OnMotion(wxMouseEvent& event);
|
void OnMotion(wxMouseEvent& event);
|
||||||
void OnLeftUp(wxMouseEvent& event);
|
void OnLeftUp(wxMouseEvent& event);
|
||||||
|
|
|
@ -324,7 +324,9 @@ void GCodeViewer::render() const
|
||||||
m_sequential_view.marker.render();
|
m_sequential_view.marker.render();
|
||||||
render_shells();
|
render_shells();
|
||||||
render_legend();
|
render_legend();
|
||||||
|
#if !ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
render_sequential_bar();
|
render_sequential_bar();
|
||||||
|
#endif // !ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
#if ENABLE_GCODE_VIEWER_STATISTICS
|
#if ENABLE_GCODE_VIEWER_STATISTICS
|
||||||
render_statistics();
|
render_statistics();
|
||||||
#endif // ENABLE_GCODE_VIEWER_STATISTICS
|
#endif // ENABLE_GCODE_VIEWER_STATISTICS
|
||||||
|
@ -381,6 +383,16 @@ void GCodeViewer::set_options_visibility_from_flags(unsigned int flags)
|
||||||
enable_legend(is_flag_set(9));
|
enable_legend(is_flag_set(9));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
void GCodeViewer::set_layers_z_range(const std::array<double, 2>& layers_z_range)
|
||||||
|
{
|
||||||
|
bool keep_sequential_current = layers_z_range[1] <= m_layers_z_range[1];
|
||||||
|
m_layers_z_range = layers_z_range;
|
||||||
|
refresh_render_paths(keep_sequential_current);
|
||||||
|
wxGetApp().plater()->update_preview_horz_slider();
|
||||||
|
}
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
|
||||||
bool GCodeViewer::init_shaders()
|
bool GCodeViewer::init_shaders()
|
||||||
{
|
{
|
||||||
unsigned char begin_id = buffer_id(GCodeProcessor::EMoveType::Retract);
|
unsigned char begin_id = buffer_id(GCodeProcessor::EMoveType::Retract);
|
||||||
|
@ -1147,6 +1159,7 @@ void GCodeViewer::render_legend() const
|
||||||
ImGui::PopStyleVar();
|
ImGui::PopStyleVar();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if !ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
void GCodeViewer::render_sequential_bar() const
|
void GCodeViewer::render_sequential_bar() const
|
||||||
{
|
{
|
||||||
static const float MARGIN = 125.0f;
|
static const float MARGIN = 125.0f;
|
||||||
|
@ -1231,6 +1244,7 @@ void GCodeViewer::render_sequential_bar() const
|
||||||
imgui.end();
|
imgui.end();
|
||||||
ImGui::PopStyleVar();
|
ImGui::PopStyleVar();
|
||||||
}
|
}
|
||||||
|
#endif // !ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
|
||||||
#if ENABLE_GCODE_VIEWER_STATISTICS
|
#if ENABLE_GCODE_VIEWER_STATISTICS
|
||||||
void GCodeViewer::render_statistics() const
|
void GCodeViewer::render_statistics() const
|
||||||
|
|
|
@ -149,6 +149,7 @@ class GCodeViewer
|
||||||
void reset_ranges() { ranges.reset(); }
|
void reset_ranges() { ranges.reset(); }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#if !ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
struct SequentialView
|
struct SequentialView
|
||||||
{
|
{
|
||||||
class Marker
|
class Marker
|
||||||
|
@ -182,6 +183,7 @@ class GCodeViewer
|
||||||
Vec3f current_position{ Vec3f::Zero() };
|
Vec3f current_position{ Vec3f::Zero() };
|
||||||
Marker marker;
|
Marker marker;
|
||||||
};
|
};
|
||||||
|
#endif // !ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
|
||||||
#if ENABLE_GCODE_VIEWER_STATISTICS
|
#if ENABLE_GCODE_VIEWER_STATISTICS
|
||||||
struct Statistics
|
struct Statistics
|
||||||
|
@ -229,6 +231,42 @@ class GCodeViewer
|
||||||
#endif // ENABLE_GCODE_VIEWER_STATISTICS
|
#endif // ENABLE_GCODE_VIEWER_STATISTICS
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
struct SequentialView
|
||||||
|
{
|
||||||
|
class Marker
|
||||||
|
{
|
||||||
|
GL_Model m_model;
|
||||||
|
Transform3f m_world_transform;
|
||||||
|
std::array<float, 4> m_color{ 1.0f, 1.0f, 1.0f, 1.0f };
|
||||||
|
bool m_visible{ false };
|
||||||
|
Shader m_shader;
|
||||||
|
|
||||||
|
public:
|
||||||
|
void init();
|
||||||
|
|
||||||
|
const BoundingBoxf3& get_bounding_box() const { return m_model.get_bounding_box(); }
|
||||||
|
|
||||||
|
void set_world_transform(const Transform3f& transform) { m_world_transform = transform; }
|
||||||
|
void set_color(const std::array<float, 4>& color) { m_color = color; }
|
||||||
|
|
||||||
|
bool is_visible() const { return m_visible; }
|
||||||
|
void set_visible(bool visible) { m_visible = visible; }
|
||||||
|
|
||||||
|
void render() const;
|
||||||
|
|
||||||
|
private:
|
||||||
|
void init_shader();
|
||||||
|
};
|
||||||
|
|
||||||
|
unsigned int first{ 0 };
|
||||||
|
unsigned int last{ 0 };
|
||||||
|
unsigned int current{ 0 };
|
||||||
|
Vec3f current_position{ Vec3f::Zero() };
|
||||||
|
Marker marker;
|
||||||
|
};
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
|
||||||
enum class EViewType : unsigned char
|
enum class EViewType : unsigned char
|
||||||
{
|
{
|
||||||
FeatureType,
|
FeatureType,
|
||||||
|
@ -284,6 +322,11 @@ public:
|
||||||
const BoundingBoxf3& get_bounding_box() const { return m_bounding_box; }
|
const BoundingBoxf3& get_bounding_box() const { return m_bounding_box; }
|
||||||
const std::vector<double>& get_layers_zs() const { return m_layers_zs; };
|
const std::vector<double>& get_layers_zs() const { return m_layers_zs; };
|
||||||
|
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
const SequentialView& get_sequential_view() const { return m_sequential_view; }
|
||||||
|
void update_sequential_view_current(unsigned int low, unsigned int high) { m_sequential_view.current = high; refresh_render_paths(true); }
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
|
||||||
EViewType get_view_type() const { return m_view_type; }
|
EViewType get_view_type() const { return m_view_type; }
|
||||||
void set_view_type(EViewType type) {
|
void set_view_type(EViewType type) {
|
||||||
if (type == EViewType::Count)
|
if (type == EViewType::Count)
|
||||||
|
@ -298,12 +341,16 @@ public:
|
||||||
void set_toolpath_role_visibility_flags(unsigned int flags) { m_extrusions.role_visibility_flags = flags; }
|
void set_toolpath_role_visibility_flags(unsigned int flags) { m_extrusions.role_visibility_flags = flags; }
|
||||||
unsigned int get_options_visibility_flags() const;
|
unsigned int get_options_visibility_flags() const;
|
||||||
void set_options_visibility_from_flags(unsigned int flags);
|
void set_options_visibility_from_flags(unsigned int flags);
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
void set_layers_z_range(const std::array<double, 2>& layers_z_range);
|
||||||
|
#else
|
||||||
void set_layers_z_range(const std::array<double, 2>& layers_z_range)
|
void set_layers_z_range(const std::array<double, 2>& layers_z_range)
|
||||||
{
|
{
|
||||||
bool keep_sequential_current = layers_z_range[1] <= m_layers_z_range[1];
|
bool keep_sequential_current = layers_z_range[1] <= m_layers_z_range[1];
|
||||||
m_layers_z_range = layers_z_range;
|
m_layers_z_range = layers_z_range;
|
||||||
refresh_render_paths(keep_sequential_current);
|
refresh_render_paths(keep_sequential_current);
|
||||||
}
|
}
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
|
||||||
bool is_legend_enabled() const { return m_legend_enabled; }
|
bool is_legend_enabled() const { return m_legend_enabled; }
|
||||||
void enable_legend(bool enable) { m_legend_enabled = enable; }
|
void enable_legend(bool enable) { m_legend_enabled = enable; }
|
||||||
|
@ -316,7 +363,9 @@ private:
|
||||||
void render_toolpaths() const;
|
void render_toolpaths() const;
|
||||||
void render_shells() const;
|
void render_shells() const;
|
||||||
void render_legend() const;
|
void render_legend() const;
|
||||||
|
#if !ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
void render_sequential_bar() const;
|
void render_sequential_bar() const;
|
||||||
|
#endif // !ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
#if ENABLE_GCODE_VIEWER_STATISTICS
|
#if ENABLE_GCODE_VIEWER_STATISTICS
|
||||||
void render_statistics() const;
|
void render_statistics() const;
|
||||||
#endif // ENABLE_GCODE_VIEWER_STATISTICS
|
#endif // ENABLE_GCODE_VIEWER_STATISTICS
|
||||||
|
|
|
@ -42,7 +42,9 @@ namespace Slic3r {
|
||||||
class Bed3D;
|
class Bed3D;
|
||||||
struct Camera;
|
struct Camera;
|
||||||
class BackgroundSlicingProcess;
|
class BackgroundSlicingProcess;
|
||||||
|
#if !ENABLE_GCODE_VIEWER
|
||||||
class GCodePreviewData;
|
class GCodePreviewData;
|
||||||
|
#endif // !ENABLE_GCODE_VIEWER
|
||||||
struct ThumbnailData;
|
struct ThumbnailData;
|
||||||
struct SlicingParameters;
|
struct SlicingParameters;
|
||||||
enum LayerHeightEditActionType : unsigned int;
|
enum LayerHeightEditActionType : unsigned int;
|
||||||
|
@ -551,6 +553,10 @@ public:
|
||||||
|
|
||||||
#if ENABLE_GCODE_VIEWER
|
#if ENABLE_GCODE_VIEWER
|
||||||
void reset_gcode_toolpaths() { m_gcode_viewer.reset(); }
|
void reset_gcode_toolpaths() { m_gcode_viewer.reset(); }
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
const GCodeViewer::SequentialView& get_gcode_sequential_view() const { return m_gcode_viewer.get_sequential_view(); }
|
||||||
|
void update_gcode_sequential_view_current(unsigned int low, unsigned int high) { m_gcode_viewer.update_sequential_view_current(low, high); }
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
#endif // ENABLE_GCODE_VIEWER
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
void toggle_sla_auxiliaries_visibility(bool visible, const ModelObject* mo = nullptr, int instance_idx = -1);
|
void toggle_sla_auxiliaries_visibility(bool visible, const ModelObject* mo = nullptr, int instance_idx = -1);
|
||||||
|
|
|
@ -210,7 +210,9 @@ Preview::Preview(
|
||||||
, m_number_extruders(1)
|
, m_number_extruders(1)
|
||||||
, m_preferred_color_mode("feature")
|
, m_preferred_color_mode("feature")
|
||||||
, m_loaded(false)
|
, m_loaded(false)
|
||||||
|
#if !ENABLE_GCODE_VIEWER
|
||||||
, m_enabled(false)
|
, m_enabled(false)
|
||||||
|
#endif // !ENABLE_GCODE_VIEWER
|
||||||
, m_schedule_background_process(schedule_background_process_func)
|
, m_schedule_background_process(schedule_background_process_func)
|
||||||
#ifdef __linux__
|
#ifdef __linux__
|
||||||
, m_volumes_cleanup_required(false)
|
, m_volumes_cleanup_required(false)
|
||||||
|
@ -245,8 +247,12 @@ bool Preview::init(wxWindow* parent, Model* model)
|
||||||
m_canvas->enable_dynamic_background(true);
|
m_canvas->enable_dynamic_background(true);
|
||||||
m_canvas->enable_collapse_toolbar(true);
|
m_canvas->enable_collapse_toolbar(true);
|
||||||
|
|
||||||
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
m_double_slider_sizer = create_vert_slider_sizer();
|
||||||
|
#else
|
||||||
m_double_slider_sizer = new wxBoxSizer(wxHORIZONTAL);
|
m_double_slider_sizer = new wxBoxSizer(wxHORIZONTAL);
|
||||||
create_double_slider();
|
create_double_slider();
|
||||||
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
m_label_view_type = new wxStaticText(this, wxID_ANY, _L("View"));
|
m_label_view_type = new wxStaticText(this, wxID_ANY, _L("View"));
|
||||||
|
|
||||||
|
@ -315,15 +321,25 @@ bool Preview::init(wxWindow* parent, Model* model)
|
||||||
top_sizer->Add(m_canvas_widget, 1, wxALL | wxEXPAND, 0);
|
top_sizer->Add(m_canvas_widget, 1, wxALL | wxEXPAND, 0);
|
||||||
top_sizer->Add(m_double_slider_sizer, 0, wxEXPAND, 0);
|
top_sizer->Add(m_double_slider_sizer, 0, wxEXPAND, 0);
|
||||||
|
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
m_horz_slider = new DoubleSlider::Control(this, wxID_ANY, 0, 0, 0, 100, wxDefaultPosition, wxDefaultSize, wxSL_HORIZONTAL);
|
||||||
|
m_horz_slider->SetDrawMode(DoubleSlider::dmSequentialGCodeView);
|
||||||
|
m_horz_slider->Bind(wxEVT_SCROLL_CHANGED, &Preview::on_horz_slider_scroll_changed, this);
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
|
||||||
#if ENABLE_GCODE_VIEWER
|
#if ENABLE_GCODE_VIEWER
|
||||||
m_bottom_toolbar_sizer = new wxBoxSizer(wxHORIZONTAL);
|
m_bottom_toolbar_sizer = new wxBoxSizer(wxHORIZONTAL);
|
||||||
m_bottom_toolbar_sizer->AddSpacer(10);
|
m_bottom_toolbar_sizer->AddSpacer(10);
|
||||||
m_bottom_toolbar_sizer->Add(m_label_view_type, 0, wxALIGN_CENTER_VERTICAL, 5);
|
m_bottom_toolbar_sizer->Add(m_label_view_type, 0, wxALIGN_CENTER_VERTICAL | wxRIGHT, 5);
|
||||||
m_bottom_toolbar_sizer->Add(m_choice_view_type, 0, wxEXPAND | wxALL, 5);
|
m_bottom_toolbar_sizer->Add(m_choice_view_type, 0, wxALIGN_CENTER_VERTICAL, 5);
|
||||||
m_bottom_toolbar_sizer->AddSpacer(10);
|
m_bottom_toolbar_sizer->AddSpacer(10);
|
||||||
m_bottom_toolbar_sizer->Add(m_label_show, 0, wxALIGN_CENTER_VERTICAL, 5);
|
m_bottom_toolbar_sizer->Add(m_label_show, 0, wxALIGN_CENTER_VERTICAL | wxLEFT | wxRIGHT, 5);
|
||||||
m_bottom_toolbar_sizer->Add(m_combochecklist_options, 0, wxEXPAND | wxALL, 5);
|
m_bottom_toolbar_sizer->Add(m_combochecklist_options, 0, wxALIGN_CENTER_VERTICAL, 5);
|
||||||
m_bottom_toolbar_sizer->Add(m_combochecklist_features, 0, wxEXPAND | wxALL, 5);
|
m_bottom_toolbar_sizer->Add(m_combochecklist_features, 0, wxALIGN_CENTER_VERTICAL | wxLEFT, 5);
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
m_bottom_toolbar_sizer->AddSpacer(10);
|
||||||
|
m_bottom_toolbar_sizer->Add(m_horz_slider, 1, wxALL | wxEXPAND, 5);
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
#else
|
#else
|
||||||
wxBoxSizer* bottom_sizer = new wxBoxSizer(wxHORIZONTAL);
|
wxBoxSizer* bottom_sizer = new wxBoxSizer(wxHORIZONTAL);
|
||||||
bottom_sizer->Add(m_label_view_type, 0, wxALIGN_CENTER_VERTICAL, 5);
|
bottom_sizer->Add(m_label_view_type, 0, wxALIGN_CENTER_VERTICAL, 5);
|
||||||
|
@ -417,10 +433,12 @@ void Preview::set_number_extruders(unsigned int number_extruders)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if !ENABLE_GCODE_VIEWER
|
||||||
void Preview::set_enabled(bool enabled)
|
void Preview::set_enabled(bool enabled)
|
||||||
{
|
{
|
||||||
m_enabled = enabled;
|
m_enabled = enabled;
|
||||||
}
|
}
|
||||||
|
#endif // !ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
void Preview::bed_shape_changed()
|
void Preview::bed_shape_changed()
|
||||||
{
|
{
|
||||||
|
@ -498,7 +516,14 @@ void Preview::refresh_print()
|
||||||
void Preview::msw_rescale()
|
void Preview::msw_rescale()
|
||||||
{
|
{
|
||||||
// rescale slider
|
// rescale slider
|
||||||
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
if (m_vert_slider != nullptr) m_vert_slider->msw_rescale();
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
if (m_horz_slider != nullptr) m_horz_slider->msw_rescale();
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
#else
|
||||||
if (m_slider) m_slider->msw_rescale();
|
if (m_slider) m_slider->msw_rescale();
|
||||||
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
// rescale warning legend on the canvas
|
// rescale warning legend on the canvas
|
||||||
get_canvas3d()->msw_rescale();
|
get_canvas3d()->msw_rescale();
|
||||||
|
@ -509,14 +534,22 @@ void Preview::msw_rescale()
|
||||||
|
|
||||||
void Preview::move_double_slider(wxKeyEvent& evt)
|
void Preview::move_double_slider(wxKeyEvent& evt)
|
||||||
{
|
{
|
||||||
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
if (m_vert_slider != nullptr) m_vert_slider->OnKeyDown(evt);
|
||||||
|
#else
|
||||||
if (m_slider)
|
if (m_slider)
|
||||||
m_slider->OnKeyDown(evt);
|
m_slider->OnKeyDown(evt);
|
||||||
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
}
|
}
|
||||||
|
|
||||||
void Preview::edit_double_slider(wxKeyEvent& evt)
|
void Preview::edit_double_slider(wxKeyEvent& evt)
|
||||||
{
|
{
|
||||||
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
if (m_vert_slider != nullptr) m_vert_slider->OnChar(evt);
|
||||||
|
#else
|
||||||
if (m_slider)
|
if (m_slider)
|
||||||
m_slider->OnChar(evt);
|
m_slider->OnChar(evt);
|
||||||
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
}
|
}
|
||||||
|
|
||||||
void Preview::bind_event_handlers()
|
void Preview::bind_event_handlers()
|
||||||
|
@ -580,25 +613,35 @@ void Preview::show_hide_ui_elements(const std::string& what)
|
||||||
}
|
}
|
||||||
#endif // !ENABLE_GCODE_VIEWER
|
#endif // !ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
void Preview::hide_vert_slider()
|
||||||
|
{
|
||||||
|
m_double_slider_sizer->Hide((size_t)0);
|
||||||
|
Layout();
|
||||||
|
}
|
||||||
|
#else
|
||||||
void Preview::reset_sliders(bool reset_all)
|
void Preview::reset_sliders(bool reset_all)
|
||||||
{
|
{
|
||||||
m_enabled = false;
|
m_enabled = false;
|
||||||
// reset_double_slider();
|
// reset_double_slider();
|
||||||
if (reset_all)
|
if (reset_all)
|
||||||
m_double_slider_sizer->Hide((size_t)0);
|
m_double_slider_sizer->Hide((size_t)0);
|
||||||
else
|
else
|
||||||
m_double_slider_sizer->GetItem(size_t(0))->GetSizer()->Hide(1);
|
m_double_slider_sizer->GetItem(size_t(0))->GetSizer()->Hide(1);
|
||||||
}
|
}
|
||||||
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
|
#if !ENABLE_GCODE_VIEWER
|
||||||
void Preview::update_sliders(const std::vector<double>& layers_z, bool keep_z_range)
|
void Preview::update_sliders(const std::vector<double>& layers_z, bool keep_z_range)
|
||||||
{
|
{
|
||||||
m_enabled = true;
|
m_enabled = true;
|
||||||
|
|
||||||
update_double_slider(layers_z, keep_z_range);
|
update_double_slider(layers_z, keep_z_range);
|
||||||
|
|
||||||
m_double_slider_sizer->Show((size_t)0);
|
m_double_slider_sizer->Show((size_t)0);
|
||||||
|
|
||||||
Layout();
|
Layout();
|
||||||
}
|
}
|
||||||
|
#endif // !ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
void Preview::on_size(wxSizeEvent& evt)
|
void Preview::on_size(wxSizeEvent& evt)
|
||||||
{
|
{
|
||||||
|
@ -708,18 +751,55 @@ void Preview::update_bottom_toolbar()
|
||||||
m_bottom_toolbar_sizer->Show(m_combochecklist_features,
|
m_bottom_toolbar_sizer->Show(m_combochecklist_features,
|
||||||
!m_canvas->is_gcode_legend_enabled() || m_canvas->get_gcode_view_type() != GCodeViewer::EViewType::FeatureType);
|
!m_canvas->is_gcode_legend_enabled() || m_canvas->get_gcode_view_type() != GCodeViewer::EViewType::FeatureType);
|
||||||
m_bottom_toolbar_sizer->Layout();
|
m_bottom_toolbar_sizer->Layout();
|
||||||
|
Refresh();
|
||||||
}
|
}
|
||||||
#endif // ENABLE_GCODE_VIEWER
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
wxBoxSizer* Preview::create_vert_slider_sizer()
|
||||||
|
{
|
||||||
|
wxBoxSizer* sizer = new wxBoxSizer(wxHORIZONTAL);
|
||||||
|
m_vert_slider = new DoubleSlider::Control(this, wxID_ANY, 0, 0, 0, 100);
|
||||||
|
|
||||||
|
m_vert_slider->SetDrawMode(wxGetApp().preset_bundle->printers.get_edited_preset().printer_technology() == ptSLA,
|
||||||
|
wxGetApp().preset_bundle->prints.get_edited_preset().config.opt_bool("complete_objects"));
|
||||||
|
|
||||||
|
sizer->Add(m_vert_slider, 0, wxEXPAND, 0);
|
||||||
|
|
||||||
|
// sizer, m_canvas_widget
|
||||||
|
m_canvas_widget->Bind(wxEVT_KEY_DOWN, &Preview::update_vert_slider_from_canvas, this);
|
||||||
|
m_canvas_widget->Bind(wxEVT_KEY_UP, [this](wxKeyEvent& event) {
|
||||||
|
if (event.GetKeyCode() == WXK_SHIFT)
|
||||||
|
m_vert_slider->UseDefaultColors(true);
|
||||||
|
event.Skip();
|
||||||
|
});
|
||||||
|
|
||||||
|
m_vert_slider->Bind(wxEVT_SCROLL_CHANGED, &Preview::on_vert_slider_scroll_changed, this);
|
||||||
|
|
||||||
|
Bind(DoubleSlider::wxCUSTOMEVT_TICKSCHANGED, [this](wxEvent&) {
|
||||||
|
Model& model = wxGetApp().plater()->model();
|
||||||
|
model.custom_gcode_per_print_z = m_vert_slider->GetTicksValues();
|
||||||
|
m_schedule_background_process();
|
||||||
|
|
||||||
|
update_view_type(false);
|
||||||
|
|
||||||
|
reload_print();
|
||||||
|
});
|
||||||
|
|
||||||
|
return sizer;
|
||||||
|
}
|
||||||
|
#else
|
||||||
void Preview::create_double_slider()
|
void Preview::create_double_slider()
|
||||||
{
|
{
|
||||||
m_slider = new DoubleSlider::Control(this, wxID_ANY, 0, 0, 0, 100);
|
m_slider = new DoubleSlider::Control(this, wxID_ANY, 0, 0, 0, 100);
|
||||||
|
|
||||||
bool sla_print_technology = wxGetApp().preset_bundle->printers.get_edited_preset().printer_technology() == ptSLA;
|
bool sla_print_technology = wxGetApp().preset_bundle->printers.get_edited_preset().printer_technology() == ptSLA;
|
||||||
bool sequential_print = wxGetApp().preset_bundle->prints.get_edited_preset().config.opt_bool("complete_objects");
|
bool sequential_print = wxGetApp().preset_bundle->prints.get_edited_preset().config.opt_bool("complete_objects");
|
||||||
m_slider->SetDrawMode(sla_print_technology, sequential_print);
|
m_slider->SetDrawMode(sla_print_technology, sequential_print);
|
||||||
|
|
||||||
m_double_slider_sizer->Add(m_slider, 0, wxEXPAND, 0);
|
m_double_slider_sizer->Add(m_slider, 0, wxEXPAND, 0);
|
||||||
|
|
||||||
|
|
||||||
// sizer, m_canvas_widget
|
// sizer, m_canvas_widget
|
||||||
m_canvas_widget->Bind(wxEVT_KEY_DOWN, &Preview::update_double_slider_from_canvas, this);
|
m_canvas_widget->Bind(wxEVT_KEY_DOWN, &Preview::update_double_slider_from_canvas, this);
|
||||||
m_canvas_widget->Bind(wxEVT_KEY_UP, [this](wxKeyEvent& event) {
|
m_canvas_widget->Bind(wxEVT_KEY_UP, [this](wxKeyEvent& event) {
|
||||||
|
@ -730,7 +810,6 @@ void Preview::create_double_slider()
|
||||||
|
|
||||||
m_slider->Bind(wxEVT_SCROLL_CHANGED, &Preview::on_sliders_scroll_changed, this);
|
m_slider->Bind(wxEVT_SCROLL_CHANGED, &Preview::on_sliders_scroll_changed, this);
|
||||||
|
|
||||||
|
|
||||||
Bind(DoubleSlider::wxCUSTOMEVT_TICKSCHANGED, [this](wxEvent&) {
|
Bind(DoubleSlider::wxCUSTOMEVT_TICKSCHANGED, [this](wxEvent&) {
|
||||||
Model& model = wxGetApp().plater()->model();
|
Model& model = wxGetApp().plater()->model();
|
||||||
model.custom_gcode_per_print_z = m_slider->GetTicksValues();
|
model.custom_gcode_per_print_z = m_slider->GetTicksValues();
|
||||||
|
@ -741,6 +820,7 @@ void Preview::create_double_slider()
|
||||||
reload_print();
|
reload_print();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
// Find an index of a value in a sorted vector, which is in <z-eps, z+eps>.
|
// Find an index of a value in a sorted vector, which is in <z-eps, z+eps>.
|
||||||
// Returns -1 if there is no such member.
|
// Returns -1 if there is no such member.
|
||||||
|
@ -769,8 +849,13 @@ static int find_close_layer_idx(const std::vector<double>& zs, double &z, double
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
void Preview::check_vert_slider_values(std::vector<CustomGCode::Item>& ticks_from_model,
|
||||||
|
const std::vector<double>& layers_z)
|
||||||
|
#else
|
||||||
void Preview::check_slider_values(std::vector<CustomGCode::Item>& ticks_from_model,
|
void Preview::check_slider_values(std::vector<CustomGCode::Item>& ticks_from_model,
|
||||||
const std::vector<double>& layers_z)
|
const std::vector<double>& layers_z)
|
||||||
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
{
|
{
|
||||||
// All ticks that would end up outside the slider range should be erased.
|
// All ticks that would end up outside the slider range should be erased.
|
||||||
// TODO: this should be placed into more appropriate part of code,
|
// TODO: this should be placed into more appropriate part of code,
|
||||||
|
@ -787,12 +872,68 @@ void Preview::check_slider_values(std::vector<CustomGCode::Item>& ticks_from_mod
|
||||||
m_schedule_background_process();
|
m_schedule_background_process();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Preview::update_double_slider(const std::vector<double>& layers_z, bool keep_z_range)
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
void Preview::update_vert_slider(const std::vector<double>& layers_z, bool keep_z_range)
|
||||||
|
{
|
||||||
|
// Save the initial slider span.
|
||||||
|
double z_low = m_vert_slider->GetLowerValueD();
|
||||||
|
double z_high = m_vert_slider->GetHigherValueD();
|
||||||
|
bool was_empty = m_vert_slider->GetMaxValue() == 0;
|
||||||
|
|
||||||
|
bool force_sliders_full_range = was_empty;
|
||||||
|
if (!keep_z_range)
|
||||||
|
{
|
||||||
|
bool span_changed = layers_z.empty() || std::abs(layers_z.back() - m_vert_slider->GetMaxValueD()) > DoubleSlider::epsilon()/*1e-6*/;
|
||||||
|
force_sliders_full_range |= span_changed;
|
||||||
|
}
|
||||||
|
bool snap_to_min = force_sliders_full_range || m_vert_slider->is_lower_at_min();
|
||||||
|
bool snap_to_max = force_sliders_full_range || m_vert_slider->is_higher_at_max();
|
||||||
|
|
||||||
|
// Detect and set manipulation mode for double slider
|
||||||
|
update_vert_slider_mode();
|
||||||
|
|
||||||
|
CustomGCode::Info& ticks_info_from_model = wxGetApp().plater()->model().custom_gcode_per_print_z;
|
||||||
|
check_vert_slider_values(ticks_info_from_model.gcodes, layers_z);
|
||||||
|
|
||||||
|
m_vert_slider->SetSliderValues(layers_z);
|
||||||
|
assert(m_vert_slider->GetMinValue() == 0);
|
||||||
|
m_vert_slider->SetMaxValue(layers_z.empty() ? 0 : layers_z.size() - 1);
|
||||||
|
|
||||||
|
int idx_low = 0;
|
||||||
|
int idx_high = m_vert_slider->GetMaxValue();
|
||||||
|
if (!layers_z.empty()) {
|
||||||
|
if (!snap_to_min) {
|
||||||
|
int idx_new = find_close_layer_idx(layers_z, z_low, DoubleSlider::epsilon()/*1e-6*/);
|
||||||
|
if (idx_new != -1)
|
||||||
|
idx_low = idx_new;
|
||||||
|
}
|
||||||
|
if (!snap_to_max) {
|
||||||
|
int idx_new = find_close_layer_idx(layers_z, z_high, DoubleSlider::epsilon()/*1e-6*/);
|
||||||
|
if (idx_new != -1)
|
||||||
|
idx_high = idx_new;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
m_vert_slider->SetSelectionSpan(idx_low, idx_high);
|
||||||
|
|
||||||
|
m_vert_slider->SetTicksValues(ticks_info_from_model);
|
||||||
|
|
||||||
|
bool sla_print_technology = wxGetApp().plater()->printer_technology() == ptSLA;
|
||||||
|
bool sequential_print = wxGetApp().preset_bundle->prints.get_edited_preset().config.opt_bool("complete_objects");
|
||||||
|
m_vert_slider->SetDrawMode(sla_print_technology, sequential_print);
|
||||||
|
|
||||||
|
m_vert_slider->SetExtruderColors(wxGetApp().plater()->get_extruder_colors_from_plater_config());
|
||||||
|
|
||||||
|
m_double_slider_sizer->Show((size_t)0);
|
||||||
|
Layout();
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
void Preview::update_double_slider(const std::vector<double> & layers_z, bool keep_z_range)
|
||||||
{
|
{
|
||||||
// Save the initial slider span.
|
// Save the initial slider span.
|
||||||
double z_low = m_slider->GetLowerValueD();
|
double z_low = m_slider->GetLowerValueD();
|
||||||
double z_high = m_slider->GetHigherValueD();
|
double z_high = m_slider->GetHigherValueD();
|
||||||
bool was_empty = m_slider->GetMaxValue() == 0;
|
bool was_empty = m_slider->GetMaxValue() == 0;
|
||||||
|
|
||||||
bool force_sliders_full_range = was_empty;
|
bool force_sliders_full_range = was_empty;
|
||||||
if (!keep_z_range)
|
if (!keep_z_range)
|
||||||
{
|
{
|
||||||
|
@ -805,7 +946,7 @@ void Preview::update_double_slider(const std::vector<double>& layers_z, bool kee
|
||||||
// Detect and set manipulation mode for double slider
|
// Detect and set manipulation mode for double slider
|
||||||
update_double_slider_mode();
|
update_double_slider_mode();
|
||||||
|
|
||||||
CustomGCode::Info &ticks_info_from_model = wxGetApp().plater()->model().custom_gcode_per_print_z;
|
CustomGCode::Info& ticks_info_from_model = wxGetApp().plater()->model().custom_gcode_per_print_z;
|
||||||
check_slider_values(ticks_info_from_model.gcodes, layers_z);
|
check_slider_values(ticks_info_from_model.gcodes, layers_z);
|
||||||
|
|
||||||
m_slider->SetSliderValues(layers_z);
|
m_slider->SetSliderValues(layers_z);
|
||||||
|
@ -814,13 +955,13 @@ void Preview::update_double_slider(const std::vector<double>& layers_z, bool kee
|
||||||
|
|
||||||
int idx_low = 0;
|
int idx_low = 0;
|
||||||
int idx_high = m_slider->GetMaxValue();
|
int idx_high = m_slider->GetMaxValue();
|
||||||
if (! layers_z.empty()) {
|
if (!layers_z.empty()) {
|
||||||
if (! snap_to_min) {
|
if (!snap_to_min) {
|
||||||
int idx_new = find_close_layer_idx(layers_z, z_low, DoubleSlider::epsilon()/*1e-6*/);
|
int idx_new = find_close_layer_idx(layers_z, z_low, DoubleSlider::epsilon()/*1e-6*/);
|
||||||
if (idx_new != -1)
|
if (idx_new != -1)
|
||||||
idx_low = idx_new;
|
idx_low = idx_new;
|
||||||
}
|
}
|
||||||
if (! snap_to_max) {
|
if (!snap_to_max) {
|
||||||
int idx_new = find_close_layer_idx(layers_z, z_high, DoubleSlider::epsilon()/*1e-6*/);
|
int idx_new = find_close_layer_idx(layers_z, z_high, DoubleSlider::epsilon()/*1e-6*/);
|
||||||
if (idx_new != -1)
|
if (idx_new != -1)
|
||||||
idx_high = idx_new;
|
idx_high = idx_new;
|
||||||
|
@ -836,8 +977,13 @@ void Preview::update_double_slider(const std::vector<double>& layers_z, bool kee
|
||||||
|
|
||||||
m_slider->SetExtruderColors(wxGetApp().plater()->get_extruder_colors_from_plater_config());
|
m_slider->SetExtruderColors(wxGetApp().plater()->get_extruder_colors_from_plater_config());
|
||||||
}
|
}
|
||||||
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
void Preview::update_vert_slider_mode()
|
||||||
|
#else
|
||||||
void Preview::update_double_slider_mode()
|
void Preview::update_double_slider_mode()
|
||||||
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
{
|
{
|
||||||
// true -> single-extruder printer profile OR
|
// true -> single-extruder printer profile OR
|
||||||
// multi-extruder printer profile , but whole model is printed by only one extruder
|
// multi-extruder printer profile , but whole model is printed by only one extruder
|
||||||
|
@ -886,16 +1032,68 @@ void Preview::update_double_slider_mode()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
m_vert_slider->SetModeAndOnlyExtruder(one_extruder_printed_model, only_extruder);
|
||||||
|
#else
|
||||||
m_slider->SetModeAndOnlyExtruder(one_extruder_printed_model, only_extruder);
|
m_slider->SetModeAndOnlyExtruder(one_extruder_printed_model, only_extruder);
|
||||||
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
void Preview::reset_vert_slider()
|
||||||
|
{
|
||||||
|
m_vert_slider->SetHigherValue(0);
|
||||||
|
m_vert_slider->SetLowerValue(0);
|
||||||
|
}
|
||||||
|
#else
|
||||||
void Preview::reset_double_slider()
|
void Preview::reset_double_slider()
|
||||||
{
|
{
|
||||||
m_slider->SetHigherValue(0);
|
m_slider->SetHigherValue(0);
|
||||||
m_slider->SetLowerValue(0);
|
m_slider->SetLowerValue(0);
|
||||||
}
|
}
|
||||||
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
void Preview::update_double_slider_from_canvas(wxKeyEvent& event)
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
void Preview::update_vert_slider_from_canvas(wxKeyEvent& event)
|
||||||
|
{
|
||||||
|
if (event.HasModifiers()) {
|
||||||
|
event.Skip();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const auto key = event.GetKeyCode();
|
||||||
|
|
||||||
|
if (key == 'U' || key == 'D') {
|
||||||
|
const int new_pos = key == 'U' ? m_vert_slider->GetHigherValue() + 1 : m_vert_slider->GetHigherValue() - 1;
|
||||||
|
m_vert_slider->SetHigherValue(new_pos);
|
||||||
|
if (event.ShiftDown() || m_vert_slider->is_one_layer()) m_vert_slider->SetLowerValue(m_vert_slider->GetHigherValue());
|
||||||
|
}
|
||||||
|
else if (key == 'S')
|
||||||
|
m_vert_slider->ChangeOneLayerLock();
|
||||||
|
else if (key == WXK_SHIFT)
|
||||||
|
m_vert_slider->UseDefaultColors(false);
|
||||||
|
else
|
||||||
|
event.Skip();
|
||||||
|
}
|
||||||
|
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
void Preview::update_horz_slider()
|
||||||
|
{
|
||||||
|
const GCodeViewer::SequentialView& view = m_canvas->get_gcode_sequential_view();
|
||||||
|
std::vector<double> values(view.last - view.first + 1);
|
||||||
|
unsigned int count = 0;
|
||||||
|
for (unsigned int i = view.first; i <= view.last; ++i)
|
||||||
|
{
|
||||||
|
values[count++] = static_cast<double>(i + 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
m_horz_slider->SetSliderValues(values);
|
||||||
|
m_horz_slider->SetMaxValue(view.last - view.first);
|
||||||
|
m_horz_slider->SetSelectionSpan(0, view.current);
|
||||||
|
}
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
#else
|
||||||
|
void Preview::update_double_slider_from_canvas(wxKeyEvent & event)
|
||||||
{
|
{
|
||||||
if (event.HasModifiers()) {
|
if (event.HasModifiers()) {
|
||||||
event.Skip();
|
event.Skip();
|
||||||
|
@ -909,13 +1107,11 @@ void Preview::update_double_slider_from_canvas(wxKeyEvent& event)
|
||||||
m_slider->SetHigherValue(new_pos);
|
m_slider->SetHigherValue(new_pos);
|
||||||
if (event.ShiftDown() || m_slider->is_one_layer()) m_slider->SetLowerValue(m_slider->GetHigherValue());
|
if (event.ShiftDown() || m_slider->is_one_layer()) m_slider->SetLowerValue(m_slider->GetHigherValue());
|
||||||
}
|
}
|
||||||
#if !ENABLE_GCODE_VIEWER
|
|
||||||
else if (key == 'L') {
|
else if (key == 'L') {
|
||||||
m_checkbox_legend->SetValue(!m_checkbox_legend->GetValue());
|
m_checkbox_legend->SetValue(!m_checkbox_legend->GetValue());
|
||||||
auto evt = wxCommandEvent();
|
auto evt = wxCommandEvent();
|
||||||
on_checkbox_legend(evt);
|
on_checkbox_legend(evt);
|
||||||
}
|
}
|
||||||
#endif // !ENABLE_GCODE_VIEWER
|
|
||||||
else if (key == 'S')
|
else if (key == 'S')
|
||||||
m_slider->ChangeOneLayerLock();
|
m_slider->ChangeOneLayerLock();
|
||||||
else if (key == WXK_SHIFT)
|
else if (key == WXK_SHIFT)
|
||||||
|
@ -923,6 +1119,7 @@ void Preview::update_double_slider_from_canvas(wxKeyEvent& event)
|
||||||
else
|
else
|
||||||
event.Skip();
|
event.Skip();
|
||||||
}
|
}
|
||||||
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
void Preview::load_print_as_fff(bool keep_z_range)
|
void Preview::load_print_as_fff(bool keep_z_range)
|
||||||
{
|
{
|
||||||
|
@ -951,10 +1148,12 @@ void Preview::load_print_as_fff(bool keep_z_range)
|
||||||
|
|
||||||
if (! has_layers)
|
if (! has_layers)
|
||||||
{
|
{
|
||||||
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
hide_vert_slider();
|
||||||
|
#else
|
||||||
reset_sliders(true);
|
reset_sliders(true);
|
||||||
#if !ENABLE_GCODE_VIEWER
|
|
||||||
m_canvas->reset_legend_texture();
|
m_canvas->reset_legend_texture();
|
||||||
#endif // !ENABLE_GCODE_VIEWER
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
m_canvas_widget->Refresh();
|
m_canvas_widget->Refresh();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -1046,10 +1245,18 @@ void Preview::load_print_as_fff(bool keep_z_range)
|
||||||
#endif // !ENABLE_GCODE_VIEWER
|
#endif // !ENABLE_GCODE_VIEWER
|
||||||
if (zs.empty()) {
|
if (zs.empty()) {
|
||||||
// all layers filtered out
|
// all layers filtered out
|
||||||
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
hide_vert_slider();
|
||||||
|
#else
|
||||||
reset_sliders(true);
|
reset_sliders(true);
|
||||||
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
m_canvas_widget->Refresh();
|
m_canvas_widget->Refresh();
|
||||||
} else
|
} else
|
||||||
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
update_vert_slider(zs, keep_z_range);
|
||||||
|
#else
|
||||||
update_sliders(zs, keep_z_range);
|
update_sliders(zs, keep_z_range);
|
||||||
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1077,7 +1284,11 @@ void Preview::load_print_as_sla()
|
||||||
n_layers = (unsigned int)zs.size();
|
n_layers = (unsigned int)zs.size();
|
||||||
if (n_layers == 0)
|
if (n_layers == 0)
|
||||||
{
|
{
|
||||||
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
hide_vert_slider();
|
||||||
|
#else
|
||||||
reset_sliders(true);
|
reset_sliders(true);
|
||||||
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
m_canvas_widget->Refresh();
|
m_canvas_widget->Refresh();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1092,13 +1303,21 @@ void Preview::load_print_as_sla()
|
||||||
#endif // ENABLE_GCODE_VIEWER
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
if (n_layers > 0)
|
if (n_layers > 0)
|
||||||
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
update_vert_slider(zs);
|
||||||
|
#else
|
||||||
update_sliders(zs);
|
update_sliders(zs);
|
||||||
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
m_loaded = true;
|
m_loaded = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
void Preview::on_vert_slider_scroll_changed(wxCommandEvent& event)
|
||||||
|
#else
|
||||||
void Preview::on_sliders_scroll_changed(wxCommandEvent& event)
|
void Preview::on_sliders_scroll_changed(wxCommandEvent& event)
|
||||||
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
{
|
{
|
||||||
if (IsShown())
|
if (IsShown())
|
||||||
{
|
{
|
||||||
|
@ -1106,7 +1325,7 @@ void Preview::on_sliders_scroll_changed(wxCommandEvent& event)
|
||||||
if (tech == ptFFF)
|
if (tech == ptFFF)
|
||||||
{
|
{
|
||||||
#if ENABLE_GCODE_VIEWER
|
#if ENABLE_GCODE_VIEWER
|
||||||
m_canvas->set_toolpaths_z_range({ m_slider->GetLowerValueD(), m_slider->GetHigherValueD() });
|
m_canvas->set_toolpaths_z_range({ m_vert_slider->GetLowerValueD(), m_vert_slider->GetHigherValueD() });
|
||||||
m_canvas->set_as_dirty();
|
m_canvas->set_as_dirty();
|
||||||
#else
|
#else
|
||||||
m_canvas->set_toolpaths_range(m_slider->GetLowerValueD() - 1e-6, m_slider->GetHigherValueD() + 1e-6);
|
m_canvas->set_toolpaths_range(m_slider->GetLowerValueD() - 1e-6, m_slider->GetHigherValueD() + 1e-6);
|
||||||
|
@ -1116,13 +1335,27 @@ void Preview::on_sliders_scroll_changed(wxCommandEvent& event)
|
||||||
}
|
}
|
||||||
else if (tech == ptSLA)
|
else if (tech == ptSLA)
|
||||||
{
|
{
|
||||||
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
m_canvas->set_clipping_plane(0, ClippingPlane(Vec3d::UnitZ(), -m_vert_slider->GetLowerValueD()));
|
||||||
|
m_canvas->set_clipping_plane(1, ClippingPlane(-Vec3d::UnitZ(), m_vert_slider->GetHigherValueD()));
|
||||||
|
m_canvas->set_use_clipping_planes(m_vert_slider->GetHigherValue() != 0);
|
||||||
|
#else
|
||||||
m_canvas->set_clipping_plane(0, ClippingPlane(Vec3d::UnitZ(), -m_slider->GetLowerValueD()));
|
m_canvas->set_clipping_plane(0, ClippingPlane(Vec3d::UnitZ(), -m_slider->GetLowerValueD()));
|
||||||
m_canvas->set_clipping_plane(1, ClippingPlane(-Vec3d::UnitZ(), m_slider->GetHigherValueD()));
|
m_canvas->set_clipping_plane(1, ClippingPlane(-Vec3d::UnitZ(), m_slider->GetHigherValueD()));
|
||||||
m_canvas->set_use_clipping_planes(m_slider->GetHigherValue() != 0);
|
m_canvas->set_use_clipping_planes(m_slider->GetHigherValue() != 0);
|
||||||
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
m_canvas->render();
|
m_canvas->render();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
void Preview::on_horz_slider_scroll_changed(wxCommandEvent& event)
|
||||||
|
{
|
||||||
|
m_canvas->update_gcode_sequential_view_current(static_cast<unsigned int>(m_horz_slider->GetLowerValueD()), static_cast<unsigned int>(m_horz_slider->GetHigherValueD()));
|
||||||
|
m_canvas->render();
|
||||||
|
}
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
|
||||||
} // namespace GUI
|
} // namespace GUI
|
||||||
} // namespace Slic3r
|
} // namespace Slic3r
|
||||||
|
|
|
@ -24,7 +24,9 @@ namespace Slic3r {
|
||||||
class DynamicPrintConfig;
|
class DynamicPrintConfig;
|
||||||
class Print;
|
class Print;
|
||||||
class BackgroundSlicingProcess;
|
class BackgroundSlicingProcess;
|
||||||
|
#if !ENABLE_GCODE_VIEWER
|
||||||
class GCodePreviewData;
|
class GCodePreviewData;
|
||||||
|
#endif // !ENABLE_GCODE_VIEWER
|
||||||
class Model;
|
class Model;
|
||||||
|
|
||||||
namespace DoubleSlider {
|
namespace DoubleSlider {
|
||||||
|
@ -100,9 +102,10 @@ class Preview : public wxPanel
|
||||||
|
|
||||||
DynamicPrintConfig* m_config;
|
DynamicPrintConfig* m_config;
|
||||||
BackgroundSlicingProcess* m_process;
|
BackgroundSlicingProcess* m_process;
|
||||||
GCodePreviewData* m_gcode_preview_data;
|
|
||||||
#if ENABLE_GCODE_VIEWER
|
#if ENABLE_GCODE_VIEWER
|
||||||
GCodeProcessor::Result* m_gcode_result;
|
GCodeProcessor::Result* m_gcode_result;
|
||||||
|
#else
|
||||||
|
GCodePreviewData* m_gcode_preview_data;
|
||||||
#endif // ENABLE_GCODE_VIEWER
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
#ifdef __linux__
|
#ifdef __linux__
|
||||||
|
@ -118,9 +121,18 @@ class Preview : public wxPanel
|
||||||
std::string m_preferred_color_mode;
|
std::string m_preferred_color_mode;
|
||||||
|
|
||||||
bool m_loaded;
|
bool m_loaded;
|
||||||
|
#if !ENABLE_GCODE_VIEWER
|
||||||
bool m_enabled;
|
bool m_enabled;
|
||||||
|
#endif // !ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
DoubleSlider::Control* m_vert_slider{ nullptr };
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
DoubleSlider::Control* m_horz_slider{ nullptr };
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
#else
|
||||||
DoubleSlider::Control* m_slider {nullptr};
|
DoubleSlider::Control* m_slider {nullptr};
|
||||||
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
public:
|
public:
|
||||||
#if ENABLE_GCODE_VIEWER
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
@ -138,7 +150,9 @@ Preview(wxWindow* parent, Model* model, DynamicPrintConfig* config,
|
||||||
void set_as_dirty();
|
void set_as_dirty();
|
||||||
|
|
||||||
void set_number_extruders(unsigned int number_extruders);
|
void set_number_extruders(unsigned int number_extruders);
|
||||||
|
#if !ENABLE_GCODE_VIEWER
|
||||||
void set_enabled(bool enabled);
|
void set_enabled(bool enabled);
|
||||||
|
#endif // !ENABLE_GCODE_VIEWER
|
||||||
void bed_shape_changed();
|
void bed_shape_changed();
|
||||||
void select_view(const std::string& direction);
|
void select_view(const std::string& direction);
|
||||||
void set_drop_target(wxDropTarget* target);
|
void set_drop_target(wxDropTarget* target);
|
||||||
|
@ -157,6 +171,9 @@ Preview(wxWindow* parent, Model* model, DynamicPrintConfig* config,
|
||||||
|
|
||||||
#if ENABLE_GCODE_VIEWER
|
#if ENABLE_GCODE_VIEWER
|
||||||
void update_bottom_toolbar();
|
void update_bottom_toolbar();
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
void update_horz_slider();
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
#endif // ENABLE_GCODE_VIEWER
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -165,12 +182,14 @@ private:
|
||||||
void bind_event_handlers();
|
void bind_event_handlers();
|
||||||
void unbind_event_handlers();
|
void unbind_event_handlers();
|
||||||
|
|
||||||
#if !ENABLE_GCODE_VIEWER
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
void hide_vert_slider();
|
||||||
|
#else
|
||||||
void show_hide_ui_elements(const std::string& what);
|
void show_hide_ui_elements(const std::string& what);
|
||||||
#endif // !ENABLE_GCODE_VIEWER
|
|
||||||
|
|
||||||
void reset_sliders(bool reset_all);
|
void reset_sliders(bool reset_all);
|
||||||
void update_sliders(const std::vector<double>& layers_z, bool keep_z_range = false);
|
void update_sliders(const std::vector<double>& layers_z, bool keep_z_range = false);
|
||||||
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
void on_size(wxSizeEvent& evt);
|
void on_size(wxSizeEvent& evt);
|
||||||
void on_choice_view_type(wxCommandEvent& evt);
|
void on_choice_view_type(wxCommandEvent& evt);
|
||||||
|
@ -185,20 +204,39 @@ private:
|
||||||
void on_checkbox_legend(wxCommandEvent& evt);
|
void on_checkbox_legend(wxCommandEvent& evt);
|
||||||
#endif // ENABLE_GCODE_VIEWER
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
// Create/Update/Reset double slider on 3dPreview
|
||||||
|
wxBoxSizer* create_vert_slider_sizer();
|
||||||
|
void check_vert_slider_values(std::vector<CustomGCode::Item>& ticks_from_model,
|
||||||
|
const std::vector<double>& layers_z);
|
||||||
|
void reset_vert_slider();
|
||||||
|
void update_vert_slider(const std::vector<double>& layers_z, bool keep_z_range = false);
|
||||||
|
void update_vert_slider_mode();
|
||||||
|
// update vertical DoubleSlider after keyDown in canvas
|
||||||
|
void update_vert_slider_from_canvas(wxKeyEvent& event);
|
||||||
|
#else
|
||||||
// Create/Update/Reset double slider on 3dPreview
|
// Create/Update/Reset double slider on 3dPreview
|
||||||
void create_double_slider();
|
void create_double_slider();
|
||||||
void check_slider_values(std::vector<CustomGCode::Item> &ticks_from_model,
|
void check_slider_values(std::vector<CustomGCode::Item>& ticks_from_model,
|
||||||
const std::vector<double> &layers_z);
|
const std::vector<double>& layers_z);
|
||||||
void reset_double_slider();
|
void reset_double_slider();
|
||||||
void update_double_slider(const std::vector<double>& layers_z, bool keep_z_range = false);
|
void update_double_slider(const std::vector<double>& layers_z, bool keep_z_range = false);
|
||||||
void update_double_slider_mode();
|
void update_double_slider_mode();
|
||||||
// update DoubleSlider after keyDown in canvas
|
// update DoubleSlider after keyDown in canvas
|
||||||
void update_double_slider_from_canvas(wxKeyEvent& event);
|
void update_double_slider_from_canvas(wxKeyEvent& event);
|
||||||
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
void load_print_as_fff(bool keep_z_range = false);
|
void load_print_as_fff(bool keep_z_range = false);
|
||||||
void load_print_as_sla();
|
void load_print_as_sla();
|
||||||
|
|
||||||
|
#if ENABLE_GCODE_VIEWER
|
||||||
|
void on_vert_slider_scroll_changed(wxCommandEvent& event);
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
void on_horz_slider_scroll_changed(wxCommandEvent& event);
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
#else
|
||||||
void on_sliders_scroll_changed(wxCommandEvent& event);
|
void on_sliders_scroll_changed(wxCommandEvent& event);
|
||||||
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace GUI
|
} // namespace GUI
|
||||||
|
|
|
@ -1641,6 +1641,9 @@ struct Plater::priv
|
||||||
bool init_view_toolbar();
|
bool init_view_toolbar();
|
||||||
#if ENABLE_GCODE_VIEWER
|
#if ENABLE_GCODE_VIEWER
|
||||||
void update_preview_bottom_toolbar();
|
void update_preview_bottom_toolbar();
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
void update_preview_horz_slider();
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
#endif // ENABLE_GCODE_VIEWER
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
void reset_all_gizmos();
|
void reset_all_gizmos();
|
||||||
|
@ -2591,8 +2594,10 @@ void Plater::priv::deselect_all()
|
||||||
|
|
||||||
void Plater::priv::remove(size_t obj_idx)
|
void Plater::priv::remove(size_t obj_idx)
|
||||||
{
|
{
|
||||||
|
#if !ENABLE_GCODE_VIEWER
|
||||||
// Prevent toolpaths preview from rendering while we modify the Print object
|
// Prevent toolpaths preview from rendering while we modify the Print object
|
||||||
preview->set_enabled(false);
|
preview->set_enabled(false);
|
||||||
|
#endif // !ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
if (view3D->is_layers_editing_enabled())
|
if (view3D->is_layers_editing_enabled())
|
||||||
view3D->enable_layers_editing(false);
|
view3D->enable_layers_editing(false);
|
||||||
|
@ -2622,8 +2627,10 @@ void Plater::priv::reset()
|
||||||
|
|
||||||
set_project_filename(wxEmptyString);
|
set_project_filename(wxEmptyString);
|
||||||
|
|
||||||
|
#if !ENABLE_GCODE_VIEWER
|
||||||
// Prevent toolpaths preview from rendering while we modify the Print object
|
// Prevent toolpaths preview from rendering while we modify the Print object
|
||||||
preview->set_enabled(false);
|
preview->set_enabled(false);
|
||||||
|
#endif // !ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
if (view3D->is_layers_editing_enabled())
|
if (view3D->is_layers_editing_enabled())
|
||||||
view3D->enable_layers_editing(false);
|
view3D->enable_layers_editing(false);
|
||||||
|
@ -3867,6 +3874,13 @@ void Plater::priv::update_preview_bottom_toolbar()
|
||||||
{
|
{
|
||||||
preview->update_bottom_toolbar();
|
preview->update_bottom_toolbar();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
void Plater::priv::update_preview_horz_slider()
|
||||||
|
{
|
||||||
|
preview->update_horz_slider();
|
||||||
|
}
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
#endif // ENABLE_GCODE_VIEWER
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
bool Plater::priv::can_set_instance_to_object() const
|
bool Plater::priv::can_set_instance_to_object() const
|
||||||
|
@ -5463,6 +5477,13 @@ void Plater::update_preview_bottom_toolbar()
|
||||||
{
|
{
|
||||||
p->update_preview_bottom_toolbar();
|
p->update_preview_bottom_toolbar();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
void Plater::update_preview_horz_slider()
|
||||||
|
{
|
||||||
|
p->update_preview_horz_slider();
|
||||||
|
}
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
#endif // ENABLE_GCODE_VIEWER
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
const Mouse3DController& Plater::get_mouse3d_controller() const
|
const Mouse3DController& Plater::get_mouse3d_controller() const
|
||||||
|
|
|
@ -320,6 +320,9 @@ public:
|
||||||
|
|
||||||
#if ENABLE_GCODE_VIEWER
|
#if ENABLE_GCODE_VIEWER
|
||||||
void update_preview_bottom_toolbar();
|
void update_preview_bottom_toolbar();
|
||||||
|
#if ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
|
void update_preview_horz_slider();
|
||||||
|
#endif // ENABLE_GCODE_USE_WXWIDGETS_SLIDER
|
||||||
#endif // ENABLE_GCODE_VIEWER
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
|
|
||||||
const Mouse3DController& get_mouse3d_controller() const;
|
const Mouse3DController& get_mouse3d_controller() const;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue