mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-10-23 16:51:21 -06:00
WIP - Sequential print visualization using vertical slider in preview (missing travel moves)
This commit is contained in:
parent
70b19d2f5d
commit
4ad42d6171
6 changed files with 176 additions and 8 deletions
|
@ -64,4 +64,12 @@
|
||||||
|
|
||||||
#define ENABLE_CTRL_M_ON_WINDOWS (0 && ENABLE_2_3_0_ALPHA3)
|
#define ENABLE_CTRL_M_ON_WINDOWS (0 && ENABLE_2_3_0_ALPHA3)
|
||||||
|
|
||||||
|
|
||||||
|
//===================
|
||||||
|
// 2.3.0.alpha4 techs
|
||||||
|
//===================
|
||||||
|
#define ENABLE_2_3_0_ALPHA4 1
|
||||||
|
|
||||||
|
#define ENABLE_SEQUENTIAL_VSLIDER (1 && ENABLE_GCODE_VIEWER && ENABLE_2_3_0_ALPHA4)
|
||||||
|
|
||||||
#endif // _prusaslicer_technologies_h_
|
#endif // _prusaslicer_technologies_h_
|
||||||
|
|
|
@ -300,8 +300,13 @@ void GCodeViewer::load(const GCodeProcessor::Result& gcode_result, const Print&
|
||||||
reset();
|
reset();
|
||||||
|
|
||||||
load_toolpaths(gcode_result);
|
load_toolpaths(gcode_result);
|
||||||
|
#if ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
if (m_layers.empty())
|
||||||
|
return;
|
||||||
|
#else
|
||||||
if (m_layers_zs.empty())
|
if (m_layers_zs.empty())
|
||||||
return;
|
return;
|
||||||
|
#endif // ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
|
||||||
m_settings_ids = gcode_result.settings_ids;
|
m_settings_ids = gcode_result.settings_ids;
|
||||||
|
|
||||||
|
@ -428,7 +433,12 @@ void GCodeViewer::reset()
|
||||||
m_extrusions.reset_role_visibility_flags();
|
m_extrusions.reset_role_visibility_flags();
|
||||||
m_extrusions.reset_ranges();
|
m_extrusions.reset_ranges();
|
||||||
m_shells.volumes.clear();
|
m_shells.volumes.clear();
|
||||||
|
#if ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
m_layers.reset();
|
||||||
|
m_layers_z_range_2 = { 0, 0 };
|
||||||
|
#else
|
||||||
m_layers_zs = std::vector<double>();
|
m_layers_zs = std::vector<double>();
|
||||||
|
#endif // ENABLE_SEQUENTIAL_VSLIDER
|
||||||
m_layers_z_range = { 0.0, 0.0 };
|
m_layers_z_range = { 0.0, 0.0 };
|
||||||
m_roles = std::vector<ExtrusionRole>();
|
m_roles = std::vector<ExtrusionRole>();
|
||||||
m_time_statistics.reset();
|
m_time_statistics.reset();
|
||||||
|
@ -599,6 +609,16 @@ void GCodeViewer::set_options_visibility_from_flags(unsigned int flags)
|
||||||
enable_legend(is_flag_set(static_cast<unsigned int>(Preview::OptionType::Legend)));
|
enable_legend(is_flag_set(static_cast<unsigned int>(Preview::OptionType::Legend)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
void GCodeViewer::set_layers_z_range(const std::array<unsigned int, 2>& layers_z_range)
|
||||||
|
{
|
||||||
|
bool keep_sequential_current_first = layers_z_range[0] >= m_layers_z_range_2[0];
|
||||||
|
bool keep_sequential_current_last = layers_z_range[1] <= m_layers_z_range_2[1];
|
||||||
|
m_layers_z_range_2 = layers_z_range;
|
||||||
|
refresh_render_paths(keep_sequential_current_first, keep_sequential_current_last);
|
||||||
|
wxGetApp().plater()->update_preview_moves_slider();
|
||||||
|
}
|
||||||
|
#else
|
||||||
void GCodeViewer::set_layers_z_range(const std::array<double, 2>& layers_z_range)
|
void GCodeViewer::set_layers_z_range(const std::array<double, 2>& layers_z_range)
|
||||||
{
|
{
|
||||||
bool keep_sequential_current_first = layers_z_range[0] >= m_layers_z_range[0];
|
bool keep_sequential_current_first = layers_z_range[0] >= m_layers_z_range[0];
|
||||||
|
@ -607,6 +627,7 @@ void GCodeViewer::set_layers_z_range(const std::array<double, 2>& layers_z_range
|
||||||
refresh_render_paths(keep_sequential_current_first, keep_sequential_current_last);
|
refresh_render_paths(keep_sequential_current_first, keep_sequential_current_last);
|
||||||
wxGetApp().plater()->update_preview_moves_slider();
|
wxGetApp().plater()->update_preview_moves_slider();
|
||||||
}
|
}
|
||||||
|
#endif // ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
|
||||||
void GCodeViewer::export_toolpaths_to_obj(const char* filename) const
|
void GCodeViewer::export_toolpaths_to_obj(const char* filename) const
|
||||||
{
|
{
|
||||||
|
@ -1531,11 +1552,39 @@ void GCodeViewer::load_toolpaths(const GCodeProcessor::Result& gcode_result)
|
||||||
// dismiss indices data, no more needed
|
// dismiss indices data, no more needed
|
||||||
std::vector<MultiIndexBuffer>().swap(indices);
|
std::vector<MultiIndexBuffer>().swap(indices);
|
||||||
|
|
||||||
|
#if ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
// layers zs / roles / extruder ids / cp color ids -> extract from result
|
||||||
|
std::vector<std::pair<double, unsigned int>> averages;
|
||||||
|
for (size_t i = 0; i < m_moves_count; ++i) {
|
||||||
|
const GCodeProcessor::MoveVertex& move = gcode_result.moves[i];
|
||||||
|
if (move.type == EMoveType::Extrude) {
|
||||||
|
// layers zs
|
||||||
|
const double* const last_z = m_layers.empty() ? nullptr : &m_layers.get_zs().back();
|
||||||
|
double z = static_cast<double>(move.position[2]);
|
||||||
|
if (last_z == nullptr || z < *last_z - EPSILON || *last_z + EPSILON < z)
|
||||||
|
m_layers.append(z, { i - 1, i });
|
||||||
|
else
|
||||||
|
m_layers.get_endpoints().back().last = i;
|
||||||
|
// extruder ids
|
||||||
|
m_extruder_ids.emplace_back(move.extruder_id);
|
||||||
|
// roles
|
||||||
|
if (i > 0)
|
||||||
|
m_roles.emplace_back(move.extrusion_role);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// set layers z range
|
||||||
|
if (!m_layers.empty()) {
|
||||||
|
m_layers_z_range = { m_layers.get_zs().front(), m_layers.get_zs().back() };
|
||||||
|
m_layers_z_range_2 = { 0, static_cast<unsigned int>(m_layers.size() - 1) };
|
||||||
|
}
|
||||||
|
#else
|
||||||
// layers zs -> extract from result
|
// layers zs -> extract from result
|
||||||
for (const Path& path : m_buffers[buffer_id(EMoveType::Extrude)].paths) {
|
for (const Path& path : m_buffers[buffer_id(EMoveType::Extrude)].paths) {
|
||||||
m_layers_zs.emplace_back(static_cast<double>(path.first.position[2]));
|
m_layers_zs.emplace_back(static_cast<double>(path.first.position[2]));
|
||||||
// m_layers_zs.emplace_back(static_cast<double>(path.last.position[2]));
|
// m_layers_zs.emplace_back(static_cast<double>(path.last.position[2]));
|
||||||
}
|
}
|
||||||
|
|
||||||
// roles / extruder ids / cp color ids -> extract from result
|
// roles / extruder ids / cp color ids -> extract from result
|
||||||
for (size_t i = 0; i < m_moves_count; ++i) {
|
for (size_t i = 0; i < m_moves_count; ++i) {
|
||||||
const GCodeProcessor::MoveVertex& move = gcode_result.moves[i];
|
const GCodeProcessor::MoveVertex& move = gcode_result.moves[i];
|
||||||
|
@ -1544,6 +1593,7 @@ void GCodeViewer::load_toolpaths(const GCodeProcessor::Result& gcode_result)
|
||||||
m_roles.emplace_back(move.extrusion_role);
|
m_roles.emplace_back(move.extrusion_role);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// layers zs -> replace intervals of layers with similar top positions with their average value.
|
// layers zs -> replace intervals of layers with similar top positions with their average value.
|
||||||
std::sort(m_layers_zs.begin(), m_layers_zs.end());
|
std::sort(m_layers_zs.begin(), m_layers_zs.end());
|
||||||
int n = int(m_layers_zs.size());
|
int n = int(m_layers_zs.size());
|
||||||
|
@ -1560,9 +1610,11 @@ void GCodeViewer::load_toolpaths(const GCodeProcessor::Result& gcode_result)
|
||||||
m_layers_zs.shrink_to_fit();
|
m_layers_zs.shrink_to_fit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// set layers z range
|
// set layers z range
|
||||||
if (!m_layers_zs.empty())
|
if (!m_layers_zs.empty())
|
||||||
m_layers_z_range = { m_layers_zs.front(), m_layers_zs.back() };
|
m_layers_z_range = { m_layers_zs.front(), m_layers_zs.back() };
|
||||||
|
#endif // ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
|
||||||
// roles -> remove duplicates
|
// roles -> remove duplicates
|
||||||
std::sort(m_roles.begin(), m_roles.end());
|
std::sort(m_roles.begin(), m_roles.end());
|
||||||
|
@ -1671,9 +1723,19 @@ void GCodeViewer::refresh_render_paths(bool keep_sequential_current_first, bool
|
||||||
Travel_Colors[0] /* Move */);
|
Travel_Colors[0] /* Move */);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#if ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
auto is_in_layers_range = [this](const Path& path, size_t min_id, size_t max_id) {
|
||||||
|
auto in_layers_range = [this, min_id, max_id](size_t id) {
|
||||||
|
return m_layers.get_endpoints_at(min_id).first <= id && id <= m_layers.get_endpoints_at(max_id).last;
|
||||||
|
};
|
||||||
|
|
||||||
|
return in_layers_range(path.first.s_id) || in_layers_range(path.last.s_id);
|
||||||
|
};
|
||||||
|
#endif // ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
|
||||||
auto is_in_z_range = [](const Path& path, double min_z, double max_z) {
|
auto is_in_z_range = [](const Path& path, double min_z, double max_z) {
|
||||||
auto in_z_range = [min_z, max_z](double z) {
|
auto in_z_range = [min_z, max_z](double z) {
|
||||||
return z > min_z - EPSILON && z < max_z + EPSILON;
|
return min_z - EPSILON < z && z < max_z + EPSILON;
|
||||||
};
|
};
|
||||||
|
|
||||||
return in_z_range(path.first.position[2]) || in_z_range(path.last.position[2]);
|
return in_z_range(path.first.position[2]) || in_z_range(path.last.position[2]);
|
||||||
|
@ -1727,8 +1789,13 @@ void GCodeViewer::refresh_render_paths(bool keep_sequential_current_first, bool
|
||||||
if (!is_travel_in_z_range(i, m_layers_z_range[0], m_layers_z_range[1]))
|
if (!is_travel_in_z_range(i, m_layers_z_range[0], m_layers_z_range[1]))
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
#if ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
else if (!is_in_layers_range(path, m_layers_z_range_2[0], m_layers_z_range_2[1]))
|
||||||
|
continue;
|
||||||
|
#else
|
||||||
else if (!is_in_z_range(path, m_layers_z_range[0], m_layers_z_range[1]))
|
else if (!is_in_z_range(path, m_layers_z_range[0], m_layers_z_range[1]))
|
||||||
continue;
|
continue;
|
||||||
|
#endif // ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
|
||||||
if (path.type == EMoveType::Extrude && !is_visible(path))
|
if (path.type == EMoveType::Extrude && !is_visible(path))
|
||||||
continue;
|
continue;
|
||||||
|
@ -1746,10 +1813,17 @@ void GCodeViewer::refresh_render_paths(bool keep_sequential_current_first, bool
|
||||||
top_layer_endpoints.last = std::max(top_layer_endpoints.last, path.last.s_id);
|
top_layer_endpoints.last = std::max(top_layer_endpoints.last, path.last.s_id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#if ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
else if (is_in_layers_range(path, m_layers_z_range_2[1], m_layers_z_range_2[1])) {
|
||||||
|
top_layer_endpoints.first = std::min(top_layer_endpoints.first, path.first.s_id);
|
||||||
|
top_layer_endpoints.last = std::max(top_layer_endpoints.last, path.last.s_id);
|
||||||
|
}
|
||||||
|
#else
|
||||||
else if (is_in_z_range(path, m_layers_z_range[1], m_layers_z_range[1])) {
|
else if (is_in_z_range(path, m_layers_z_range[1], m_layers_z_range[1])) {
|
||||||
top_layer_endpoints.first = std::min(top_layer_endpoints.first, path.first.s_id);
|
top_layer_endpoints.first = std::min(top_layer_endpoints.first, path.first.s_id);
|
||||||
top_layer_endpoints.last = std::max(top_layer_endpoints.last, path.last.s_id);
|
top_layer_endpoints.last = std::max(top_layer_endpoints.last, path.last.s_id);
|
||||||
}
|
}
|
||||||
|
#endif // ENABLE_SEQUENTIAL_VSLIDER
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1803,7 +1877,13 @@ void GCodeViewer::refresh_render_paths(bool keep_sequential_current_first, bool
|
||||||
switch (path.type)
|
switch (path.type)
|
||||||
{
|
{
|
||||||
case EMoveType::Extrude: {
|
case EMoveType::Extrude: {
|
||||||
|
#if ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
if (!top_layer_only ||
|
||||||
|
m_sequential_view.current.last == global_endpoints.last ||
|
||||||
|
is_in_layers_range(path, m_layers_z_range_2[1], m_layers_z_range_2[1]))
|
||||||
|
#else
|
||||||
if (!top_layer_only || m_sequential_view.current.last == global_endpoints.last || is_in_z_range(path, m_layers_z_range[1], m_layers_z_range[1]))
|
if (!top_layer_only || m_sequential_view.current.last == global_endpoints.last || is_in_z_range(path, m_layers_z_range[1], m_layers_z_range[1]))
|
||||||
|
#endif // ENABLE_SEQUENTIAL_VSLIDER
|
||||||
color = extrusion_color(path);
|
color = extrusion_color(path);
|
||||||
else
|
else
|
||||||
color = { 0.25f, 0.25f, 0.25f };
|
color = { 0.25f, 0.25f, 0.25f };
|
||||||
|
@ -2197,13 +2277,23 @@ void GCodeViewer::render_legend() const
|
||||||
if (item.type != ColorChange)
|
if (item.type != ColorChange)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
#if ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
const std::vector<double> zs = m_layers.get_zs();
|
||||||
|
auto lower_b = std::lower_bound(zs.begin(), zs.end(), item.print_z - Slic3r::DoubleSlider::epsilon());
|
||||||
|
if (lower_b == zs.end())
|
||||||
|
continue;
|
||||||
|
#else
|
||||||
auto lower_b = std::lower_bound(m_layers_zs.begin(), m_layers_zs.end(), item.print_z - Slic3r::DoubleSlider::epsilon());
|
auto lower_b = std::lower_bound(m_layers_zs.begin(), m_layers_zs.end(), item.print_z - Slic3r::DoubleSlider::epsilon());
|
||||||
|
|
||||||
if (lower_b == m_layers_zs.end())
|
if (lower_b == m_layers_zs.end())
|
||||||
continue;
|
continue;
|
||||||
|
#endif // ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
|
||||||
double current_z = *lower_b;
|
double current_z = *lower_b;
|
||||||
|
#if ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
double previous_z = (lower_b == zs.begin()) ? 0.0 : *(--lower_b);
|
||||||
|
#else
|
||||||
double previous_z = lower_b == m_layers_zs.begin() ? 0.0 : *(--lower_b);
|
double previous_z = lower_b == m_layers_zs.begin() ? 0.0 : *(--lower_b);
|
||||||
|
#endif // ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
|
||||||
// to avoid duplicate values, check adding values
|
// to avoid duplicate values, check adding values
|
||||||
if (ret.empty() || !(ret.back().second.first == previous_z && ret.back().second.second == current_z))
|
if (ret.empty() || !(ret.back().second.first == previous_z && ret.back().second.second == current_z))
|
||||||
|
@ -2794,10 +2884,18 @@ void GCodeViewer::log_memory_used(const std::string& label, long long additional
|
||||||
render_paths_size += SLIC3R_STDVEC_MEMSIZE(path.offsets, size_t);
|
render_paths_size += SLIC3R_STDVEC_MEMSIZE(path.offsets, size_t);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#if ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
long long layers_size = SLIC3R_STDVEC_MEMSIZE(m_layers.get_zs(), double);
|
||||||
|
layers_size += SLIC3R_STDVEC_MEMSIZE(m_layers.get_endpoints(), Layers::Endpoints);
|
||||||
|
BOOST_LOG_TRIVIAL(trace) << label
|
||||||
|
<< format_memsize_MB(additional + paths_size + render_paths_size + layers_size)
|
||||||
|
<< log_memory_info();
|
||||||
|
#else
|
||||||
long long layers_zs_size = SLIC3R_STDVEC_MEMSIZE(m_layers_zs, double);
|
long long layers_zs_size = SLIC3R_STDVEC_MEMSIZE(m_layers_zs, double);
|
||||||
BOOST_LOG_TRIVIAL(trace) << label
|
BOOST_LOG_TRIVIAL(trace) << label
|
||||||
<< format_memsize_MB(additional + paths_size + render_paths_size + layers_zs_size)
|
<< format_memsize_MB(additional + paths_size + render_paths_size + layers_zs_size)
|
||||||
<< log_memory_info();
|
<< log_memory_info();
|
||||||
|
#endif // ENABLE_SEQUENTIAL_VSLIDER
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -272,6 +272,42 @@ class GCodeViewer
|
||||||
void reset_ranges() { ranges.reset(); }
|
void reset_ranges() { ranges.reset(); }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#if ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
class Layers
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
struct Endpoints
|
||||||
|
{
|
||||||
|
size_t first{ 0 };
|
||||||
|
size_t last{ 0 };
|
||||||
|
};
|
||||||
|
|
||||||
|
private:
|
||||||
|
std::vector<double> m_zs;
|
||||||
|
std::vector<Endpoints> m_endpoints;
|
||||||
|
|
||||||
|
public:
|
||||||
|
void append(double z, Endpoints endpoints)
|
||||||
|
{
|
||||||
|
m_zs.emplace_back(z);
|
||||||
|
m_endpoints.emplace_back(endpoints);
|
||||||
|
}
|
||||||
|
|
||||||
|
void reset()
|
||||||
|
{
|
||||||
|
m_zs = std::vector<double>();
|
||||||
|
m_endpoints = std::vector<Endpoints>();
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t size() const { return m_zs.size(); }
|
||||||
|
bool empty() const { return m_zs.empty(); }
|
||||||
|
const std::vector<double>& get_zs() const { return m_zs; }
|
||||||
|
const std::vector<Endpoints>& get_endpoints() const { return m_endpoints; }
|
||||||
|
std::vector<Endpoints>& get_endpoints() { return m_endpoints; }
|
||||||
|
Endpoints get_endpoints_at(unsigned int id) const { return (id < m_endpoints.size()) ? m_endpoints[id] : Endpoints(); }
|
||||||
|
};
|
||||||
|
#endif // ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
|
||||||
#if ENABLE_GCODE_VIEWER_STATISTICS
|
#if ENABLE_GCODE_VIEWER_STATISTICS
|
||||||
struct Statistics
|
struct Statistics
|
||||||
{
|
{
|
||||||
|
@ -397,7 +433,12 @@ private:
|
||||||
// bounding box of toolpaths + marker tools
|
// bounding box of toolpaths + marker tools
|
||||||
BoundingBoxf3 m_max_bounding_box;
|
BoundingBoxf3 m_max_bounding_box;
|
||||||
std::vector<Color> m_tool_colors;
|
std::vector<Color> m_tool_colors;
|
||||||
|
#if ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
Layers m_layers;
|
||||||
|
std::array<unsigned int, 2> m_layers_z_range_2;
|
||||||
|
#else
|
||||||
std::vector<double> m_layers_zs;
|
std::vector<double> m_layers_zs;
|
||||||
|
#endif // ENABLE_SEQUENTIAL_VSLIDER
|
||||||
std::array<double, 2> m_layers_z_range;
|
std::array<double, 2> m_layers_z_range;
|
||||||
std::vector<ExtrusionRole> m_roles;
|
std::vector<ExtrusionRole> m_roles;
|
||||||
size_t m_extruders_count;
|
size_t m_extruders_count;
|
||||||
|
@ -431,7 +472,11 @@ public:
|
||||||
|
|
||||||
const BoundingBoxf3& get_paths_bounding_box() const { return m_paths_bounding_box; }
|
const BoundingBoxf3& get_paths_bounding_box() const { return m_paths_bounding_box; }
|
||||||
const BoundingBoxf3& get_max_bounding_box() const { return m_max_bounding_box; }
|
const BoundingBoxf3& get_max_bounding_box() const { return m_max_bounding_box; }
|
||||||
|
#if ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
const std::vector<double>& get_layers_zs() const { return m_layers.get_zs(); };
|
||||||
|
#else
|
||||||
const std::vector<double>& get_layers_zs() const { return m_layers_zs; };
|
const std::vector<double>& get_layers_zs() const { return m_layers_zs; };
|
||||||
|
#endif // ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
|
||||||
const SequentialView& get_sequential_view() const { return m_sequential_view; }
|
const SequentialView& get_sequential_view() const { return m_sequential_view; }
|
||||||
void update_sequential_view_current(unsigned int first, unsigned int last);
|
void update_sequential_view_current(unsigned int first, unsigned int last);
|
||||||
|
@ -450,7 +495,11 @@ 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_SEQUENTIAL_VSLIDER
|
||||||
|
void set_layers_z_range(const std::array<unsigned int, 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);
|
||||||
|
#endif // ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
|
||||||
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; }
|
||||||
|
|
|
@ -2182,9 +2182,19 @@ void GLCanvas3D::set_toolpath_view_type(GCodeViewer::EViewType type)
|
||||||
void GLCanvas3D::set_toolpaths_z_range(const std::array<double, 2>& range)
|
void GLCanvas3D::set_toolpaths_z_range(const std::array<double, 2>& range)
|
||||||
{
|
{
|
||||||
m_volumes.set_range(range[0] - 1e-6, range[1] + 1e-6);
|
m_volumes.set_range(range[0] - 1e-6, range[1] + 1e-6);
|
||||||
|
#if !ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
if (m_gcode_viewer.has_data())
|
||||||
|
m_gcode_viewer.set_layers_z_range(range);
|
||||||
|
#endif // !ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
}
|
||||||
|
|
||||||
|
#if ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
void GLCanvas3D::set_toolpaths_z_range_2(const std::array<unsigned int, 2>& range)
|
||||||
|
{
|
||||||
if (m_gcode_viewer.has_data())
|
if (m_gcode_viewer.has_data())
|
||||||
m_gcode_viewer.set_layers_z_range(range);
|
m_gcode_viewer.set_layers_z_range(range);
|
||||||
}
|
}
|
||||||
|
#endif // ENABLE_SEQUENTIAL_VSLIDER
|
||||||
#else
|
#else
|
||||||
std::vector<double> GLCanvas3D::get_current_print_zs(bool active_only) const
|
std::vector<double> GLCanvas3D::get_current_print_zs(bool active_only) const
|
||||||
{
|
{
|
||||||
|
|
|
@ -652,6 +652,9 @@ public:
|
||||||
void set_toolpath_role_visibility_flags(unsigned int flags);
|
void set_toolpath_role_visibility_flags(unsigned int flags);
|
||||||
void set_toolpath_view_type(GCodeViewer::EViewType type);
|
void set_toolpath_view_type(GCodeViewer::EViewType type);
|
||||||
void set_toolpaths_z_range(const std::array<double, 2>& range);
|
void set_toolpaths_z_range(const std::array<double, 2>& range);
|
||||||
|
#if ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
void set_toolpaths_z_range_2(const std::array<unsigned int, 2>& range);
|
||||||
|
#endif // ENABLE_SEQUENTIAL_VSLIDER
|
||||||
#else
|
#else
|
||||||
std::vector<double> get_current_print_zs(bool active_only) const;
|
std::vector<double> get_current_print_zs(bool active_only) const;
|
||||||
#endif // ENABLE_GCODE_VIEWER
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
|
|
|
@ -1427,13 +1427,14 @@ void Preview::on_layers_slider_scroll_changed(wxCommandEvent& event)
|
||||||
void Preview::on_sliders_scroll_changed(wxCommandEvent& event)
|
void Preview::on_sliders_scroll_changed(wxCommandEvent& event)
|
||||||
#endif // ENABLE_GCODE_VIEWER
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
{
|
{
|
||||||
if (IsShown())
|
if (IsShown()) {
|
||||||
{
|
|
||||||
PrinterTechnology tech = m_process->current_printer_technology();
|
PrinterTechnology tech = m_process->current_printer_technology();
|
||||||
if (tech == ptFFF)
|
if (tech == ptFFF) {
|
||||||
{
|
|
||||||
#if ENABLE_GCODE_VIEWER
|
#if ENABLE_GCODE_VIEWER
|
||||||
m_canvas->set_toolpaths_z_range({ m_layers_slider->GetLowerValueD(), m_layers_slider->GetHigherValueD() });
|
m_canvas->set_toolpaths_z_range({ m_layers_slider->GetLowerValueD(), m_layers_slider->GetHigherValueD() });
|
||||||
|
#if ENABLE_SEQUENTIAL_VSLIDER
|
||||||
|
m_canvas->set_toolpaths_z_range_2({ static_cast<unsigned int>(m_layers_slider->GetLowerValue()), static_cast<unsigned int>(m_layers_slider->GetHigherValue()) });
|
||||||
|
#endif // ENABLE_SEQUENTIAL_VSLIDER
|
||||||
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);
|
||||||
|
@ -1441,8 +1442,7 @@ void Preview::on_sliders_scroll_changed(wxCommandEvent& event)
|
||||||
m_canvas->set_use_clipping_planes(false);
|
m_canvas->set_use_clipping_planes(false);
|
||||||
#endif // ENABLE_GCODE_VIEWER
|
#endif // ENABLE_GCODE_VIEWER
|
||||||
}
|
}
|
||||||
else if (tech == ptSLA)
|
else if (tech == ptSLA) {
|
||||||
{
|
|
||||||
#if ENABLE_GCODE_VIEWER
|
#if ENABLE_GCODE_VIEWER
|
||||||
m_canvas->set_clipping_plane(0, ClippingPlane(Vec3d::UnitZ(), -m_layers_slider->GetLowerValueD()));
|
m_canvas->set_clipping_plane(0, ClippingPlane(Vec3d::UnitZ(), -m_layers_slider->GetLowerValueD()));
|
||||||
m_canvas->set_clipping_plane(1, ClippingPlane(-Vec3d::UnitZ(), m_layers_slider->GetHigherValueD()));
|
m_canvas->set_clipping_plane(1, ClippingPlane(-Vec3d::UnitZ(), m_layers_slider->GetHigherValueD()));
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue