mirror of
https://github.com/SoftFever/OrcaSlicer.git
synced 2025-10-24 09:11:23 -06:00
ENH: add tips when no sdcard
add has_ipcam status in DeviceManager Change-Id: Ie51608218c9bf9513201ccffebfd12802d320680 Signed-off-by: Stone Li <stone.li@bambulab.com>
This commit is contained in:
parent
a2c847be11
commit
3dbdc40360
5 changed files with 85 additions and 4 deletions
|
@ -1140,6 +1140,7 @@ bool MachineObject::has_recording()
|
|||
|
||||
int MachineObject::command_get_version()
|
||||
{
|
||||
BOOST_LOG_TRIVIAL(info) << "command_get_version";
|
||||
json j;
|
||||
j["info"]["sequence_id"] = std::to_string(MachineObject::m_sequence_id++);
|
||||
j["info"]["command"] = "get_version";
|
||||
|
@ -1716,6 +1717,9 @@ bool MachineObject::is_function_supported(PrinterFunction func)
|
|||
case FUNC_LOCAL_TUNNEL:
|
||||
func_name = "FUNC_LOCAL_TUNNEL";
|
||||
break;
|
||||
case FUNC_PRINT_WITHOUT_SD:
|
||||
func_name = "FUNC_PRINT_WITHOUT_SD";
|
||||
break;
|
||||
default:
|
||||
return true;
|
||||
}
|
||||
|
@ -2177,6 +2181,13 @@ int MachineObject::parse_json(std::string payload)
|
|||
camera_timelapse = false;
|
||||
}
|
||||
}
|
||||
if (jj["ipcam"].contains("ipcam_dev")) {
|
||||
if (jj["ipcam"]["ipcam_dev"].get<std::string>() == "1") {
|
||||
has_ipcam = true;
|
||||
} else {
|
||||
has_ipcam = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
catch (...) {
|
||||
|
|
|
@ -69,6 +69,7 @@ enum PrinterFunction {
|
|||
FUNC_MEDIA_FILE,
|
||||
FUNC_REMOTE_TUNNEL,
|
||||
FUNC_LOCAL_TUNNEL,
|
||||
FUNC_PRINT_WITHOUT_SD,
|
||||
FUNC_MAX
|
||||
};
|
||||
|
||||
|
@ -492,6 +493,7 @@ public:
|
|||
PrintingSpeedLevel _parse_printing_speed_lvl(int lvl);
|
||||
|
||||
/* camera */
|
||||
bool has_ipcam { false };
|
||||
bool camera_recording { false };
|
||||
bool camera_timelapse { false };
|
||||
bool camera_has_sdcard { false };
|
||||
|
|
|
@ -40,6 +40,59 @@ wxDEFINE_EVENT(EVT_EDIT_PRINT_NAME, wxCommandEvent);
|
|||
|
||||
static wxString task_canceled_text = _L("Task canceled");
|
||||
|
||||
|
||||
std::string get_print_status_info(PrintDialogStatus status)
|
||||
{
|
||||
switch(status) {
|
||||
case PrintStatusInit:
|
||||
return "PrintStatusInit";
|
||||
case PrintStatusNoUserLogin:
|
||||
return "PrintStatusNoUserLogin";
|
||||
case PrintStatusInvalidPrinter:
|
||||
return "PrintStatusInvalidPrinter";
|
||||
case PrintStatusConnectingServer:
|
||||
return "PrintStatusConnectingServer";
|
||||
case PrintStatusReading:
|
||||
return "PrintStatusReading";
|
||||
case PrintStatusReadingFinished:
|
||||
return "PrintStatusReadingFinished";
|
||||
case PrintStatusReadingTimeout:
|
||||
return "PrintStatusReadingTimeout";
|
||||
case PrintStatusInUpgrading:
|
||||
return "PrintStatusInUpgrading";
|
||||
case PrintStatusNeedUpgradingAms:
|
||||
return "PrintStatusNeedUpgradingAms";
|
||||
case PrintStatusInSystemPrinting:
|
||||
return "PrintStatusInSystemPrinting";
|
||||
case PrintStatusInPrinting:
|
||||
return "PrintStatusInPrinting";
|
||||
case PrintStatusDisableAms:
|
||||
return "PrintStatusDisableAms";
|
||||
case PrintStatusAmsMappingSuccess:
|
||||
return "PrintStatusAmsMappingSuccess";
|
||||
case PrintStatusAmsMappingInvalid:
|
||||
return "PrintStatusAmsMappingInvalid";
|
||||
case PrintStatusAmsMappingU0Invalid:
|
||||
return "PrintStatusAmsMappingU0Invalid";
|
||||
case PrintStatusAmsMappingValid:
|
||||
return "PrintStatusAmsMappingValid";
|
||||
case PrintStatusAmsMappingByOrder:
|
||||
return "PrintStatusAmsMappingByOrder";
|
||||
case PrintStatusRefreshingMachineList:
|
||||
return "PrintStatusRefreshingMachineList";
|
||||
case PrintStatusSending:
|
||||
return "PrintStatusSending";
|
||||
case PrintStatusSendingCanceled:
|
||||
return "PrintStatusSendingCanceled";
|
||||
case PrintStatusLanModeNoSdcard:
|
||||
return "PrintStatusLanModeNoSdcard";
|
||||
case PrintStatusNoSdcard:
|
||||
return "PrintStatusNoSdcard";
|
||||
}
|
||||
return "unknown";
|
||||
}
|
||||
|
||||
|
||||
MachineListModel::MachineListModel() : wxDataViewVirtualListModel(INITIAL_NUMBER_OF_MACHINES) { ; }
|
||||
|
||||
void MachineListModel::display_machines(std::map<std::string, MachineObject *> list)
|
||||
|
@ -1414,7 +1467,7 @@ void SelectMachineDialog::update_print_status_msg(wxString msg, bool is_warning,
|
|||
void SelectMachineDialog::show_status(PrintDialogStatus status, std::vector<wxString> params)
|
||||
{
|
||||
if (m_print_status != status)
|
||||
BOOST_LOG_TRIVIAL(info) << "select_machine_dialog: show_status = " << status;
|
||||
BOOST_LOG_TRIVIAL(info) << "select_machine_dialog: show_status = " << status << "(" << get_print_status_info(status) << ")";
|
||||
m_print_status = status;
|
||||
|
||||
// m_comboBox_printer
|
||||
|
@ -1524,7 +1577,7 @@ void SelectMachineDialog::show_status(PrintDialogStatus status, std::vector<wxSt
|
|||
} else if (status == PrintDialogStatus::PrintStatusSendingCanceled) {
|
||||
Enable_Send_Button(true);
|
||||
Enable_Refresh_Button(true);
|
||||
} else if (status == PrintDialogStatus::PrintStatusNoSdcard) {
|
||||
} else if (status == PrintDialogStatus::PrintStatusLanModeNoSdcard) {
|
||||
wxString msg_text = _L("An SD card needs to be inserted before printing via LAN.");
|
||||
update_print_status_msg(msg_text, true, true);
|
||||
Enable_Send_Button(true);
|
||||
|
@ -1534,6 +1587,11 @@ void SelectMachineDialog::show_status(PrintDialogStatus status, std::vector<wxSt
|
|||
update_print_status_msg(msg_text, false, false);
|
||||
Enable_Send_Button(true);
|
||||
Enable_Refresh_Button(true);
|
||||
} else if (status == PrintDialogStatus::PrintStatusNoSdcard) {
|
||||
wxString msg_text = _L("An SD card needs to be inserted before printing.");
|
||||
update_print_status_msg(msg_text, true, true);
|
||||
Enable_Send_Button(true);
|
||||
Enable_Refresh_Button(true);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1913,6 +1971,7 @@ void SelectMachineDialog::on_selection_changed(wxCommandEvent &event)
|
|||
|
||||
if (obj) {
|
||||
obj->command_get_version();
|
||||
obj->command_request_push_all();
|
||||
dev->set_selected_machine(m_printer_last_select);
|
||||
update_select_layout(obj);
|
||||
} else {
|
||||
|
@ -2016,11 +2075,17 @@ void SelectMachineDialog::update_show_status()
|
|||
show_status(PrintDialogStatus::PrintStatusInPrinting);
|
||||
return;
|
||||
}
|
||||
else if (!obj_->is_function_supported(PrinterFunction::FUNC_PRINT_WITHOUT_SD)) {
|
||||
show_status(PrintDialogStatus::PrintStatusNoSdcard);
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
|
||||
// check sdcard when if lan mode printer
|
||||
if (obj_->is_lan_mode_printer()) {
|
||||
if (!obj_->has_sdcard()) {
|
||||
show_status(PrintDialogStatus::PrintStatusNoSdcard);
|
||||
show_status(PrintDialogStatus::PrintStatusLanModeNoSdcard);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -248,9 +248,12 @@ enum PrintDialogStatus {
|
|||
PrintStatusRefreshingMachineList,
|
||||
PrintStatusSending,
|
||||
PrintStatusSendingCanceled,
|
||||
PrintStatusLanModeNoSdcard,
|
||||
PrintStatusNoSdcard
|
||||
};
|
||||
|
||||
std::string get_print_status_info(PrintDialogStatus status);
|
||||
|
||||
class SelectMachineDialog : public DPIDialog
|
||||
{
|
||||
private:
|
||||
|
|
|
@ -1341,7 +1341,7 @@ void StatusPanel::update(MachineObject *obj)
|
|||
m_timelapse_button->Hide();
|
||||
}
|
||||
|
||||
if (obj->is_function_supported(PrinterFunction::FUNC_RECORDING)) {
|
||||
if (obj->is_function_supported(PrinterFunction::FUNC_RECORDING) || obj->has_ipcam) {
|
||||
m_recording_button->Show();
|
||||
} else {
|
||||
m_recording_button->Hide();
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue