mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-07-19 04:37:52 -06:00
Merge remote-tracking branch 'remotes/origin/gcode_preview'
This commit is contained in:
commit
8fb443522b
12 changed files with 175 additions and 38 deletions
|
@ -2044,4 +2044,11 @@ sub reset_legend_texture {
|
||||||
Slic3r::GUI::_3DScene::reset_legend_texture();
|
Slic3r::GUI::_3DScene::reset_legend_texture();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub get_current_print_zs {
|
||||||
|
my ($self) = @_;
|
||||||
|
|
||||||
|
my $count = $self->volumes->get_current_print_zs();
|
||||||
|
return $count;
|
||||||
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
|
|
@ -74,12 +74,8 @@ sub new {
|
||||||
|
|
||||||
my $combochecklist_features = $self->{combochecklist_features} = Wx::ComboCtrl->new();
|
my $combochecklist_features = $self->{combochecklist_features} = Wx::ComboCtrl->new();
|
||||||
$combochecklist_features->Create($self, -1, "Feature types", wxDefaultPosition, [200, -1], wxCB_READONLY);
|
$combochecklist_features->Create($self, -1, "Feature types", wxDefaultPosition, [200, -1], wxCB_READONLY);
|
||||||
#FIXME If the following line is removed, the combo box popup list will not react to mouse clicks.
|
|
||||||
# On the other side, with this line the combo box popup cannot be closed by clicking on the combo button on Windows 10.
|
|
||||||
$combochecklist_features->UseAltPopupWindow();
|
|
||||||
$combochecklist_features->EnablePopupAnimation(0);
|
|
||||||
my $feature_text = "Feature types";
|
my $feature_text = "Feature types";
|
||||||
my $feature_items = "Perimeter|External perimeter|Overhang perimeter|Internal infill|Solid infill|Top solid infill|Bridge infill|Gap fill|Skirt|Support material|Support material interface|Wipe tower";
|
my $feature_items = "Perimeter|External perimeter|Overhang perimeter|Internal infill|Solid infill|Top solid infill|Bridge infill|Gap fill|Skirt|Support material|Support material interface|Wipe tower|Custom";
|
||||||
Slic3r::GUI::create_combochecklist($combochecklist_features, $feature_text, $feature_items, 1);
|
Slic3r::GUI::create_combochecklist($combochecklist_features, $feature_text, $feature_items, 1);
|
||||||
|
|
||||||
my $checkbox_travel = $self->{checkbox_travel} = Wx::CheckBox->new($self, -1, "Travel");
|
my $checkbox_travel = $self->{checkbox_travel} = Wx::CheckBox->new($self, -1, "Travel");
|
||||||
|
@ -255,6 +251,7 @@ sub new {
|
||||||
'Support material' => '00FF00',
|
'Support material' => '00FF00',
|
||||||
'Support material interface' => '008000',
|
'Support material interface' => '008000',
|
||||||
'Wipe tower' => 'B3E3AB',
|
'Wipe tower' => 'B3E3AB',
|
||||||
|
'Custom' => 'FFFF00',
|
||||||
);
|
);
|
||||||
$self->gcode_preview_data->set_extrusion_paths_colors(\@extrusion_roles_colors);
|
$self->gcode_preview_data->set_extrusion_paths_colors(\@extrusion_roles_colors);
|
||||||
|
|
||||||
|
@ -322,31 +319,9 @@ sub load_print {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
my $z_idx_low = $self->slider_low->GetValue;
|
# used to set the sliders to the extremes of the current zs range
|
||||||
my $z_idx_high = $self->slider_high->GetValue;
|
$self->{force_sliders_full_range} = 0;
|
||||||
$self->enabled(1);
|
|
||||||
$self->slider_low->SetRange(0, $n_layers - 1);
|
|
||||||
$self->slider_high->SetRange(0, $n_layers - 1);
|
|
||||||
if ($z_idx_high < $n_layers && ($self->single_layer || $z_idx_high != 0)) {
|
|
||||||
# use $z_idx
|
|
||||||
} else {
|
|
||||||
# Out of range. Disable 'single layer' view.
|
|
||||||
$self->single_layer(0);
|
|
||||||
$self->{checkbox_singlelayer}->SetValue(0);
|
|
||||||
$z_idx_low = 0;
|
|
||||||
$z_idx_high = $n_layers - 1;
|
|
||||||
}
|
|
||||||
if ($self->single_layer) {
|
|
||||||
$z_idx_low = $z_idx_high;
|
|
||||||
} elsif ($z_idx_low > $z_idx_high) {
|
|
||||||
$z_idx_low = 0;
|
|
||||||
}
|
|
||||||
$self->slider_low->SetValue($z_idx_low);
|
|
||||||
$self->slider_high->SetValue($z_idx_high);
|
|
||||||
$self->slider_low->Show;
|
|
||||||
$self->slider_high->Show;
|
|
||||||
$self->Layout;
|
|
||||||
|
|
||||||
if ($self->{preferred_color_mode} eq 'tool_or_feature') {
|
if ($self->{preferred_color_mode} eq 'tool_or_feature') {
|
||||||
# It is left to Slic3r to decide whether the print shall be colored by the tool or by the feature.
|
# It is left to Slic3r to decide whether the print shall be colored by the tool or by the feature.
|
||||||
# Color by feature if it is a single extruder print.
|
# Color by feature if it is a single extruder print.
|
||||||
|
@ -384,16 +359,58 @@ sub load_print {
|
||||||
}
|
}
|
||||||
$self->show_hide_ui_elements('simple');
|
$self->show_hide_ui_elements('simple');
|
||||||
} else {
|
} else {
|
||||||
|
$self->{force_sliders_full_range} = (scalar(@{$self->canvas->volumes}) == 0) && $self->auto_zoom;
|
||||||
$self->canvas->load_gcode_preview($self->print, $self->gcode_preview_data, \@colors);
|
$self->canvas->load_gcode_preview($self->print, $self->gcode_preview_data, \@colors);
|
||||||
$self->show_hide_ui_elements('full');
|
$self->show_hide_ui_elements('full');
|
||||||
|
|
||||||
|
# recalculates zs and update sliders accordingly
|
||||||
|
$self->{layers_z} = $self->canvas->get_current_print_zs();
|
||||||
|
$n_layers = scalar(@{$self->{layers_z}});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$self->update_sliders($n_layers);
|
||||||
|
|
||||||
if ($self->auto_zoom) {
|
if ($self->auto_zoom) {
|
||||||
$self->canvas->zoom_to_volumes;
|
$self->canvas->zoom_to_volumes;
|
||||||
}
|
}
|
||||||
$self->_loaded(1);
|
$self->_loaded(1);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
sub update_sliders
|
||||||
|
{
|
||||||
|
my ($self, $n_layers) = @_;
|
||||||
|
|
||||||
|
my $z_idx_low = $self->slider_low->GetValue;
|
||||||
|
my $z_idx_high = $self->slider_high->GetValue;
|
||||||
|
$self->enabled(1);
|
||||||
|
$self->slider_low->SetRange(0, $n_layers - 1);
|
||||||
|
$self->slider_high->SetRange(0, $n_layers - 1);
|
||||||
|
|
||||||
|
if ($self->{force_sliders_full_range}) {
|
||||||
|
$z_idx_low = 0;
|
||||||
|
$z_idx_high = $n_layers - 1;
|
||||||
|
} elsif ($z_idx_high < $n_layers && ($self->single_layer || $z_idx_high != 0)) {
|
||||||
|
# use $z_idx
|
||||||
|
} else {
|
||||||
|
# Out of range. Disable 'single layer' view.
|
||||||
|
$self->single_layer(0);
|
||||||
|
$self->{checkbox_singlelayer}->SetValue(0);
|
||||||
|
$z_idx_low = 0;
|
||||||
|
$z_idx_high = $n_layers - 1;
|
||||||
|
}
|
||||||
|
if ($self->single_layer) {
|
||||||
|
$z_idx_low = $z_idx_high;
|
||||||
|
} elsif ($z_idx_low > $z_idx_high) {
|
||||||
|
$z_idx_low = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
$self->slider_low->SetValue($z_idx_low);
|
||||||
|
$self->slider_high->SetValue($z_idx_high);
|
||||||
|
$self->slider_low->Show;
|
||||||
|
$self->slider_high->Show;
|
||||||
$self->set_z_range($self->{layers_z}[$z_idx_low], $self->{layers_z}[$z_idx_high]);
|
$self->set_z_range($self->{layers_z}[$z_idx_low], $self->{layers_z}[$z_idx_high]);
|
||||||
|
$self->Layout;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub set_z_range
|
sub set_z_range
|
||||||
|
|
|
@ -26,6 +26,7 @@ enum ExtrusionRole {
|
||||||
erSupportMaterial,
|
erSupportMaterial,
|
||||||
erSupportMaterialInterface,
|
erSupportMaterialInterface,
|
||||||
erWipeTower,
|
erWipeTower,
|
||||||
|
erCustom,
|
||||||
// Extrusion role for a collection with multiple extrusion roles.
|
// Extrusion role for a collection with multiple extrusion roles.
|
||||||
erMixed,
|
erMixed,
|
||||||
};
|
};
|
||||||
|
|
|
@ -587,6 +587,15 @@ void GCode::_do_export(Print &print, FILE *file, GCodePreviewData *preview_data)
|
||||||
this->_print_first_layer_bed_temperature(file, print, start_gcode, initial_extruder_id, true);
|
this->_print_first_layer_bed_temperature(file, print, start_gcode, initial_extruder_id, true);
|
||||||
// Set extruder(s) temperature before and after start G-code.
|
// Set extruder(s) temperature before and after start G-code.
|
||||||
this->_print_first_layer_extruder_temperatures(file, print, start_gcode, initial_extruder_id, false);
|
this->_print_first_layer_extruder_temperatures(file, print, start_gcode, initial_extruder_id, false);
|
||||||
|
|
||||||
|
if (m_enable_analyzer)
|
||||||
|
{
|
||||||
|
// adds tag for analyzer
|
||||||
|
char buf[32];
|
||||||
|
sprintf(buf, ";%s%d\n", GCodeAnalyzer::Extrusion_Role_Tag.c_str(), erCustom);
|
||||||
|
_writeln(file, buf);
|
||||||
|
}
|
||||||
|
|
||||||
// Write the custom start G-code
|
// Write the custom start G-code
|
||||||
_writeln(file, start_gcode);
|
_writeln(file, start_gcode);
|
||||||
// Process filament-specific gcode in extruder order.
|
// Process filament-specific gcode in extruder order.
|
||||||
|
@ -770,6 +779,15 @@ void GCode::_do_export(Print &print, FILE *file, GCodePreviewData *preview_data)
|
||||||
// Write end commands to file.
|
// Write end commands to file.
|
||||||
_write(file, this->retract());
|
_write(file, this->retract());
|
||||||
_write(file, m_writer.set_fan(false));
|
_write(file, m_writer.set_fan(false));
|
||||||
|
|
||||||
|
if (m_enable_analyzer)
|
||||||
|
{
|
||||||
|
// adds tag for analyzer
|
||||||
|
char buf[32];
|
||||||
|
sprintf(buf, ";%s%d\n", GCodeAnalyzer::Extrusion_Role_Tag.c_str(), erCustom);
|
||||||
|
_writeln(file, buf);
|
||||||
|
}
|
||||||
|
|
||||||
// Process filament-specific gcode in extruder order.
|
// Process filament-specific gcode in extruder order.
|
||||||
if (print.config.single_extruder_multi_material) {
|
if (print.config.single_extruder_multi_material) {
|
||||||
// Process the end_filament_gcode for the active filament only.
|
// Process the end_filament_gcode for the active filament only.
|
||||||
|
|
|
@ -150,7 +150,13 @@ void GCodeAnalyzer::_process_gcode_line(GCodeReader&, const GCodeReader::GCodeLi
|
||||||
{
|
{
|
||||||
// processes 'special' comments contained in line
|
// processes 'special' comments contained in line
|
||||||
if (_process_tags(line))
|
if (_process_tags(line))
|
||||||
|
{
|
||||||
|
#if 0
|
||||||
|
// DEBUG ONLY: puts the line back into the gcode
|
||||||
|
m_process_output += line.raw() + "\n";
|
||||||
|
#endif
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// sets new start position/extrusion
|
// sets new start position/extrusion
|
||||||
_set_start_position(_get_end_position());
|
_set_start_position(_get_end_position());
|
||||||
|
|
|
@ -125,6 +125,7 @@ const GCodePreviewData::Color GCodePreviewData::Extrusion::Default_Extrusion_Rol
|
||||||
Color(0.0f, 0.5f, 0.0f, 1.0f), // erSupportMaterial
|
Color(0.0f, 0.5f, 0.0f, 1.0f), // erSupportMaterial
|
||||||
Color(0.0f, 0.0f, 0.5f, 1.0f), // erSupportMaterialInterface
|
Color(0.0f, 0.0f, 0.5f, 1.0f), // erSupportMaterialInterface
|
||||||
Color(0.7f, 0.89f, 0.67f, 1.0f), // erWipeTower
|
Color(0.7f, 0.89f, 0.67f, 1.0f), // erWipeTower
|
||||||
|
Color(1.0f, 1.0f, 0.0f, 1.0f), // erCustom
|
||||||
Color(0.0f, 0.0f, 0.0f, 1.0f) // erMixed
|
Color(0.0f, 0.0f, 0.0f, 1.0f) // erMixed
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -144,6 +145,7 @@ const std::string GCodePreviewData::Extrusion::Default_Extrusion_Role_Names[Num_
|
||||||
"Support material",
|
"Support material",
|
||||||
"Support material interface",
|
"Support material interface",
|
||||||
"Wipe tower",
|
"Wipe tower",
|
||||||
|
"Custom",
|
||||||
"Mixed"
|
"Mixed"
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -360,8 +362,11 @@ GCodePreviewData::LegendItemsList GCodePreviewData::get_legend_items(const std::
|
||||||
{
|
{
|
||||||
case Extrusion::FeatureType:
|
case Extrusion::FeatureType:
|
||||||
{
|
{
|
||||||
items.reserve(erMixed - erPerimeter + 1);
|
ExtrusionRole first_valid = erPerimeter;
|
||||||
for (unsigned int i = (unsigned int)erPerimeter; i < (unsigned int)erMixed; ++i)
|
ExtrusionRole last_valid = erCustom;
|
||||||
|
|
||||||
|
items.reserve(last_valid - first_valid + 1);
|
||||||
|
for (unsigned int i = (unsigned int)first_valid; i <= (unsigned int)last_valid; ++i)
|
||||||
{
|
{
|
||||||
items.emplace_back(extrusion.role_names[i], extrusion.role_colors[i]);
|
items.emplace_back(extrusion.role_names[i], extrusion.role_colors[i]);
|
||||||
}
|
}
|
||||||
|
|
|
@ -450,6 +450,25 @@ void GLVolumeCollection::render_legacy() const
|
||||||
glDisableClientState(GL_NORMAL_ARRAY);
|
glDisableClientState(GL_NORMAL_ARRAY);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::vector<double> GLVolumeCollection::get_current_print_zs() const
|
||||||
|
{
|
||||||
|
std::vector<double> print_zs;
|
||||||
|
|
||||||
|
for (GLVolume *vol : this->volumes)
|
||||||
|
{
|
||||||
|
for (coordf_t z : vol->print_zs)
|
||||||
|
{
|
||||||
|
double round_z = (double)round(z * 100000.0f) / 100000.0f;
|
||||||
|
if (std::find(print_zs.begin(), print_zs.end(), round_z) == print_zs.end())
|
||||||
|
print_zs.push_back(round_z);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
std::sort(print_zs.begin(), print_zs.end());
|
||||||
|
|
||||||
|
return print_zs;
|
||||||
|
}
|
||||||
|
|
||||||
// caller is responsible for supplying NO lines with zero length
|
// caller is responsible for supplying NO lines with zero length
|
||||||
static void thick_lines_to_indexed_vertex_array(
|
static void thick_lines_to_indexed_vertex_array(
|
||||||
const Lines &lines,
|
const Lines &lines,
|
||||||
|
@ -2205,6 +2224,9 @@ void _3DScene::_update_gcode_volumes_visibility(const GCodePreviewData& preview_
|
||||||
{
|
{
|
||||||
case GCodePreviewVolumeIndex::Extrusion:
|
case GCodePreviewVolumeIndex::Extrusion:
|
||||||
{
|
{
|
||||||
|
if ((ExtrusionRole)s_gcode_preview_volume_index.first_volumes[i].flag == erCustom)
|
||||||
|
volume->zoom_to_volumes = false;
|
||||||
|
|
||||||
volume->is_active = preview_data.extrusion.is_role_flag_set((ExtrusionRole)s_gcode_preview_volume_index.first_volumes[i].flag);
|
volume->is_active = preview_data.extrusion.is_role_flag_set((ExtrusionRole)s_gcode_preview_volume_index.first_volumes[i].flag);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -372,6 +372,9 @@ public:
|
||||||
|
|
||||||
void set_render_interleaved_only_volumes(const RenderInterleavedOnlyVolumes& render_interleaved_only_volumes) { _render_interleaved_only_volumes = render_interleaved_only_volumes; }
|
void set_render_interleaved_only_volumes(const RenderInterleavedOnlyVolumes& render_interleaved_only_volumes) { _render_interleaved_only_volumes = render_interleaved_only_volumes; }
|
||||||
|
|
||||||
|
// Returns a vector containing the sorted list of all the print_zs of the volumes contained in this collection
|
||||||
|
std::vector<double> get_current_print_zs() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
GLVolumeCollection(const GLVolumeCollection &other);
|
GLVolumeCollection(const GLVolumeCollection &other);
|
||||||
GLVolumeCollection& operator=(const GLVolumeCollection &);
|
GLVolumeCollection& operator=(const GLVolumeCollection &);
|
||||||
|
|
|
@ -487,10 +487,17 @@ void create_combochecklist(wxComboCtrl* comboCtrl, std::string text, std::string
|
||||||
wxCheckListBoxComboPopup* popup = new wxCheckListBoxComboPopup;
|
wxCheckListBoxComboPopup* popup = new wxCheckListBoxComboPopup;
|
||||||
if (popup != nullptr)
|
if (popup != nullptr)
|
||||||
{
|
{
|
||||||
|
// FIXME If the following line is removed, the combo box popup list will not react to mouse clicks.
|
||||||
|
// On the other side, with this line the combo box popup cannot be closed by clicking on the combo button on Windows 10.
|
||||||
|
comboCtrl->UseAltPopupWindow();
|
||||||
|
|
||||||
|
comboCtrl->EnablePopupAnimation(false);
|
||||||
comboCtrl->SetPopupControl(popup);
|
comboCtrl->SetPopupControl(popup);
|
||||||
popup->SetStringValue(text);
|
popup->SetStringValue(text);
|
||||||
popup->Connect(wxID_ANY, wxEVT_CHECKLISTBOX, wxCommandEventHandler(wxCheckListBoxComboPopup::OnCheckListBox), nullptr, popup);
|
popup->Bind(wxEVT_CHECKLISTBOX, [popup](wxCommandEvent& evt) { popup->OnCheckListBox(evt); });
|
||||||
popup->Connect(wxID_ANY, wxEVT_LISTBOX, wxCommandEventHandler(wxCheckListBoxComboPopup::OnListBoxSelection), nullptr, popup);
|
popup->Bind(wxEVT_LISTBOX, [popup](wxCommandEvent& evt) { popup->OnListBoxSelection(evt); });
|
||||||
|
popup->Bind(wxEVT_KEY_DOWN, [popup](wxKeyEvent& evt) { popup->OnKeyEvent(evt); });
|
||||||
|
popup->Bind(wxEVT_KEY_UP, [popup](wxKeyEvent& evt) { popup->OnKeyEvent(evt); });
|
||||||
|
|
||||||
std::vector<std::string> items_str;
|
std::vector<std::string> items_str;
|
||||||
boost::split(items_str, items, boost::is_any_of("|"), boost::token_compress_off);
|
boost::split(items_str, items, boost::is_any_of("|"), boost::token_compress_off);
|
||||||
|
|
|
@ -1,6 +1,8 @@
|
||||||
#include "wxExtensions.hpp"
|
#include "wxExtensions.hpp"
|
||||||
|
|
||||||
const unsigned int wxCheckListBoxComboPopup::Height = 210;
|
const unsigned int wxCheckListBoxComboPopup::DefaultWidth = 200;
|
||||||
|
const unsigned int wxCheckListBoxComboPopup::DefaultHeight = 200;
|
||||||
|
const unsigned int wxCheckListBoxComboPopup::DefaultItemHeight = 18;
|
||||||
|
|
||||||
bool wxCheckListBoxComboPopup::Create(wxWindow* parent)
|
bool wxCheckListBoxComboPopup::Create(wxWindow* parent)
|
||||||
{
|
{
|
||||||
|
@ -25,16 +27,55 @@ wxString wxCheckListBoxComboPopup::GetStringValue() const
|
||||||
wxSize wxCheckListBoxComboPopup::GetAdjustedSize(int minWidth, int prefHeight, int maxHeight)
|
wxSize wxCheckListBoxComboPopup::GetAdjustedSize(int minWidth, int prefHeight, int maxHeight)
|
||||||
{
|
{
|
||||||
// matches owner wxComboCtrl's width
|
// matches owner wxComboCtrl's width
|
||||||
|
// and sets height dinamically in dependence of contained items count
|
||||||
|
|
||||||
wxComboCtrl* cmb = GetComboCtrl();
|
wxComboCtrl* cmb = GetComboCtrl();
|
||||||
if (cmb != nullptr)
|
if (cmb != nullptr)
|
||||||
{
|
{
|
||||||
wxSize size = GetComboCtrl()->GetSize();
|
wxSize size = GetComboCtrl()->GetSize();
|
||||||
size.SetHeight(Height);
|
|
||||||
|
unsigned int count = GetCount();
|
||||||
|
if (count > 0)
|
||||||
|
size.SetHeight(count * DefaultItemHeight);
|
||||||
|
else
|
||||||
|
size.SetHeight(DefaultHeight);
|
||||||
|
|
||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
return wxSize(200, Height);
|
return wxSize(DefaultWidth, DefaultHeight);
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxCheckListBoxComboPopup::OnKeyEvent(wxKeyEvent& evt)
|
||||||
|
{
|
||||||
|
// filters out all the keys which are not working properly
|
||||||
|
switch (evt.GetKeyCode())
|
||||||
|
{
|
||||||
|
case WXK_LEFT:
|
||||||
|
case WXK_UP:
|
||||||
|
case WXK_RIGHT:
|
||||||
|
case WXK_DOWN:
|
||||||
|
case WXK_PAGEUP:
|
||||||
|
case WXK_PAGEDOWN:
|
||||||
|
case WXK_END:
|
||||||
|
case WXK_HOME:
|
||||||
|
case WXK_NUMPAD_LEFT:
|
||||||
|
case WXK_NUMPAD_UP:
|
||||||
|
case WXK_NUMPAD_RIGHT:
|
||||||
|
case WXK_NUMPAD_DOWN:
|
||||||
|
case WXK_NUMPAD_PAGEUP:
|
||||||
|
case WXK_NUMPAD_PAGEDOWN:
|
||||||
|
case WXK_NUMPAD_END:
|
||||||
|
case WXK_NUMPAD_HOME:
|
||||||
|
{
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
{
|
||||||
|
evt.Skip();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxCheckListBoxComboPopup::OnCheckListBox(wxCommandEvent& evt)
|
void wxCheckListBoxComboPopup::OnCheckListBox(wxCommandEvent& evt)
|
||||||
|
@ -48,6 +89,8 @@ void wxCheckListBoxComboPopup::OnCheckListBox(wxCommandEvent& evt)
|
||||||
event.SetEventObject(cmb);
|
event.SetEventObject(cmb);
|
||||||
cmb->ProcessWindowEvent(event);
|
cmb->ProcessWindowEvent(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
evt.Skip();
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxCheckListBoxComboPopup::OnListBoxSelection(wxCommandEvent& evt)
|
void wxCheckListBoxComboPopup::OnListBoxSelection(wxCommandEvent& evt)
|
||||||
|
|
|
@ -6,7 +6,9 @@
|
||||||
|
|
||||||
class wxCheckListBoxComboPopup : public wxCheckListBox, public wxComboPopup
|
class wxCheckListBoxComboPopup : public wxCheckListBox, public wxComboPopup
|
||||||
{
|
{
|
||||||
static const unsigned int Height;
|
static const unsigned int DefaultWidth;
|
||||||
|
static const unsigned int DefaultHeight;
|
||||||
|
static const unsigned int DefaultItemHeight;
|
||||||
|
|
||||||
wxString m_text;
|
wxString m_text;
|
||||||
|
|
||||||
|
@ -17,6 +19,8 @@ public:
|
||||||
virtual wxString GetStringValue() const;
|
virtual wxString GetStringValue() const;
|
||||||
virtual wxSize GetAdjustedSize(int minWidth, int prefHeight, int maxHeight);
|
virtual wxSize GetAdjustedSize(int minWidth, int prefHeight, int maxHeight);
|
||||||
|
|
||||||
|
virtual void OnKeyEvent(wxKeyEvent& evt);
|
||||||
|
|
||||||
void OnCheckListBox(wxCommandEvent& evt);
|
void OnCheckListBox(wxCommandEvent& evt);
|
||||||
void OnListBoxSelection(wxCommandEvent& evt);
|
void OnListBoxSelection(wxCommandEvent& evt);
|
||||||
};
|
};
|
||||||
|
|
|
@ -85,7 +85,11 @@
|
||||||
|
|
||||||
int count()
|
int count()
|
||||||
%code{% RETVAL = THIS->volumes.size(); %};
|
%code{% RETVAL = THIS->volumes.size(); %};
|
||||||
|
|
||||||
|
std::vector<double> get_current_print_zs()
|
||||||
|
%code{% RETVAL = THIS->get_current_print_zs(); %};
|
||||||
|
|
||||||
|
|
||||||
void set_range(double low, double high);
|
void set_range(double low, double high);
|
||||||
|
|
||||||
void render_VBOs() const;
|
void render_VBOs() const;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue