Also search vendor directory for printer profile resources.
Search the vendor directory using the same conventions used to search the profiles directory when looking for thumbnails, bed_models, and bed_textures. Allows a complete, "Config Wizard"-friendly custom vendor profile to be placed in the (user's configuration) vendor directory.
This commit is contained in:
parent
4f622e4541
commit
e9423ab86d
@ -338,8 +338,11 @@ static std::string system_print_bed_model(const Preset &preset)
|
|||||||
{
|
{
|
||||||
std::string out;
|
std::string out;
|
||||||
const VendorProfile::PrinterModel *pm = PresetUtils::system_printer_model(preset);
|
const VendorProfile::PrinterModel *pm = PresetUtils::system_printer_model(preset);
|
||||||
if (pm != nullptr && ! pm->bed_model.empty())
|
if (pm != nullptr && ! pm->bed_model.empty()) {
|
||||||
|
out = Slic3r::data_dir() + "/vendor/" + preset.vendor->id + "/" + pm->bed_model;
|
||||||
|
if (! boost::filesystem::exists(boost::filesystem::path(out)))
|
||||||
out = Slic3r::resources_dir() + "/profiles/" + preset.vendor->id + "/" + pm->bed_model;
|
out = Slic3r::resources_dir() + "/profiles/" + preset.vendor->id + "/" + pm->bed_model;
|
||||||
|
}
|
||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -347,8 +350,11 @@ static std::string system_print_bed_texture(const Preset &preset)
|
|||||||
{
|
{
|
||||||
std::string out;
|
std::string out;
|
||||||
const VendorProfile::PrinterModel *pm = PresetUtils::system_printer_model(preset);
|
const VendorProfile::PrinterModel *pm = PresetUtils::system_printer_model(preset);
|
||||||
if (pm != nullptr && ! pm->bed_texture.empty())
|
if (pm != nullptr && ! pm->bed_texture.empty()) {
|
||||||
|
out = Slic3r::data_dir() + "/vendor/" + preset.vendor->id + "/" + pm->bed_texture;
|
||||||
|
if (! boost::filesystem::exists(boost::filesystem::path(out)))
|
||||||
out = Slic3r::resources_dir() + "/profiles/" + preset.vendor->id + "/" + pm->bed_texture;
|
out = Slic3r::resources_dir() + "/profiles/" + preset.vendor->id + "/" + pm->bed_texture;
|
||||||
|
}
|
||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -188,6 +188,11 @@ PrinterPicker::PrinterPicker(wxWindow *parent, const VendorProfile &vendor, wxSt
|
|||||||
|
|
||||||
wxBitmap bitmap;
|
wxBitmap bitmap;
|
||||||
int bitmap_width = 0;
|
int bitmap_width = 0;
|
||||||
|
const wxString bitmap_file = GUI::from_u8(Slic3r::data_dir() + "/vendor/" + vendor.id + "/" + model.id + "_thumbnail.png");
|
||||||
|
if (wxFileExists(bitmap_file)) {
|
||||||
|
bitmap.LoadFile(bitmap_file, wxBITMAP_TYPE_PNG);
|
||||||
|
bitmap_width = bitmap.GetWidth();
|
||||||
|
} else {
|
||||||
const wxString bitmap_file = GUI::from_u8(Slic3r::resources_dir() + "/profiles/" + vendor.id + "/" + model.id + "_thumbnail.png");
|
const wxString bitmap_file = GUI::from_u8(Slic3r::resources_dir() + "/profiles/" + vendor.id + "/" + model.id + "_thumbnail.png");
|
||||||
if (wxFileExists(bitmap_file)) {
|
if (wxFileExists(bitmap_file)) {
|
||||||
bitmap.LoadFile(bitmap_file, wxBITMAP_TYPE_PNG);
|
bitmap.LoadFile(bitmap_file, wxBITMAP_TYPE_PNG);
|
||||||
@ -204,6 +209,7 @@ PrinterPicker::PrinterPicker(wxWindow *parent, const VendorProfile &vendor, wxSt
|
|||||||
bitmap_width = bitmap.GetWidth();
|
bitmap_width = bitmap.GetWidth();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
auto *title = new wxStaticText(this, wxID_ANY, model.name, wxDefaultPosition, wxDefaultSize, wxALIGN_LEFT);
|
auto *title = new wxStaticText(this, wxID_ANY, model.name, wxDefaultPosition, wxDefaultSize, wxALIGN_LEFT);
|
||||||
title->SetFont(font_name);
|
title->SetFont(font_name);
|
||||||
|
Loading…
Reference in New Issue
Block a user