#ifndef FILAMENT_GROUP_UTILS_HPP #define FILAMENT_GROUP_UTILS_HPP #include #include #include #include #include "PrintConfig.hpp" namespace Slic3r { namespace FilamentGroupUtils { struct Color { unsigned char r = 0; unsigned char g = 0; unsigned char b = 0; unsigned char a = 255; Color(unsigned char r_ = 0, unsigned char g_ = 0, unsigned char b_ = 0, unsigned a_ = 255) :r(r_), g(g_), b(b_), a(a_) {} Color(const std::string& hexstr); bool operator<(const Color& other) const; bool operator==(const Color& other) const; bool operator!=(const Color& other) const; std::string to_hex_str(bool include_alpha = false) const; }; struct FilamentInfo { Color color; std::string type; bool is_support; }; struct MachineFilamentInfo: public FilamentInfo { int extruder_id; bool is_extended; bool operator<(const MachineFilamentInfo& other) const; }; class FilamentGroupException: public std::exception { public: enum ErrorCode { EmptyAmsFilaments, ConflictLimits, Unknown }; private: ErrorCode code_; std::string message_; public: FilamentGroupException(ErrorCode code, const std::string& message) : code_(code), message_(message) {} ErrorCode code() const noexcept { return code_; } const char* what() const noexcept override { return message_.c_str(); } }; std::vector calc_max_group_size(const std::vector>& ams_counts,bool ignore_ext_filament); std::vector> build_machine_filaments(const std::vector>& filament_configs, const std::vector>& ams_counts, bool ignore_ext_filament); bool collect_unprintable_limits(const std::vector>& physical_unprintables, const std::vector>& geometric_unprintables, std::vector>& unprintable_limits); bool remove_intersection(std::set& a, std::set& b); void extract_indices(const std::vector& used_filaments, const std::vector>& unprintable_elems, std::vector>& unprintable_idxs); void extract_unprintable_limit_indices(const std::vector>& unprintable_elems, const std::vector& used_filaments, std::map& unplaceable_limits); void extract_unprintable_limit_indices(const std::vector>& unprintable_elems, const std::vector& used_filaments, std::unordered_map>& unplaceable_limits); bool check_printable(const std::vector>& groups, const std::map& unprintable); } } #endif