ENH: update filament color file; the color name may be empty; using set instead of unordered_set

jira: [STUDIO-12346]
Change-Id: If83835fea7108babd2b19c26394ad0429493f394
(cherry picked from commit 85b07c170cd0e30f75dfab8ef68b02b0468c9f92)
This commit is contained in:
xin.zhang 2025-06-30 17:55:49 +08:00 committed by Noisyfox
parent bf3875e4c9
commit 2be0569e3d
3 changed files with 37 additions and 1841 deletions

File diff suppressed because it is too large Load diff

View file

@ -141,10 +141,7 @@ wxString FilamentColorCode::GetFilaColorName() const
const wxString& strLanguage = Slic3r::GUI::wxGetApp().app_config->get("language");
const wxString& lang_code = strLanguage.BeforeFirst('_');
auto it = m_fila_color_names.find(lang_code);
if (it != m_fila_color_names.end())
{
return it->second;
}
if (it != m_fila_color_names.end() && !it->second.empty()) { return it->second; }
it = m_fila_color_names.find("en");// retry with English as fallback
return (it != m_fila_color_names.end()) ? it->second : "Unknown";
@ -156,18 +153,6 @@ FilamentColorCode::FilamentColorCode(const wxString& color_code, FilamentColorCo
m_fila_color(std::move(color)),
m_fila_color_names(std::move(name_map))
{
if (m_owner)
{
m_owner->AddColorCode(this);
}
}
FilamentColorCode::~FilamentColorCode()
{
if (m_owner)
{
m_owner->RemoveColorCode(this);
}
}
void FilamentColorCode::Debug(const char* prefix)
@ -187,11 +172,9 @@ FilamentColorCodes::FilamentColorCodes(const wxString& fila_id, const wxString&
FilamentColorCodes::~FilamentColorCodes()
{
while (!m_fila_colors_map->empty()) // Ensure all color codes are removed before deleting the map
{
delete m_fila_colors_map->begin()->second; // Delete the first color code
}
for (auto iter : *m_fila_colors_map) { delete iter.second; }
m_fila_colors_map->clear();
delete m_fila_colors_map;
}
@ -206,11 +189,6 @@ void FilamentColorCodes::AddColorCode(FilamentColorCode* code)
m_fila_colors_map->emplace(code->GetFilaColor(), code);
}
void FilamentColorCodes::RemoveColorCode(FilamentColorCode* code)
{
m_fila_colors_map->erase(code->GetFilaColor());
}
void FilamentColorCodes::Debug(const char* prefix)
{
BOOST_LOG_TRIVIAL(debug) << prefix << "Fila ID: " << m_fila_id << ", Type: " << m_fila_type;

View file

@ -20,17 +20,6 @@ class FilamentColorCode;
class FilamentColorCodes;
class FilamentColorCodeQuery;
// Hasher
struct FilamentColorHasher
{
std::size_t operator()(const wxColour& c) const noexcept {
return (static_cast<std::size_t>(c.Red()) << 24) ^
(static_cast<std::size_t>(c.Green()) << 16) ^
(static_cast<std::size_t>(c.Blue()) << 8) ^
(static_cast<std::size_t>(c.Alpha()));
}
};
// Represents a color in HSV format
struct ColourHSV
{
@ -66,6 +55,19 @@ inline ColourHSV wxColourToHSV(const wxColour& c)
return { h, s, v };
}
// FilamentColorSorter
struct wxColorSorter
{
std::size_t operator()(const wxColour& lhs_it, const wxColour& rhs_it) const noexcept {
ColourHSV ha = wxColourToHSV(lhs_it);
ColourHSV hb = wxColourToHSV(rhs_it);
if (ha.h != hb.h) return ha.h < hb.h;
if (ha.s != hb.s) return ha.s < hb.s;
if (ha.v != hb.v) return ha.v < hb.v;
return false;
}
};
struct FilamentColor
{
enum class ColorType : char
@ -76,7 +78,7 @@ struct FilamentColor
};
ColorType m_color_type = ColorType::SINGLE_CLR; // default to single color
std::unordered_set<wxColour, FilamentColorHasher> m_colors;
std::set<wxColour, wxColorSorter> m_colors;
public:
size_t ColorCount() const noexcept { return m_colors.size(); }
@ -182,7 +184,6 @@ public:
public:
void AddColorCode(FilamentColorCode* code);
void RemoveColorCode(FilamentColorCode* code);
private:
wxString m_fila_id;//eg. 54600
@ -196,7 +197,7 @@ class FilamentColorCode
public:
FilamentColorCode() = delete;
FilamentColorCode(const wxString& color_code, FilamentColorCodes* owner, FilamentColor&& color, std::unordered_map<wxString, wxString>&& name_map);
~FilamentColorCode();
~FilamentColorCode() {};
public:
wxString GetFilaCode() const { return m_owner->GetFilaCode(); }