mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-22 00:01:09 -06:00 
			
		
		
		
	Merge branch 'master-remote' into feature/1.5
Signed-off-by: SoftFever <softfeverever@gmail.com> # Conflicts: # bbl/i18n/BambuStudio.pot # bbl/i18n/de/BambuStudio_de.po # bbl/i18n/en/BambuStudio_en.po # bbl/i18n/es/BambuStudio_es.po # bbl/i18n/fr/BambuStudio_fr.po # bbl/i18n/hu/BambuStudio_hu.po # bbl/i18n/it/BambuStudio_it.po # bbl/i18n/nl/BambuStudio_nl.po # bbl/i18n/sv/BambuStudio_sv.po # bbl/i18n/zh_cn/BambuStudio_zh_CN.po # deps/Boost/Boost.cmake # deps/wxWidgets/wxWidgets.cmake # resources/config.json # resources/i18n/de/BambuStudio.mo # resources/i18n/en/BambuStudio.mo # resources/i18n/es/BambuStudio.mo # resources/i18n/fr/BambuStudio.mo # resources/i18n/hu/BambuStudio.mo # resources/i18n/it/BambuStudio.mo # resources/i18n/nl/BambuStudio.mo # resources/i18n/sv/BambuStudio.mo # resources/i18n/zh_cn/BambuStudio.mo # resources/images/tips_arrow.svg # resources/profiles/Anycubic.json # resources/profiles/Anycubic/filament/Anycubic Generic ABS.json # resources/profiles/Anycubic/filament/Anycubic Generic ASA.json # resources/profiles/Anycubic/filament/Anycubic Generic PA-CF.json # resources/profiles/Anycubic/filament/Anycubic Generic PA.json # resources/profiles/Anycubic/filament/Anycubic Generic PC.json # resources/profiles/Anycubic/filament/Anycubic Generic PETG.json # resources/profiles/Anycubic/filament/Anycubic Generic PLA-CF.json # resources/profiles/Anycubic/filament/Anycubic Generic PLA.json # resources/profiles/Anycubic/filament/Anycubic Generic PVA.json # resources/profiles/Anycubic/filament/Anycubic Generic TPU.json # resources/profiles/Anycubic/filament/fdm_filament_common.json # resources/profiles/Anycubic/machine/Anycubic 4Max Pro 0.4 nozzle.json # resources/profiles/Anycubic/machine/Anycubic 4Max Pro.json # resources/profiles/Anycubic/process/0.20mm Standard @4MaxPro.json # resources/profiles/Anycubic/process/fdm_process_common.json # resources/profiles/BBL.json # resources/profiles/BBL/machine/Bambu Lab P1P 0.2 nozzle.json # resources/profiles/BBL/machine/Bambu Lab P1P 0.4 nozzle.json # resources/profiles/BBL/machine/Bambu Lab P1P 0.6 nozzle.json # resources/profiles/BBL/machine/Bambu Lab P1P 0.8 nozzle.json # resources/profiles/BBL/machine/Bambu Lab X1 0.2 nozzle.json # resources/profiles/BBL/machine/Bambu Lab X1 0.4 nozzle.json # resources/profiles/BBL/machine/Bambu Lab X1 0.6 nozzle.json # resources/profiles/BBL/machine/Bambu Lab X1 0.8 nozzle.json # resources/profiles/BBL/machine/Bambu Lab X1 Carbon 0.2 nozzle.json # resources/profiles/BBL/machine/Bambu Lab X1 Carbon 0.4 nozzle.json # resources/profiles/BBL/machine/Bambu Lab X1 Carbon 0.6 nozzle.json # resources/profiles/BBL/machine/Bambu Lab X1 Carbon 0.8 nozzle.json # resources/profiles/BBL/machine/fdm_bbl_3dp_001_common.json # resources/profiles/Voron.json # resources/web/data/text.js # resources/web/image/printer/Anycubic 4Max Pro_cover.png # src/BambuStudio.cpp # src/libslic3r/GCode.cpp # src/libslic3r/GCode.hpp # src/libslic3r/GCode/GCodeProcessor.cpp # src/libslic3r/GCodeWriter.hpp # src/libslic3r/PerimeterGenerator.cpp # src/libslic3r/PresetBundle.cpp # src/libslic3r/Print.cpp # src/libslic3r/Print.hpp # src/libslic3r/PrintConfig.cpp # src/libslic3r/PrintConfig.hpp # src/libslic3r/PrintObject.cpp # src/slic3r/GUI/AMSMaterialsSetting.cpp # src/slic3r/GUI/AMSMaterialsSetting.hpp # src/slic3r/GUI/AmsMappingPopup.cpp # src/slic3r/GUI/AmsMappingPopup.hpp # src/slic3r/GUI/Auxiliary.cpp # src/slic3r/GUI/BackgroundSlicingProcess.cpp # src/slic3r/GUI/ConfigManipulation.cpp # src/slic3r/GUI/DeviceManager.cpp # src/slic3r/GUI/DeviceManager.hpp # src/slic3r/GUI/ExtrusionCalibration.cpp # src/slic3r/GUI/GCodeViewer.cpp # src/slic3r/GUI/GCodeViewer.hpp # src/slic3r/GUI/GUI_App.cpp # src/slic3r/GUI/IMSlider.cpp # src/slic3r/GUI/Jobs/PrintJob.cpp # src/slic3r/GUI/Jobs/PrintJob.hpp # src/slic3r/GUI/Jobs/SendJob.cpp # src/slic3r/GUI/Jobs/SendJob.hpp # src/slic3r/GUI/MainFrame.cpp # src/slic3r/GUI/MainFrame.hpp # src/slic3r/GUI/MediaPlayCtrl.cpp # src/slic3r/GUI/OptionsGroup.cpp # src/slic3r/GUI/PhysicalPrinterDialog.cpp # src/slic3r/GUI/Plater.cpp # src/slic3r/GUI/PrintHostDialogs.cpp # src/slic3r/GUI/Printer/BambuTunnel.h # src/slic3r/GUI/Printer/PrinterFileSystem.cpp # src/slic3r/GUI/Printer/gstbambusrc.c # src/slic3r/GUI/Printer/gstbambusrc.h # src/slic3r/GUI/ReleaseNote.cpp # src/slic3r/GUI/ReleaseNote.hpp # src/slic3r/GUI/SelectMachine.cpp # src/slic3r/GUI/SendToPrinter.cpp # src/slic3r/GUI/SetBedTypeDialog.cpp # src/slic3r/GUI/StatusPanel.cpp # src/slic3r/GUI/StatusPanel.hpp # src/slic3r/GUI/Tab.cpp # src/slic3r/GUI/Widgets/AMSControl.cpp # src/slic3r/GUI/Widgets/AMSControl.hpp # src/slic3r/GUI/Widgets/ImageSwitchButton.cpp # src/slic3r/GUI/Widgets/Label.cpp # src/slic3r/GUI/WipeTowerDialog.cpp # src/slic3r/Utils/Process.cpp # src/slic3r/Utils/bambu_networking.hpp # version.inc
This commit is contained in:
		
						commit
						5ef51f6c8a
					
				
					 339 changed files with 37169 additions and 5445 deletions
				
			
		|  | @ -82,6 +82,8 @@ static const std::map<const wchar_t, std::string> font_icons = { | |||
|     {ImGui::GapFillDarkIcon            , "gap_fill_dark"                      }, | ||||
|     {ImGui::SphereButtonDarkIcon       , "toolbar_modifier_sphere_dark"       }, | ||||
| 
 | ||||
|     {ImGui::TextSearchIcon             , "im_text_search"             }, | ||||
|     {ImGui::TextSearchCloseIcon        , "im_text_search_close"       }, | ||||
| }; | ||||
| static const std::map<const wchar_t, std::string> font_icons_large = { | ||||
|     {ImGui::CloseNotifButton        , "notification_close"              }, | ||||
|  | @ -542,6 +544,123 @@ void ImGuiWrapper::set_next_window_size(float x, float y, ImGuiCond cond) | |||
| } | ||||
| 
 | ||||
| /* BBL style widgets */ | ||||
| bool ImGuiWrapper::bbl_combo_with_filter(const char* label, const std::string& preview_value, const std::vector<std::string>& all_items, std::vector<int>* filtered_items_idx, bool* is_filtered, float item_height) | ||||
| { | ||||
|     ImGuiContext& g = *GImGui; | ||||
|     const ImGuiStyle& style = g.Style; | ||||
|     ImGuiWindow* window = ImGui::GetCurrentWindow(); | ||||
|     if (window->SkipItems) | ||||
|         return false; | ||||
| 
 | ||||
|     static char pattern_buffer[256] = { 0 }; | ||||
|     auto simple_match = [](const char* pattern, const char* str) { | ||||
|         wxString sub_str = wxString(pattern).Lower(); | ||||
|         wxString main_str = wxString(str).Lower(); | ||||
|         return main_str.Find(sub_str); | ||||
|     }; | ||||
| 
 | ||||
|     bool is_filtering = false; | ||||
|     bool is_new_open = false; | ||||
| 
 | ||||
|     float sz = ImGui::GetFrameHeight(); | ||||
|     ImVec2 arrow_size(sz, sz); | ||||
|     ImVec2 CursorPos = window->DC.CursorPos; | ||||
|     const ImRect arrow_bb(CursorPos, CursorPos + arrow_size); | ||||
| 
 | ||||
|     float ButtonTextAlignX = g.Style.ButtonTextAlign.x; | ||||
|     g.Style.ButtonTextAlign.x = 0; | ||||
|     ImGui::PushStyleVar(ImGuiStyleVar_FramePadding, { sz, style.FramePadding.y}); | ||||
|     ImGui::PushStyleColor(ImGuiCol_ButtonActive, ImGui::GetStyleColorVec4(ImGuiCol_ButtonHovered)); | ||||
|     if (button(preview_value + label, ImGui::CalcItemWidth(), 0)) | ||||
|     { | ||||
|         ImGui::OpenPopup(label); | ||||
|         is_new_open = true; | ||||
|     } | ||||
|     g.Style.ButtonTextAlign.x = ButtonTextAlignX; | ||||
|     ImGui::PopStyleVar(); | ||||
|     ImGui::PopStyleColor(); | ||||
|     ImGui::BBLRenderArrow(window->DrawList, arrow_bb.Min + ImVec2(ImMax(0.0f, (arrow_size.x - g.FontSize) * 0.5f), ImMax(0.0f, (arrow_size.y - g.FontSize) * 0.5f)), ImGui::GetColorU32(ImGuiCol_Text), ImGuiDir_Down); | ||||
| 
 | ||||
|     if (is_new_open) | ||||
|         memset(pattern_buffer, 0, IM_ARRAYSIZE(pattern_buffer)); | ||||
| 
 | ||||
|     float item_rect_width = ImGui::GetItemRectSize().x; | ||||
|     float item_rect_height = item_height ? item_height : ImGui::GetItemRectSize().y; | ||||
|     ImGui::SetNextWindowPos({ CursorPos.x, ImGui::GetItemRectMax().y + 4 * m_style_scaling }); | ||||
|     ImGui::SetNextWindowSize({ item_rect_width, 0 }); | ||||
|     if (ImGui::BeginPopup(label)) | ||||
|     { | ||||
|         ImGuiWindow* popup_window = ImGui::GetCurrentWindow(); | ||||
| 
 | ||||
|         ImGui::PushStyleVar(ImGuiStyleVar_ItemSpacing, ImVec2(0, 0)); | ||||
| 
 | ||||
|         ImGui::PushStyleVar(ImGuiStyleVar_FramePadding, ImVec2(8.0f * m_style_scaling, item_rect_height - g.FontSize) * 0.5f); | ||||
|         wchar_t ICON_SEARCH = *pattern_buffer != '\0' ? ImGui::TextSearchCloseIcon : ImGui::TextSearchIcon; | ||||
|         const ImVec2 label_size = ImGui::CalcTextSize(into_u8(ICON_SEARCH).c_str(), nullptr, true); | ||||
|         const ImVec2 search_icon_pos(ImGui::GetItemRectMax().x - label_size.x, popup_window->DC.CursorPos.y + style.FramePadding.y); | ||||
|         ImGui::RenderText(search_icon_pos, into_u8(ICON_SEARCH).c_str()); | ||||
| 
 | ||||
|         auto temp = popup_window->DC.CursorPos; | ||||
|         popup_window->DC.CursorPos = search_icon_pos; | ||||
|         ImGui::PushStyleColor(ImGuiCol_Button, {0, 0, 0, 0}); | ||||
|         ImGui::PushStyleColor(ImGuiCol_ButtonActive, ImGui::GetStyleColorVec4(ImGuiCol_Button)); | ||||
|         ImGui::PushStyleColor(ImGuiCol_ButtonHovered, ImGui::GetStyleColorVec4(ImGuiCol_Button)); | ||||
|         ImGui::PushStyleColor(ImGuiCol_ButtonHovered, ImGui::GetStyleColorVec4(ImGuiCol_Button)); | ||||
|         ImGui::PushStyleColor(ImGuiCol_Border, { 0, 0, 0, 0 }); | ||||
|         if (button("##invisible_clear_button", label_size.x, label_size.y)) | ||||
|         { | ||||
|             if (*pattern_buffer != '\0') | ||||
|                 memset(pattern_buffer, 0, IM_ARRAYSIZE(pattern_buffer)); | ||||
|         } | ||||
|         ImGui::PopStyleColor(5); | ||||
|         popup_window->DC.CursorPos = temp; | ||||
| 
 | ||||
| 
 | ||||
|         ImGui::PushItemWidth(item_rect_width); | ||||
|         if (is_new_open) | ||||
|             ImGui::SetKeyboardFocusHere(); | ||||
|         ImGui::InputText("##bbl_combo_with_filter_inputText", pattern_buffer, sizeof(pattern_buffer)); | ||||
|         ImGui::PopItemWidth(); | ||||
|         ImGui::PopStyleVar(); | ||||
| 
 | ||||
|         if (*pattern_buffer != '\0') | ||||
|             is_filtering = true; | ||||
| 
 | ||||
|         if (is_filtering) | ||||
|         { | ||||
|             std::vector<std::pair<int, int> > filtered_items_with_priority;// std::pair<index, priority>
 | ||||
|             for (int i = 0; i < all_items.size(); i++) | ||||
|             { | ||||
|                 int priority = simple_match(pattern_buffer, all_items[i].c_str()); | ||||
|                 if (priority != wxNOT_FOUND) | ||||
|                     filtered_items_with_priority.push_back({ i, priority }); | ||||
|             } | ||||
|             std::sort(filtered_items_with_priority.begin(), filtered_items_with_priority.end(), [](const std::pair<int, int>& a, const std::pair<int, int>& b) {return (b.second > a.second); }); | ||||
|             for (auto item : filtered_items_with_priority) | ||||
|             { | ||||
|                 filtered_items_idx->push_back(item.first); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         *is_filtered = is_filtering; | ||||
| 
 | ||||
|         popup_window->DC.CursorPos.y -= 1 * m_style_scaling; | ||||
|         ImGui::PushStyleVar(ImGuiStyleVar_FramePadding, ImVec2(1.0f, 1.0f) * m_style_scaling); | ||||
|         if (ImGui::BeginListBox("##bbl_combo_with_filter_listBox", { item_rect_width, item_rect_height * 7.75f})) { | ||||
|             ImGui::PopStyleVar(2); | ||||
|             return true; | ||||
|         } | ||||
|         else | ||||
|         { | ||||
|             ImGui::PopStyleVar(2); | ||||
|             ImGui::EndPopup(); | ||||
|             return false; | ||||
|         } | ||||
|     } | ||||
|     else | ||||
|         return false; | ||||
| } | ||||
| 
 | ||||
| bool ImGuiWrapper::bbl_input_double(const wxString& label, const double& value, const std::string& format) | ||||
| { | ||||
|     //return ImGui::InputDouble(label.c_str(), const_cast<double *>(&value), 0.0f, 0.0f, format.c_str(), ImGuiInputTextFlags_CharsDecimal);
 | ||||
|  | @ -1636,7 +1755,7 @@ static const ImWchar ranges_keyboard_shortcuts[] = | |||
| #endif // __APPLE__
 | ||||
| 
 | ||||
| 
 | ||||
| std::vector<unsigned char> ImGuiWrapper::load_svg(const std::string& bitmap_name, unsigned target_width, unsigned target_height) | ||||
| std::vector<unsigned char> ImGuiWrapper::load_svg(const std::string& bitmap_name, unsigned target_width, unsigned target_height, unsigned *outwidth, unsigned *outheight) | ||||
| { | ||||
|     std::vector<unsigned char> empty_vector; | ||||
| 
 | ||||
|  | @ -1667,6 +1786,9 @@ std::vector<unsigned char> ImGuiWrapper::load_svg(const std::string& bitmap_name | |||
|     ::nsvgDeleteRasterizer(rast); | ||||
|     ::nsvgDelete(image); | ||||
| 
 | ||||
|     *outwidth = width; | ||||
|     *outheight = height; | ||||
| 
 | ||||
|     return data; | ||||
| } | ||||
| 
 | ||||
|  | @ -1951,11 +2073,12 @@ void ImGuiWrapper::init_font(bool compress) | |||
|         if (const ImFontAtlas::CustomRect* rect = io.Fonts->GetCustomRectByIndex(rect_id)) { | ||||
|             assert(rect->Width == icon_sz); | ||||
|             assert(rect->Height == icon_sz); | ||||
|             std::vector<unsigned char> raw_data = load_svg(icon.second, icon_sz, icon_sz); | ||||
|             unsigned outwidth, outheight; | ||||
|             std::vector<unsigned char> raw_data = load_svg(icon.second, icon_sz, icon_sz, &outwidth, &outheight); | ||||
|             const ImU32* pIn = (ImU32*)raw_data.data(); | ||||
|             for (int y = 0; y < icon_sz; y++) { | ||||
|             for (unsigned y = 0; y < outheight; y++) { | ||||
|                 ImU32* pOut = (ImU32*)pixels + (rect->Y + y) * width + (rect->X); | ||||
|                 for (int x = 0; x < icon_sz; x++) | ||||
|                 for (unsigned x = 0; x < outwidth; x++) | ||||
|                     *pOut++ = *pIn++; | ||||
|             } | ||||
|         } | ||||
|  | @ -1967,11 +2090,12 @@ void ImGuiWrapper::init_font(bool compress) | |||
|         if (const ImFontAtlas::CustomRect* rect = io.Fonts->GetCustomRectByIndex(rect_id)) { | ||||
|             assert(rect->Width == icon_sz); | ||||
|             assert(rect->Height == icon_sz); | ||||
|             std::vector<unsigned char> raw_data = load_svg(icon.second, icon_sz, icon_sz); | ||||
|             unsigned outwidth, outheight; | ||||
|             std::vector<unsigned char> raw_data = load_svg(icon.second, icon_sz, icon_sz, &outwidth, &outheight); | ||||
|             const ImU32* pIn = (ImU32*)raw_data.data(); | ||||
|             for (int y = 0; y < icon_sz; y++) { | ||||
|             for (unsigned y = 0; y < outheight; y++) { | ||||
|                 ImU32* pOut = (ImU32*)pixels + (rect->Y + y) * width + (rect->X); | ||||
|                 for (int x = 0; x < icon_sz; x++) | ||||
|                 for (unsigned x = 0; x < outwidth; x++) | ||||
|                     *pOut++ = *pIn++; | ||||
|             } | ||||
|         } | ||||
|  | @ -1983,11 +2107,12 @@ void ImGuiWrapper::init_font(bool compress) | |||
|         if (const ImFontAtlas::CustomRect* rect = io.Fonts->GetCustomRectByIndex(rect_id)) { | ||||
|             assert(rect->Width == icon_sz); | ||||
|             assert(rect->Height == icon_sz); | ||||
|             std::vector<unsigned char> raw_data = load_svg(icon.second, icon_sz, icon_sz); | ||||
|             unsigned outwidth, outheight; | ||||
|             std::vector<unsigned char> raw_data = load_svg(icon.second, icon_sz, icon_sz, &outwidth, &outheight); | ||||
|             const ImU32* pIn = (ImU32*)raw_data.data(); | ||||
|             for (int y = 0; y < icon_sz; y++) { | ||||
|             for (unsigned y = 0; y < outheight; y++) { | ||||
|                 ImU32* pOut = (ImU32*)pixels + (rect->Y + y) * width + (rect->X); | ||||
|                 for (int x = 0; x < icon_sz; x++) | ||||
|                 for (unsigned x = 0; x < outwidth; x++) | ||||
|                     *pOut++ = *pIn++; | ||||
|             } | ||||
|         } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 SoftFever
						SoftFever