* FIX: linux: fix the building issue on Linux Mint 21.3 Virginia github: https://github.com/bambulab/BambuStudio/issues/3874 author: https://github.com/lucianoloder Change-Id: Ia3db6923d5dd68dba532d7bdba6f93f73cc51d59 * FIX: auto-arranging incorrect with rotation enabled auto-arranging incorrect with rotation enabled and the objects already have been rotated. jira: STUDIO-6022 Change-Id: I349d663efb1fc71367c8a77aa8ed5047a0bf2017 (cherry picked from commit 75fe40257a274ed83886e1ee20ce8dedd0de48f6) * ENH: update X1C & X1E start gcode 1.Fix fan problem jira:NEW Signed-off-by: xun.zhang <xun.zhang@bambulab.com> Change-Id: I68ee5be78e142e8a2a210a1a70f5663893390610 * ENH: update A series gcode 1. Update A1 series start gcode and change filament gcode 2. Add G2814 command 3. Add multi-filament extrusion compensation and vibration suppression jira:NEW Signed-off-by: xun.zhang <xun.zhang@bambulab.com> Change-Id: I57d2bc8e98d3e547881dc1369c1fb31413c6205d * FIX: fix some cali problem of P series jira: none Change-Id: Id57ea8d65da22ab653cca49509cb923ff065e43f * FIX: fix can't enter ',' in multiplicator github: #3805 Change-Id: I6dd70822d1c2e79d66c70514d6dd580ab029c7ea * calib wizard * NEW: FlipLines infill jira:6701 New infill pattern that combine block lines infill and switching layers for smooth transition. Change-Id: I2608a2d39b14efcdfe9d39a9437280da350b94c0 (cherry picked from commit 8d0a09c8b763dfc924cbba9913c241e6afadbc7f) * ENH: add nozzle blob detection and air printing detection jira: new Change-Id: Ie4a19a7ad7d0b10a021c516cbc3a84b4ae734302 * FIX: Top surface bridging fail on 3DHC & FL infill Add 45 degree angle offset when processing the bridge. Need to raise infill_direction to invalidate posPrepareInfill jira: 6774 Change-Id: I5e6bef3aa814b01c5f30398ac745937a67e3ef4c (cherry picked from commit 7b12cab10b88f432a11414f8caa1c6427777a1ba) * FIX: the error display when reset virtual slot jira: none Change-Id: I5ae5899baf1bfc2aaadb832083b277855a669fd5 * FIX: Error "Voronoi cell doesn't contain a sourcepoint" github: 3859 Change-Id: Idca84992bcba5380bfe05e63ac9a5e40419dcfdf * fix build error * FIX: CLI: fix the crash issue caused by get_min_flush_volumes JIRA: no jira Change-Id: I0d5bfd605e51ebddac8fddc4d83dab5055b0fbf2 * FIX: can't use support filament in gcode.3mf 1. Add total_filament_volumes, directly access it to get used filaments github:#3865 Signed-off-by: xun.zhang <xun.zhang@bambulab.com> Change-Id: I4fae4f1947b4ebd16e394e0f3cf5fb0e9f979717 * ENH: p series support long retraction 1. P series support long retraction in filament 2. Add long retraction params in common.json jira:NEW Signed-off-by: xun.zhang <xun.zhang@bambulab.com> Change-Id: Ib94184fa1f0b5ab151360f1f053d8c8ff92e7e18 * ENH::modify some logs level jira:[for log] Change-Id: I6a46b8fcd3a030b4b630e800fe9a9ac5c387f117 * NEW: support multi device JIRA: STUDIO-6072 Change-Id: Ic514c4097767b0a728368c9ea48ee103c031fbb0 Signed-off-by: Stone Li <stone.li@bambulab.com> * ENH: update A1 series gcode 1.Update filament change gcode and machine start gcode for A1 and A1 mini jira:NEW Signed-off-by: xun.zhang <xun.zhang@bambulab.com> Change-Id: I2f3be3fd89fef21e717a32f2b89985fc046f7f6e * FIX: always have 0th filament in ams mapping 1. Only set the filament id in map when flush length is not 0 jira:NEW Signed-off-by: xun.zhang <xun.zhang@bambulab.com> Change-Id: I6e0aeaf010f6e6dcbdc3bca5c0034aa60750bb67 * ENH: add filament id in slice info jira:NEW Signed-off-by: xun.zhang <xun.zhang@bambulab.com> Change-Id: Ic5fe4632bca8acacc9ffd072ee2ed207c1da37aa * ENH: refine ui for multi machine JIRA: STUDIO-6819 STUDIO-6824 1. Shrink the Send Print dialog box 2. add input box for flipping panel Change-Id: I4174c79ecd239c374ee11478951e12be399c57ce * FIX: fix Issues with sending multiple devices JIRA: STUDIO-6876 Signed-off-by: Kunlong Ma <kunlong.ma@bambulab.com> Change-Id: I33c6a932863fc715c3f0eb5dfd4b299f980a4918 * NEW: support hms error code Change-Id: Ic256a83cf501fb05bb9d3203f3d24cb1d1290fa4 * FIX:fixed some multi job issue Change-Id: I338078ad8fcf809888db9d8daeb470a9bf4eab46 * NEW:support pin code binding Change-Id: Ida5d47881fbd83f3ffedc80369cfe377114d7f13 * ENH:add printable check for devices Change-Id: I672988fa9cfa986d924bfc64331752f4aef68067 (cherry picked from commit 69de9e5b8334ec94eec7fcee31038b8ff42d1d3b) * FIX: add more fonts jira: none Change-Id: I6bafed3563083858f29e92a3d84906a2e53dcb5c (cherry picked from commit afbea693e807dcc1c406a59aa5376b9ea2a5d606) * ENH: load more fonts this feature is according to Prusa by Filip Sykala<filip.sykala@prusa3d.cz>, thanks to Filip Sykala jira: none Change-Id: I55e92f184f750c0b93b679d4382aaa5b164ec5c3 (cherry picked from commit d05522c4cc5d7ee4cac42de398b88d347a55f74b) * ENH: add ProfileDescription for translate 1.Add ProfileDescription.hpp simply for translating jira:NEW Signed-off-by: XunZhangBambu <xun.zhang@bambulab.com> Change-Id: Iaa3ced1edccf67eaeebde35c1e8b36442d2e9a6f * ENH: Improve CrossHatch transation layers jira: 6701 Change name from Flippingline to CrossHatch. Reduce noise, improve speed by 6.5%. Improve transation layers by gradually increasing rotation angle and overshoot the transation layer while direction changed. Change-Id: I17fcc45b409074d121bf5bb5702e15553d925b51 * UP * ENH: modify the default config for multi-device JIRA: STUDIO-6072 Change-Id: If6e7582a8274eb5e685b8b8545f6eab5d17de3f5 Signed-off-by: Stone Li <stone.li@bambulab.com> * ENH: add long retraction for P series jira:NEW Signed-off-by: xun.zhang <xun.zhang@bambulab.com> Change-Id: I6890695b67e674fc5cdc2a208e89bd9e41404213 * FIX: all plates stats data missing issue jira: new Change-Id: I137a2b6d69ad08791f5a9a9788653621960dc63f * ENH:update pre print options jira:[for multi] Change-Id: I2e9bb8a09436a71749af98a0bad94e9922f95c81 * FIX:fixed can't popup pinbind win on macos jira:[STUDIO-6895] Change-Id: I664bba78cf27420d736b586df19e3c09c6f8ed21 * FIX:fixed the task of padding cannot be cancelled Change-Id: I401a22118c14ca7601be7a925cfd8e4796dfc1e9 * ENH:Play video after redirecting to device page jira:[STUDIO-6884] Change-Id: Ia5e2ac84e3d71baacfcf941b782dab2325f35d54 * FIX: fix ui bug in send multi machine page for mac JIRA: STUDIO-6882 Incorrect background color when renaming during multi machine printing Change-Id: I6c551f5023ffe747e7a7e2f5703b0707c9505922 * FIX: Fix some bugs in maintaining the selected status of local tasks JIRA: STUDIO-6824 Change-Id: I12c4da3fc56ac5077b3ccd7e89a4b57c3675eaf5 * ENH: local task sort by send time by default JIRA: STUDIO-6885 Change-Id: I03b5881a39ab2e90c5b9cf46052ba465ee707ccc * FIX: Clicking to continue printing does not take effect in error code JIRA: STUDIO-6830 Detected an incomplete printing task error pop-up when power outage occurred. Clicking to continue printing did not take effect Change-Id: Ie85a1602093dabac861cd1f41ea21e1c312c83e9 * ENH: use designTitle when designId > 0 JIRA: STUDIO-6072 Change-Id: I8342df053edeab16f930522e099e2eef91e5c5a4 Signed-off-by: Stone Li <stone.li@bambulab.com> * NEW:import vertex and mtl color from obj file Jira: STUDIO-6805 Change-Id: Iaacb13ee2451effdb83e5aba4b7fe1637b7fc95f * FIX:change the strategy of merge_ka_kd Upgrade ui, users can directly ok to proceed to the next step jira: STUDIO-6805 Change-Id: Ia81019c2eacb503666680c0b8583d026baa0134c (cherry picked from commit 38a2434753c8e3b422267283b16c75f6ad195b14) * FIX:use default_strategy after modifed cluster number jira: STUDIO-6915 Change-Id: I4e0c3d62f5a766f73d48d1e06c4364fc6babe1ac * FIX: the bug of incorrect button without restarting JIRA: STUDIO-6824 The bug can cause the user to not restart when opening the multi-device option, but the button of send multi-devices appears Change-Id: I0837fa79ecc1d8ab5ce98273ad134fa2f830421e * FIX: wrong default value for long retraction jira:NEW Signed-off-by: xun.zhang <xun.zhang@bambulab.com> Change-Id: Ifc2ec57a320fdb14e7ca746e5795501ed146ff32 * FIX: error code pop-up window without retry button in some code JIRA: STUDIO-6922 Change-Id: I67464bebaba4558618301592c455db8824bbfe30 * FIX: air printing and nozzle blob detection issue jira: STUDIO-6897 Change-Id: I008ddb24b74119d7e4124ae26310b4b86c42a799 * FIX:fix bugs of algo and read quad in obj file Jira: STUDIO-6805 Change-Id: I6c33e8197225f27dccdfa0681e64d76d1df14f61 * dd * ENH:Set the default nozzle diameter to 0.4 jira:[for nozzle] Change-Id: I74a5c9b0460046496b897eae3d9f917ac1b99052 * FIX:fixed backspace error on macos Change-Id: I76066391783c04857c1a60a6f8438111501b6d7c * ENH:Subscription list deduplication jira:[for mulit] Change-Id: I10e9d849986c9661b587c7b1a509180c2451816e * ENH:update wiki url for Pin Code jira:[pin code] Change-Id: I95faaa396a839b5b159119ef235b650c76706a84 * NEW:add OpenCV.cmake in deps jira: none Change-Id: I1ae4a2bd5618e9e620b08a937904d6af5d00bc41 * FIX:cancel obj import restrictions jira: none Change-Id: Iaf3e799ca982ad6aeb3ec76e9a416c4c8e4d100c * NEW:add multiple printer restrictions jira:[for multiple] Change-Id: I0bb5a0c1062a543c42f8d67a9347efa358b0864a * ENH:Added two entrances for adding devices jira:[multi device] Change-Id: Ieb6197e067d422979606f93b22b337a2399aec74 * slic3r: Fix wxFont being undefined [427/494] Building CXX object src/slic3r/CMakeFiles/libslic3r_gui.dir/Utils/FontUtils.cpp.o FAILED: src/slic3r/CMakeFiles/libslic3r_gui.dir/Utils/FontUtils.cpp.o /usr/bin/c++ -DBOOST_ATOMIC_NO_LIB -DBOOST_CHRONO_NO_LIB -DBOOST_DATE_TIME_NO_LIB -DBOOST_FILESYSTEM_NO_LIB -DBOOST_IOSTREAMS_NO_LIB -DBOOST_LOCALE_NO_LIB -DBOOST_LOG_NO_LIB -DBOOST_REGEX_NO_LIB -DBOOST_SYSTEM_NO_LIB -DBOOST_THREAD_NO_LIB -DCURL_STATICLIB -DGLEW_STATIC -DLIBNEST2D_GEOMETRIES_libslic3r -DLIBNEST2D_OPTIMIZER_nlopt -DLIBNEST2D_STATIC -DLIBNEST2D_THREADING_tbb -DOPENSSL_CERT_OVERRIDE -DOPENVDB_OPENEXR_STATICLIB -DOPENVDB_STATICLIB -DSLIC3R_CURRENTLY_COMPILING_GUI_MODULE -DSLIC3R_GUI -DTBB_USE_CAPTURED_EXCEPTION=0 -DUNICODE -DUSE_TBB -DWXINTL_NO_GETTEXT_MACRO -D_UNICODE -D__WXGTK3__ -D__WXGTK__ -DwxDEBUG_LEVEL=0 -DwxNO_UNSAFE_WXSTRING_CONV -DwxUSE_UNICODE -I/usr/include/dbus-1.0 -I/usr/lib/x86_64-linux-gnu/dbus-1.0/include -I/run/build/BambuStudio/src -I/run/build/BambuStudio/build/src/platform -I/run/build/BambuStudio/src/hidapi/include -I/run/build/BambuStudio/src/slic3r/Utils -I/usr/include/gtk-3.0 -I/usr/include/pango-1.0 -I/usr/include/cairo -I/usr/include/gdk-pixbuf-2.0 -I/usr/include/webp -I/usr/include/at-spi2-atk/2.0 -I/usr/include/at-spi-2.0 -I/usr/include/atk-1.0 -I/usr/include/fribidi -I/usr/include/pixman-1 -I/usr/include/harfbuzz -I/usr/include/freetype2 -I/usr/include/libpng16 -I/usr/include/gio-unix-2.0 -I/usr/include/glib-2.0 -I/usr/lib/x86_64-linux-gnu/glib-2.0/include -I/usr/include/libmount -I/usr/include/blkid -I/usr/include/sysprof-6 -I/usr/include/gstreamer-1.0 -I/run/build/BambuStudio/build/src/libslic3r -I/run/build/BambuStudio/deps/build/destdir/usr/local/include/opencascade -I/run/build/BambuStudio/src/libnest2d/include -I/run/build/BambuStudio/src/miniz -I/run/build/BambuStudio/src/glu-libtess/include -I/run/build/BambuStudio/src/clipper2/Clipper2Lib/include -I/run/build/BambuStudio/src/minilzo -isystem /run/build/BambuStudio/src/eigen -isystem /run/build/BambuStudio/src/libigl -isystem /app/lib/wx/include/gtk3-unicode-static-3.1 -isystem /app/include/wx-3.1 -isystem /run/build/BambuStudio/deps/build/destdir/usr/local/include -isystem /run/build/BambuStudio/deps/build/destdir/usr/local/include/opencv4 -isystem /run/build/BambuStudio/deps/build/destdir/usr/local/include/OpenEXR -std=gnu++20 -fext-numeric-literals -Wall -Wno-reorder -pthread -O3 -DNDEBUG -std=gnu++17 -fPIC -fsigned-char -Werror=return-type -Wno-ignored-attributes -Wno-unknown-pragmas -DOPENVDB_ABI_VERSION_NUMBER=8 -MD -MT src/slic3r/CMakeFiles/libslic3r_gui.dir/Utils/FontUtils.cpp.o -MF src/slic3r/CMakeFiles/libslic3r_gui.dir/Utils/FontUtils.cpp.o.d -o src/slic3r/CMakeFiles/libslic3r_gui.dir/Utils/FontUtils.cpp.o -c /run/build/BambuStudio/src/slic3r/Utils/FontUtils.cpp In file included from /run/build/BambuStudio/src/slic3r/Utils/FontUtils.cpp:1: /run/build/BambuStudio/src/slic3r/Utils/FontUtils.hpp:51:21: error: ‘wxFont’ does not name a type 51 | bool can_load(const wxFont &font); | ^~~~~~ * slic3r: Fix missing BOOST_LOG_TRIVIAL declaration [427/494] Building CXX object src/slic3r/CMakeFiles/libslic3r_gui.dir/Utils/FontUtils.cpp.o FAILED: src/slic3r/CMakeFiles/libslic3r_gui.dir/Utils/FontUtils.cpp.o /usr/bin/c++ -DBOOST_ATOMIC_NO_LIB -DBOOST_CHRONO_NO_LIB -DBOOST_DATE_TIME_NO_LIB -DBOOST_FILESYSTEM_NO_LIB -DBOOST_IOSTREAMS_NO_LIB -DBOOST_LOCALE_NO_LIB -DBOOST_LOG_NO_LIB -DBOOST_REGEX_NO_LIB -DBOOST_SYSTEM_NO_LIB -DBOOST_THREAD_NO_LIB -DCURL_STATICLIB -DGLEW_STATIC -DLIBNEST2D_GEOMETRIES_libslic3r -DLIBNEST2D_OPTIMIZER_nlopt -DLIBNEST2D_STATIC -DLIBNEST2D_THREADING_tbb -DOPENSSL_CERT_OVERRIDE -DOPENVDB_OPENEXR_STATICLIB -DOPENVDB_STATICLIB -DSLIC3R_CURRENTLY_COMPILING_GUI_MODULE -DSLIC3R_GUI -DTBB_USE_CAPTURED_EXCEPTION=0 -DUNICODE -DUSE_TBB -DWXINTL_NO_GETTEXT_MACRO -D_UNICODE -D__WXGTK3__ -D__WXGTK__ -DwxDEBUG_LEVEL=0 -DwxNO_UNSAFE_WXSTRING_CONV -DwxUSE_UNICODE -I/usr/include/dbus-1.0 -I/usr/lib/x86_64-linux-gnu/dbus-1.0/include -I/run/build/BambuStudio/src -I/run/build/BambuStudio/build/src/platform -I/run/build/BambuStudio/src/hidapi/include -I/run/build/BambuStudio/src/slic3r/Utils -I/usr/include/gtk-3.0 -I/usr/include/pango-1.0 -I/usr/include/cairo -I/usr/include/gdk-pixbuf-2.0 -I/usr/include/webp -I/usr/include/at-spi2-atk/2.0 -I/usr/include/at-spi-2.0 -I/usr/include/atk-1.0 -I/usr/include/fribidi -I/usr/include/pixman-1 -I/usr/include/harfbuzz -I/usr/include/freetype2 -I/usr/include/libpng16 -I/usr/include/gio-unix-2.0 -I/usr/include/glib-2.0 -I/usr/lib/x86_64-linux-gnu/glib-2.0/include -I/usr/include/libmount -I/usr/include/blkid -I/usr/include/sysprof-6 -I/usr/include/gstreamer-1.0 -I/run/build/BambuStudio/build/src/libslic3r -I/run/build/BambuStudio/deps/build/destdir/usr/local/include/opencascade -I/run/build/BambuStudio/src/libnest2d/include -I/run/build/BambuStudio/src/miniz -I/run/build/BambuStudio/src/glu-libtess/include -I/run/build/BambuStudio/src/clipper2/Clipper2Lib/include -I/run/build/BambuStudio/src/minilzo -isystem /run/build/BambuStudio/src/eigen -isystem /run/build/BambuStudio/src/libigl -isystem /app/lib/wx/include/gtk3-unicode-static-3.1 -isystem /app/include/wx-3.1 -isystem /run/build/BambuStudio/deps/build/destdir/usr/local/include -isystem /run/build/BambuStudio/deps/build/destdir/usr/local/include/opencv4 -isystem /run/build/BambuStudio/deps/build/destdir/usr/local/include/OpenEXR -std=gnu++20 -fext-numeric-literals -Wall -Wno-reorder -pthread -O3 -DNDEBUG -std=gnu++17 -fPIC -fsigned-char -Werror=return-type -Wno-ignored-attributes -Wno-unknown-pragmas -DOPENVDB_ABI_VERSION_NUMBER=8 -MD -MT src/slic3r/CMakeFiles/libslic3r_gui.dir/Utils/FontUtils.cpp.o -MF src/slic3r/CMakeFiles/libslic3r_gui.dir/Utils/FontUtils.cpp.o.d -o src/slic3r/CMakeFiles/libslic3r_gui.dir/Utils/FontUtils.cpp.o -c /run/build/BambuStudio/src/slic3r/Utils/FontUtils.cpp /run/build/BambuStudio/src/slic3r/Utils/FontUtils.cpp: In function ‘std::unique_ptr<Slic3r::FontFile> Slic3r::create_font_file(const char*)’: /run/build/BambuStudio/src/slic3r/Utils/FontUtils.cpp:127:27: error: ‘error’ was not declared in this scope; did you mean ‘perror’? 127 | BOOST_LOG_TRIVIAL(error) << "Couldn't open " << file_path << " for reading."; | ^~~~~ | perror [447/494] Building CXX object src/slic3r/CMakeFiles/libslic3r_gui.dir/GUI/TaskManager.cpp.o FAILED: src/slic3r/CMakeFiles/libslic3r_gui.dir/GUI/TaskManager.cpp.o /usr/bin/c++ -DBOOST_ATOMIC_NO_LIB -DBOOST_CHRONO_NO_LIB -DBOOST_DATE_TIME_NO_LIB -DBOOST_FILESYSTEM_NO_LIB -DBOOST_IOSTREAMS_NO_LIB -DBOOST_LOCALE_NO_LIB -DBOOST_LOG_NO_LIB -DBOOST_REGEX_NO_LIB -DBOOST_SYSTEM_NO_LIB -DBOOST_THREAD_NO_LIB -DCURL_STATICLIB -DGLEW_STATIC -DLIBNEST2D_GEOMETRIES_libslic3r -DLIBNEST2D_OPTIMIZER_nlopt -DLIBNEST2D_STATIC -DLIBNEST2D_THREADING_tbb -DOPENSSL_CERT_OVERRIDE -DOPENVDB_OPENEXR_STATICLIB -DOPENVDB_STATICLIB -DSLIC3R_CURRENTLY_COMPILING_GUI_MODULE -DSLIC3R_GUI -DTBB_USE_CAPTURED_EXCEPTION=0 -DUNICODE -DUSE_TBB -DWXINTL_NO_GETTEXT_MACRO -D_UNICODE -D__WXGTK3__ -D__WXGTK__ -DwxDEBUG_LEVEL=0 -DwxNO_UNSAFE_WXSTRING_CONV -DwxUSE_UNICODE -I/usr/include/dbus-1.0 -I/usr/lib/x86_64-linux-gnu/dbus-1.0/include -I/run/build/BambuStudio/src -I/run/build/BambuStudio/build/src/platform -I/run/build/BambuStudio/src/hidapi/include -I/run/build/BambuStudio/src/slic3r/Utils -I/usr/include/gtk-3.0 -I/usr/include/pango-1.0 -I/usr/include/cairo -I/usr/include/gdk-pixbuf-2.0 -I/usr/include/webp -I/usr/include/at-spi2-atk/2.0 -I/usr/include/at-spi-2.0 -I/usr/include/atk-1.0 -I/usr/include/fribidi -I/usr/include/pixman-1 -I/usr/include/harfbuzz -I/usr/include/freetype2 -I/usr/include/libpng16 -I/usr/include/gio-unix-2.0 -I/usr/include/glib-2.0 -I/usr/lib/x86_64-linux-gnu/glib-2.0/include -I/usr/include/libmount -I/usr/include/blkid -I/usr/include/sysprof-6 -I/usr/include/gstreamer-1.0 -I/run/build/BambuStudio/build/src/libslic3r -I/run/build/BambuStudio/deps/build/destdir/usr/local/include/opencascade -I/run/build/BambuStudio/src/libnest2d/include -I/run/build/BambuStudio/src/miniz -I/run/build/BambuStudio/src/glu-libtess/include -I/run/build/BambuStudio/src/clipper2/Clipper2Lib/include -I/run/build/BambuStudio/src/minilzo -isystem /run/build/BambuStudio/src/eigen -isystem /run/build/BambuStudio/src/libigl -isystem /app/lib/wx/include/gtk3-unicode-static-3.1 -isystem /app/include/wx-3.1 -isystem /run/build/BambuStudio/deps/build/destdir/usr/local/include -isystem /run/build/BambuStudio/deps/build/destdir/usr/local/include/opencv4 -isystem /run/build/BambuStudio/deps/build/destdir/usr/local/include/OpenEXR -std=gnu++20 -fext-numeric-literals -Wall -Wno-reorder -pthread -O3 -DNDEBUG -std=gnu++17 -fPIC -fsigned-char -Werror=return-type -Wno-ignored-attributes -Wno-unknown-pragmas -DOPENVDB_ABI_VERSION_NUMBER=8 -MD -MT src/slic3r/CMakeFiles/libslic3r_gui.dir/GUI/TaskManager.cpp.o -MF src/slic3r/CMakeFiles/libslic3r_gui.dir/GUI/TaskManager.cpp.o.d -o src/slic3r/CMakeFiles/libslic3r_gui.dir/GUI/TaskManager.cpp.o -c /run/build/BambuStudio/src/slic3r/GUI/TaskManager.cpp In file included from /run/build/BambuStudio/src/slic3r/GUI/TaskManager.cpp:1: /run/build/BambuStudio/src/slic3r/GUI/TaskManager.hpp: In member function ‘void Slic3r::TaskStateInfo::set_state(Slic3r::TaskState)’: /run/build/BambuStudio/src/slic3r/GUI/TaskManager.hpp:40:9: error: ‘BOOST_LOG_TRIVIAL’ was not declared in this scope 40 | BOOST_LOG_TRIVIAL(trace) << "TaskStateInfo set state = " << get_task_state_enum_str(ts); | ^~~~~~~~~~~~~~~~~ * fix OpenCV * wip - build break * fix build error wip * ENH: support preset description(tooltip) Change-Id: Iff005baac4974c538d1109fb0ba1df20b04a8f69 Jira: STUDIO-5754 * fix more build errors * Revert "ENH: load more fonts" This reverts commit 32b6fd199ac50e21db1f72089e5b3287a1776e04. * change colors * misc fixes * restore export gcode btn --------- Signed-off-by: xun.zhang <xun.zhang@bambulab.com> Signed-off-by: Stone Li <stone.li@bambulab.com> Signed-off-by: Kunlong Ma <kunlong.ma@bambulab.com> Signed-off-by: XunZhangBambu <xun.zhang@bambulab.com> Co-authored-by: lane.wei <lane.wei@bambulab.com> Co-authored-by: Arthur <arthur.tang@bambulab.com> Co-authored-by: xun.zhang <xun.zhang@bambulab.com> Co-authored-by: zhimin.zeng <zhimin.zeng@bambulab.com> Co-authored-by: Kunlong Ma <kunlong.ma@bambulab.com> Co-authored-by: jianjia.ma <jianjia.ma@bambulab.com> Co-authored-by: liz.li <liz.li@bambulab.com> Co-authored-by: tao wang <tao.wang@bambulab.com> Co-authored-by: Stone Li <stone.li@bambulab.com> Co-authored-by: zhou.xu <zhou.xu@bambulab.com> Co-authored-by: Bastien Nocera <hadess@hadess.net> Co-authored-by: chunmao.guo <chunmao.guo@bambulab.com>
651 lines
27 KiB
C++
651 lines
27 KiB
C++
#include "MediaFilePanel.h"
|
|
#include "ImageGrid.h"
|
|
#include "I18N.hpp"
|
|
#include "GUI_App.hpp"
|
|
#include "Plater.hpp"
|
|
#include "Widgets/Button.hpp"
|
|
#include "Widgets/SwitchButton.hpp"
|
|
#include "Widgets/Label.hpp"
|
|
#include "Printer/PrinterFileSystem.h"
|
|
#include "MsgDialog.hpp"
|
|
#include "Widgets/ProgressDialog.hpp"
|
|
#include <libslic3r/Model.hpp>
|
|
#include <libslic3r/Format/bbs_3mf.hpp>
|
|
|
|
#ifdef __WXMSW__
|
|
#include <shellapi.h>
|
|
#endif
|
|
#ifdef __APPLE__
|
|
#include "../Utils/MacDarkMode.hpp"
|
|
#endif
|
|
|
|
namespace Slic3r {
|
|
namespace GUI {
|
|
|
|
MediaFilePanel::MediaFilePanel(wxWindow * parent)
|
|
: wxPanel(parent, wxID_ANY)
|
|
, m_bmp_loading(this, "media_loading", 0)
|
|
, m_bmp_failed(this, "media_failed", 0)
|
|
, m_bmp_empty(this, "media_empty", 0)
|
|
, m_machine("<null>")
|
|
{
|
|
SetBackgroundColour(0xEEEEEE);
|
|
Hide();
|
|
|
|
wxBoxSizer * sizer = new wxBoxSizer(wxVERTICAL);
|
|
|
|
wxBoxSizer * top_sizer = new wxBoxSizer(wxHORIZONTAL);
|
|
top_sizer->SetMinSize({-1, 75 * em_unit(this) / 10});
|
|
|
|
// Time group
|
|
auto time_panel = new wxWindow(this, wxID_ANY);
|
|
time_panel->SetBackgroundColour(0xEEEEEE);
|
|
m_time_panel = new ::StaticBox(time_panel, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxBORDER_NONE);
|
|
m_time_panel->SetCornerRadius(0);
|
|
m_button_year = new ::Button(m_time_panel, _L("Year"), "", wxBORDER_NONE);
|
|
m_button_month = new ::Button(m_time_panel, _L("Month"), "", wxBORDER_NONE);
|
|
m_button_all = new ::Button(m_time_panel, _L("All Files"), "", wxBORDER_NONE);
|
|
m_button_year->SetToolTip(_L("Group files by year, recent first."));
|
|
m_button_month->SetToolTip(_L("Group files by month, recent first."));
|
|
m_button_all->SetToolTip(_L("Show all files, recent first."));
|
|
m_button_all->SetFont(Label::Head_14); // sync with m_last_mode
|
|
for (auto b : {m_button_year, m_button_month, m_button_all}) {
|
|
b->SetBackgroundColor(StateColor());
|
|
b->SetTextColor(StateColor(
|
|
std::make_pair(0x3B4446, (int) StateColor::Checked),
|
|
std::make_pair(*wxLIGHT_GREY, (int) StateColor::Hovered),
|
|
std::make_pair(0xABACAC, (int) StateColor::Normal)
|
|
));
|
|
}
|
|
|
|
wxBoxSizer *time_sizer = new wxBoxSizer(wxHORIZONTAL);
|
|
time_sizer->Add(m_button_year, 0, wxALIGN_CENTER_VERTICAL | wxLEFT | wxRIGHT, 24);
|
|
time_sizer->Add(m_button_month, 0, wxALIGN_CENTER_VERTICAL);
|
|
time_sizer->Add(m_button_all, 0, wxALIGN_CENTER_VERTICAL | wxLEFT | wxRIGHT, 24);
|
|
m_time_panel->SetSizer(time_sizer);
|
|
wxBoxSizer *time_sizer2 = new wxBoxSizer(wxHORIZONTAL);
|
|
time_sizer2->Add(m_time_panel, 1, wxEXPAND);
|
|
time_panel->SetSizer(time_sizer2);
|
|
top_sizer->Add(time_panel, 1, wxEXPAND);
|
|
|
|
// File type
|
|
StateColor background(
|
|
std::make_pair(0xEEEEEE, (int) StateColor::Checked),
|
|
std::make_pair(*wxLIGHT_GREY, (int) StateColor::Hovered),
|
|
std::make_pair(*wxWHITE, (int) StateColor::Normal));
|
|
m_type_panel = new ::StaticBox(this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxBORDER_NONE);
|
|
m_type_panel->SetBackgroundColor(*wxWHITE);
|
|
m_type_panel->SetCornerRadius(FromDIP(5));
|
|
m_type_panel->SetMinSize({-1, 48 * em_unit(this) / 10});
|
|
m_button_timelapse = new ::Button(m_type_panel, _L("Timelapse"), "", wxBORDER_NONE);
|
|
m_button_timelapse->SetToolTip(_L("Switch to timelapse files."));
|
|
m_button_video = new ::Button(m_type_panel, _L("Video"), "", wxBORDER_NONE);
|
|
m_button_video->SetToolTip(_L("Switch to video files."));
|
|
m_button_model = new ::Button(m_type_panel, _L("Model"), "", wxBORDER_NONE);
|
|
m_button_video->SetToolTip(_L("Switch to 3mf model files."));
|
|
for (auto b : {m_button_timelapse, m_button_video, m_button_model}) {
|
|
b->SetBackgroundColor(background);
|
|
b->SetCanFocus(false);
|
|
}
|
|
|
|
wxBoxSizer *type_sizer = new wxBoxSizer(wxHORIZONTAL);
|
|
type_sizer->Add(m_button_timelapse, 0, wxALIGN_CENTER_VERTICAL | wxLEFT | wxRIGHT, 24);
|
|
//type_sizer->Add(m_button_video, 0, wxALIGN_CENTER_VERTICAL | wxRIGHT, 24);
|
|
m_button_video->Hide();
|
|
type_sizer->Add(m_button_model, 0, wxALIGN_CENTER_VERTICAL | wxRIGHT, 24);
|
|
m_type_panel->SetSizer(type_sizer);
|
|
top_sizer->Add(m_type_panel, 0, wxALIGN_CENTER_VERTICAL);
|
|
|
|
// File management
|
|
m_manage_panel = new ::StaticBox(this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxBORDER_NONE);
|
|
m_manage_panel->SetBackgroundColor(StateColor());
|
|
m_button_delete = new ::Button(m_manage_panel, _L("Delete"));
|
|
m_button_delete->SetToolTip(_L("Delete selected files from printer."));
|
|
m_button_download = new ::Button(m_manage_panel, _L("Download"));
|
|
m_button_download->SetToolTip(_L("Download selected files from printer."));
|
|
m_button_management = new ::Button(m_manage_panel, _L("Select"));
|
|
m_button_management->SetToolTip(_L("Batch manage files."));
|
|
m_button_refresh = new ::Button(m_manage_panel, _L("Refresh"));
|
|
m_button_refresh->SetToolTip(_L("Reload file list from printer."));
|
|
for (auto b : {m_button_delete, m_button_download, m_button_refresh, m_button_management}) {
|
|
b->SetFont(Label::Body_12);
|
|
b->SetCornerRadius(12);
|
|
b->SetPaddingSize({10, 6});
|
|
b->SetCanFocus(false);
|
|
}
|
|
m_button_delete->SetBorderColorNormal(wxColor("#FF6F00"));
|
|
m_button_delete->SetTextColorNormal(wxColor("#FF6F00"));
|
|
m_button_management->SetBorderWidth(0);
|
|
m_button_management->SetBackgroundColorNormal(wxColor("#009688"));
|
|
m_button_management->SetTextColorNormal(*wxWHITE);
|
|
m_button_management->Enable(false);
|
|
m_button_refresh->SetBorderWidth(0);
|
|
m_button_refresh->SetBackgroundColorNormal(wxColor("#009688"));
|
|
m_button_refresh->SetTextColorNormal(*wxWHITE);
|
|
m_button_refresh->Enable(false);
|
|
|
|
wxBoxSizer *manage_sizer = new wxBoxSizer(wxHORIZONTAL);
|
|
manage_sizer->AddStretchSpacer(1);
|
|
manage_sizer->Add(m_button_download, 0, wxALIGN_CENTER_VERTICAL)->Show(false);
|
|
manage_sizer->Add(m_button_delete, 0, wxALIGN_CENTER_VERTICAL | wxLEFT | wxRIGHT, 24)->Show(false);
|
|
manage_sizer->Add(m_button_refresh, 0, wxALIGN_CENTER_VERTICAL);
|
|
manage_sizer->Add(m_button_management, 0, wxALIGN_CENTER_VERTICAL | wxLEFT | wxRIGHT, 24);
|
|
m_manage_panel->SetSizer(manage_sizer);
|
|
top_sizer->Add(m_manage_panel, 1, wxEXPAND);
|
|
|
|
sizer->Add(top_sizer, 0, wxEXPAND);
|
|
|
|
m_image_grid = new ImageGrid(this);
|
|
m_image_grid->Bind(EVT_ITEM_ACTION, [this](wxCommandEvent &e) { doAction(size_t(e.GetExtraLong()), e.GetInt()); });
|
|
m_image_grid->SetStatus(m_bmp_failed, _L("No printers."));
|
|
sizer->Add(m_image_grid, 1, wxEXPAND);
|
|
|
|
SetSizer(sizer);
|
|
|
|
// Time group
|
|
auto time_button_clicked = [this](wxEvent &e) {
|
|
auto mode = PrinterFileSystem::G_NONE;
|
|
if (e.GetEventObject() == m_button_year)
|
|
mode = PrinterFileSystem::G_YEAR;
|
|
else if (e.GetEventObject() == m_button_month)
|
|
mode = PrinterFileSystem::G_MONTH;
|
|
m_image_grid->SetGroupMode(mode);
|
|
};
|
|
m_button_year->Bind(wxEVT_COMMAND_BUTTON_CLICKED, time_button_clicked);
|
|
m_button_month->Bind(wxEVT_COMMAND_BUTTON_CLICKED, time_button_clicked);
|
|
m_button_all->Bind(wxEVT_COMMAND_BUTTON_CLICKED, time_button_clicked);
|
|
m_button_all->SetValue(true);
|
|
|
|
// File type
|
|
auto type_button_clicked = [this](wxEvent &e) {
|
|
Button *buttons[]{m_button_timelapse, m_button_video, m_button_model};
|
|
auto type = std::find(buttons, buttons + sizeof(buttons) / sizeof(buttons[0]), e.GetEventObject()) - buttons;
|
|
if (m_last_type == type)
|
|
return;
|
|
m_image_grid->SetFileType(type, m_external ? "" : "internal");
|
|
buttons[m_last_type]->SetValue(!buttons[m_last_type]->GetValue());
|
|
m_last_type = type;
|
|
buttons[m_last_type]->SetValue(!buttons[m_last_type]->GetValue());
|
|
if (type == PrinterFileSystem::F_MODEL)
|
|
m_image_grid->SetGroupMode(PrinterFileSystem::G_NONE);
|
|
};
|
|
m_button_timelapse->Bind(wxEVT_COMMAND_BUTTON_CLICKED, type_button_clicked);
|
|
m_button_video->Bind(wxEVT_COMMAND_BUTTON_CLICKED, type_button_clicked);
|
|
m_button_model->Bind(wxEVT_COMMAND_BUTTON_CLICKED, type_button_clicked);
|
|
m_button_timelapse->SetValue(true);
|
|
|
|
// File management
|
|
m_button_management->Bind(wxEVT_COMMAND_BUTTON_CLICKED, [this](auto &e) {
|
|
e.Skip();
|
|
SetSelecting(!m_image_grid->IsSelecting());
|
|
});
|
|
m_button_refresh->Bind(wxEVT_COMMAND_BUTTON_CLICKED, [this](auto &e) {
|
|
e.Skip();
|
|
if (auto fs = m_image_grid->GetFileSystem())
|
|
fs->ListAllFiles();
|
|
});
|
|
m_button_download->Bind(wxEVT_COMMAND_BUTTON_CLICKED, [this](auto &e) {
|
|
m_image_grid->DoActionOnSelection(1);
|
|
SetSelecting(false);
|
|
});
|
|
m_button_delete->Bind(wxEVT_COMMAND_BUTTON_CLICKED, [this](auto &e) {
|
|
m_image_grid->DoActionOnSelection(0);
|
|
SetSelecting(false);
|
|
});
|
|
|
|
auto onShowHide = [this](auto &e) {
|
|
e.Skip();
|
|
if (auto w = dynamic_cast<wxWindow *>(e.GetEventObject()); !w || w->IsBeingDeleted())
|
|
return;
|
|
CallAfter([this] {
|
|
auto fs = m_image_grid ? m_image_grid->GetFileSystem() : nullptr;
|
|
if (fs) IsShownOnScreen() ? fs->Start() : fs->Stop();
|
|
});
|
|
};
|
|
Bind(wxEVT_SHOW, onShowHide);
|
|
parent->GetParent()->Bind(wxEVT_SHOW, onShowHide);
|
|
}
|
|
|
|
MediaFilePanel::~MediaFilePanel()
|
|
{
|
|
SetMachineObject(nullptr);
|
|
}
|
|
|
|
void MediaFilePanel::SetMachineObject(MachineObject* obj)
|
|
{
|
|
std::string machine = obj ? obj->dev_id : "";
|
|
if (obj) {
|
|
m_lan_mode = obj->is_lan_mode_printer();
|
|
m_lan_ip = obj->dev_ip;
|
|
m_lan_passwd = obj->get_access_code();
|
|
m_dev_ver = obj->get_ota_version();
|
|
m_device_busy = obj->is_camera_busy_off();
|
|
m_sdcard_exist = obj->has_sdcard();
|
|
m_local_support = obj->file_local;
|
|
m_remote_support = obj->file_remote;
|
|
m_model_download_support = obj->file_model_download;
|
|
} else {
|
|
m_lan_mode = false;
|
|
m_lan_ip.clear();
|
|
m_lan_passwd.clear();
|
|
m_dev_ver.clear();
|
|
m_sdcard_exist = false;
|
|
m_device_busy = false;
|
|
m_local_support = false;
|
|
m_remote_support = false;
|
|
m_model_download_support = false;
|
|
}
|
|
Enable(obj && obj->is_connected() && obj->m_push_count > 0);
|
|
if (machine == m_machine) {
|
|
if ((m_waiting_enable && IsEnabled()) || (m_waiting_support && (m_local_support || m_remote_support))) {
|
|
auto fs = m_image_grid->GetFileSystem();
|
|
if (fs) fs->Retry();
|
|
}
|
|
return;
|
|
}
|
|
m_machine.swap(machine);
|
|
m_last_errors.clear();
|
|
auto fs = m_image_grid->GetFileSystem();
|
|
if (fs) {
|
|
m_image_grid->SetFileSystem(nullptr);
|
|
fs->Unbind(EVT_MODE_CHANGED, &MediaFilePanel::modeChanged, this);
|
|
fs->Stop(true);
|
|
}
|
|
m_button_refresh->Enable(false);
|
|
m_button_management->Enable(false);
|
|
SetSelecting(false);
|
|
if (m_machine.empty()) {
|
|
m_image_grid->SetStatus(m_bmp_failed, _L("No printers."));
|
|
} else {
|
|
boost::shared_ptr<PrinterFileSystem> fs(new PrinterFileSystem);
|
|
fs->Attached();
|
|
m_image_grid->SetFileSystem(fs);
|
|
m_image_grid->SetFileType(m_last_type, m_external ? "" : "internal");
|
|
fs->Bind(EVT_FILE_CHANGED, [this, wfs = boost::weak_ptr(fs)](auto &e) {
|
|
e.Skip();
|
|
boost::shared_ptr fs(wfs.lock());
|
|
if (fs == nullptr || m_image_grid->GetFileSystem() != fs) // canceled
|
|
return;
|
|
m_time_panel->Show(fs->GetFileType() < PrinterFileSystem::F_MODEL);
|
|
//m_manage_panel->Show(fs->GetFileType() < PrinterFileSystem::F_MODEL);
|
|
m_button_refresh->Enable(fs->GetStatus() == PrinterFileSystem::ListReady);
|
|
m_button_management->Enable(fs->GetCount() > 0);
|
|
bool download_support = fs->GetFileType() < PrinterFileSystem::F_MODEL || m_model_download_support;
|
|
m_image_grid->ShowDownload(download_support);
|
|
if (fs->GetCount() == 0)
|
|
SetSelecting(false);
|
|
});
|
|
fs->Bind(EVT_SELECT_CHANGED, [this, wfs = boost::weak_ptr(fs)](auto &e) {
|
|
e.Skip();
|
|
boost::shared_ptr fs(wfs.lock());
|
|
if (fs == nullptr || m_image_grid->GetFileSystem() != fs) // canceled
|
|
return;
|
|
m_button_delete->Enable(e.GetInt() > 0);
|
|
m_button_download->Enable(e.GetInt() > 0);
|
|
});
|
|
fs->Bind(EVT_MODE_CHANGED, &MediaFilePanel::modeChanged, this);
|
|
fs->Bind(EVT_STATUS_CHANGED, [this, wfs = boost::weak_ptr(fs)](auto& e) {
|
|
e.Skip();
|
|
boost::shared_ptr fs(wfs.lock());
|
|
if (fs == nullptr || m_image_grid->GetFileSystem() != fs) // canceled
|
|
return;
|
|
ScalableBitmap icon;
|
|
wxString msg;
|
|
int status = e.GetInt();
|
|
int extra = e.GetExtraLong();
|
|
switch (status) {
|
|
case PrinterFileSystem::Initializing: icon = m_bmp_loading; msg = _L("Initializing..."); break;
|
|
case PrinterFileSystem::Connecting: icon = m_bmp_loading; msg = _L("Connecting..."); break;
|
|
case PrinterFileSystem::Failed: icon = m_bmp_failed; if (extra != 1) msg = _L("Connect failed [%d]!"); break;
|
|
case PrinterFileSystem::ListSyncing: icon = m_bmp_loading; msg = _L("Loading file list..."); break;
|
|
case PrinterFileSystem::ListReady: icon = extra == 0 ? m_bmp_empty : m_bmp_failed; msg = extra == 0 ? _L("No files") : _L("Load failed"); break;
|
|
}
|
|
int err = fs->GetLastError();
|
|
if (!e.GetString().IsEmpty())
|
|
msg = e.GetString();
|
|
if (err != 0)
|
|
msg += " [%d]";
|
|
if (fs->GetCount() == 0 && !msg.empty())
|
|
m_image_grid->SetStatus(icon, msg);
|
|
if (e.GetInt() == PrinterFileSystem::Initializing)
|
|
fetchUrl(boost::weak_ptr(fs));
|
|
|
|
err = fs->GetLastError();
|
|
if ((status == PrinterFileSystem::Failed && m_last_errors.find(err) == m_last_errors.end()) ||
|
|
status == PrinterFileSystem::ListReady) {
|
|
m_last_errors.insert(fs->GetLastError());
|
|
}
|
|
});
|
|
fs->Bind(EVT_DOWNLOAD, [this, wfs = boost::weak_ptr(fs)](auto& e) {
|
|
e.Skip();
|
|
boost::shared_ptr fs(wfs.lock());
|
|
if (fs == nullptr || m_image_grid->GetFileSystem() != fs) // canceled
|
|
return;
|
|
|
|
int result = e.GetExtraLong();
|
|
if (result > 1 && !e.GetString().IsEmpty())
|
|
CallAfter([this, m = e.GetString()] {
|
|
MessageDialog(this, m, _L("Download failed"), wxOK | wxICON_ERROR).ShowModal();
|
|
});
|
|
|
|
NetworkAgent* agent = wxGetApp().getAgent();
|
|
if (result > 1 || result == 0) {
|
|
json j;
|
|
j["code"] = result;
|
|
j["dev_id"] = m_machine;
|
|
j["dev_ip"] = m_lan_ip;
|
|
if (result > 1) {
|
|
// download failed
|
|
j["result"] = "failed";
|
|
} else if (result == 0) {
|
|
// download success
|
|
j["result"] = "success";
|
|
}
|
|
}
|
|
return;
|
|
});
|
|
if (IsShown()) fs->Start();
|
|
}
|
|
wxCommandEvent e(EVT_MODE_CHANGED);
|
|
modeChanged(e);
|
|
}
|
|
|
|
void MediaFilePanel::SwitchStorage(bool external)
|
|
{
|
|
if (m_external == external)
|
|
return;
|
|
m_external = external;
|
|
m_type_panel->Show(external);
|
|
if (!external) {
|
|
Button *buttons[]{m_button_timelapse, m_button_video, m_button_model};
|
|
auto button = buttons[PrinterFileSystem::F_MODEL];
|
|
wxCommandEvent event(wxEVT_COMMAND_BUTTON_CLICKED, button->GetId());
|
|
event.SetEventObject(button);
|
|
wxPostEvent(button, event);
|
|
}
|
|
m_image_grid->SetFileType(m_last_type, m_external ? "" : "internal");
|
|
}
|
|
|
|
void MediaFilePanel::Rescale()
|
|
{
|
|
m_bmp_loading.msw_rescale();
|
|
m_bmp_failed.msw_rescale();
|
|
m_bmp_empty.msw_rescale();
|
|
|
|
auto top_sizer = GetSizer()->GetItem((size_t) 0)->GetSizer();
|
|
top_sizer->SetMinSize({-1, 75 * em_unit(this) / 10});
|
|
m_button_year->Rescale();
|
|
m_button_month->Rescale();
|
|
m_button_all->Rescale();
|
|
|
|
m_button_video->Rescale();
|
|
m_button_timelapse->Rescale();
|
|
m_button_model->Rescale();
|
|
m_type_panel->SetMinSize({-1, 48 * em_unit(this) / 10});
|
|
|
|
m_button_download->Rescale();
|
|
m_button_delete->Rescale();
|
|
m_button_refresh->Rescale();
|
|
m_button_management->Rescale();
|
|
|
|
m_image_grid->Rescale();
|
|
}
|
|
|
|
void MediaFilePanel::SetSelecting(bool selecting)
|
|
{
|
|
m_image_grid->SetSelecting(selecting);
|
|
m_button_management->SetLabel(selecting ? _L("Cancel") : _L("Select"));
|
|
auto fs = m_image_grid->GetFileSystem();
|
|
bool download_support = fs && fs->GetFileType() < PrinterFileSystem::F_MODEL || m_model_download_support;
|
|
m_manage_panel->GetSizer()->Show(m_button_download, selecting && download_support);
|
|
m_manage_panel->GetSizer()->Show(m_button_delete, selecting);
|
|
m_manage_panel->GetSizer()->Show(m_button_refresh, !selecting);
|
|
m_manage_panel->Layout();
|
|
}
|
|
|
|
void MediaFilePanel::modeChanged(wxCommandEvent& e1)
|
|
{
|
|
e1.Skip();
|
|
auto fs = m_image_grid->GetFileSystem();
|
|
auto mode = fs ? fs->GetGroupMode() : 0;
|
|
if (m_last_mode == mode)
|
|
return;
|
|
::Button* buttons[] = {m_button_all, m_button_month, m_button_year};
|
|
auto b = buttons[m_last_mode];
|
|
b->SetFont(Label::Body_14);
|
|
b->SetValue(false);
|
|
b = buttons[mode];
|
|
b->SetFont(Label::Head_14);
|
|
b->SetValue(true);
|
|
m_last_mode = mode;
|
|
}
|
|
|
|
extern wxString hide_passwd(wxString url, std::vector<wxString> const &passwords);
|
|
|
|
void MediaFilePanel::fetchUrl(boost::weak_ptr<PrinterFileSystem> wfs)
|
|
{
|
|
boost::shared_ptr fs(wfs.lock());
|
|
if (!fs || fs != m_image_grid->GetFileSystem()) return;
|
|
if (!IsEnabled()) {
|
|
m_waiting_enable = true;
|
|
m_image_grid->SetStatus(m_bmp_failed, _L("Initialize failed (Device connection not ready)!"));
|
|
fs->SetUrl("0");
|
|
return;
|
|
}
|
|
m_waiting_enable = false;
|
|
if (!m_local_support && !m_remote_support) {
|
|
m_waiting_support = true;
|
|
m_image_grid->SetStatus(m_bmp_failed, _L("Browsing file in SD card is not supported in current firmware. Please update the printer firmware."));
|
|
fs->SetUrl("0");
|
|
return;
|
|
}
|
|
if (!m_sdcard_exist) {
|
|
m_image_grid->SetStatus(m_bmp_failed, _L("Initialize failed (Storage unavailable, insert SD card.)!"));
|
|
fs->SetUrl("0");
|
|
return;
|
|
}
|
|
if (m_device_busy) {
|
|
m_image_grid->SetStatus(m_bmp_failed, _L("The printer is currently busy downloading. Please try again after it finishes."));
|
|
fs->SetUrl("0");
|
|
return;
|
|
}
|
|
m_waiting_support = false;
|
|
NetworkAgent *agent = wxGetApp().getAgent();
|
|
std::string agent_version = agent ? agent->get_version() : "";
|
|
if ((m_lan_mode || !m_remote_support) && m_local_support && !m_lan_ip.empty()) {
|
|
std::string url = "bambu:///local/" + m_lan_ip + ".?port=6000&user=" + m_lan_user + "&passwd=" + m_lan_passwd;
|
|
url += "&device=" + m_machine;
|
|
url += "&net_ver=" + agent_version;
|
|
url += "&dev_ver=" + m_dev_ver;
|
|
url += "&cli_id=" + wxGetApp().app_config->get("slicer_uuid");
|
|
url += "&cli_ver=" + std::string(SLIC3R_VERSION);
|
|
fs->SetUrl(url);
|
|
return;
|
|
}
|
|
if (!m_remote_support && m_local_support) { // not support tutk
|
|
m_image_grid->SetStatus(m_bmp_failed, _L("Please enter the IP of printer to connect."));
|
|
fs->SetUrl("0");
|
|
fs.reset();
|
|
if (wxGetApp().show_modal_ip_address_enter_dialog(_L("LAN Connection Failed (Failed to view sdcard)"))) {
|
|
if (auto fs = wfs.lock())
|
|
fs->Retry();
|
|
}
|
|
return;
|
|
}
|
|
if (m_lan_mode) {
|
|
m_image_grid->SetStatus(m_bmp_failed, _L("Browsing file in SD card is not supported in LAN Only Mode."));
|
|
fs->SetUrl("0");
|
|
return;
|
|
}
|
|
if (agent) {
|
|
agent->get_camera_url(m_machine,
|
|
[this, wfs, m = m_machine, v = agent->get_version(), dv = m_dev_ver](std::string url) {
|
|
if (boost::algorithm::starts_with(url, "bambu:///")) {
|
|
url += "&device=" + m;
|
|
url += "&net_ver=" + v;
|
|
url += "&dev_ver=" + dv;
|
|
url += "&cli_id=" + wxGetApp().app_config->get("slicer_uuid");
|
|
url += "&cli_ver=" + std::string(SLIC3R_VERSION);
|
|
}
|
|
BOOST_LOG_TRIVIAL(info) << "MediaFilePanel::fetchUrl: camera_url: " << hide_passwd(url, {"?uid=", "authkey=", "passwd="});
|
|
CallAfter([=] {
|
|
boost::shared_ptr fs(wfs.lock());
|
|
if (!fs || fs != m_image_grid->GetFileSystem()) return;
|
|
if (boost::algorithm::starts_with(url, "bambu:///")) {
|
|
fs->SetUrl(url + "&device=" + m + "&dev_ver=" + v);
|
|
} else {
|
|
m_image_grid->SetStatus(m_bmp_failed, wxString::Format(_L("Initialize failed (%s)!"), url.empty() ? _L("Network unreachable") : from_u8(url)));
|
|
fs->SetUrl("3");
|
|
}
|
|
});
|
|
});
|
|
}
|
|
}
|
|
|
|
struct MediaProgressDialog : ProgressDialog
|
|
{
|
|
MediaProgressDialog(wxString title, wxWindow * parent, std::function<void()> cancel)
|
|
: ProgressDialog(title, "", 100, parent, wxPD_NO_PROGRESS | wxPD_APP_MODAL | wxPD_CAN_ABORT)
|
|
, m_cancel(cancel) {}
|
|
void OnCancel() override{m_cancel(); }
|
|
std::function<void()> m_cancel;
|
|
};
|
|
|
|
void MediaFilePanel::doAction(size_t index, int action)
|
|
{
|
|
auto fs = m_image_grid->GetFileSystem();
|
|
if (action == 0) {
|
|
if (index == -1) {
|
|
MessageDialog dlg(this,
|
|
wxString::Format(_L_PLURAL("You are going to delete %u file from printer. Are you sure to continue?",
|
|
"You are going to delete %u files from printer. Are you sure to continue?", fs->GetSelectCount()),
|
|
fs->GetSelectCount()),
|
|
_L("Delete files"), wxYES_NO | wxICON_WARNING);
|
|
if (dlg.ShowModal() != wxID_YES)
|
|
return;
|
|
} else {
|
|
MessageDialog dlg(this,
|
|
wxString::Format(_L("Do you want to delete the file '%s' from printer?"), from_u8(fs->GetFile(index).name)),
|
|
_L("Delete file"), wxYES_NO | wxICON_WARNING);
|
|
if (dlg.ShowModal() != wxID_YES)
|
|
return;
|
|
}
|
|
fs->DeleteFiles(index);
|
|
} else if (action == 1) {
|
|
if (fs->GetFileType() == PrinterFileSystem::F_MODEL) {
|
|
if (index != -1) {
|
|
auto dlg = new MediaProgressDialog(_L("Print"), this, [fs] { fs->FetchModelCancel(); });
|
|
dlg->Update(0, _L("Fetching model infomations ..."));
|
|
fs->FetchModel(index, [this, fs, dlg, index](int result, std::string const &data) {
|
|
dlg->Destroy();
|
|
if (result == PrinterFileSystem::ERROR_CANCEL)
|
|
return;
|
|
if (result != 0) {
|
|
wxString msg = data.empty() ? _L("Failed to fetch model information from printer.") :
|
|
from_u8(data);
|
|
CallAfter([this, msg] {
|
|
MessageDialog(this, msg, _L("Print"), wxOK).ShowModal();
|
|
});
|
|
return;
|
|
}
|
|
Slic3r::DynamicPrintConfig config;
|
|
Slic3r::Model model;
|
|
Slic3r::PlateDataPtrs plate_data_list;
|
|
Slic3r::Semver file_version;
|
|
std::istringstream is(data);
|
|
if (!Slic3r::load_gcode_3mf_from_stream(is, &config, &model, &plate_data_list, &file_version)
|
|
|| plate_data_list.empty()) {
|
|
MessageDialog(this,
|
|
_L("Failed to parse model information."),
|
|
_L("Print"), wxOK).ShowModal();
|
|
return;
|
|
}
|
|
|
|
|
|
auto &file = fs->GetFile(index);
|
|
|
|
std::string file_path = file.path;
|
|
if (!file_path.empty() && file_path[0] == '/') {
|
|
file_path.erase(0, 1);
|
|
}
|
|
|
|
int gcode_file_count = Slic3r::GUI::wxGetApp().plater()->update_print_required_data(config, model, plate_data_list, file.name, file_path);
|
|
|
|
if (gcode_file_count > 0) {
|
|
wxPostEvent(Slic3r::GUI::wxGetApp().plater(), SimpleEvent(EVT_PRINT_FROM_SDCARD_VIEW));
|
|
}
|
|
else {
|
|
MessageDialog dlg(this, _L("The .gcode.3mf file contains no G-code data.Please slice it with Orca Slicer and export a new .gcode.3mf file."), wxEmptyString, wxICON_WARNING | wxOK);
|
|
auto res = dlg.ShowModal();
|
|
}
|
|
|
|
});
|
|
return;
|
|
}
|
|
}
|
|
if (index != -1) {
|
|
auto &file = fs->GetFile(index);
|
|
if (file.IsDownload() && file.DownloadProgress() >= -1) {
|
|
if (!file.local_path.empty()) {
|
|
if (!fs->DownloadCheckFile(index)) {
|
|
MessageDialog(this,
|
|
wxString::Format(_L("File '%s' was lost! Please download it again."), from_u8(file.name)),
|
|
_L("Error"), wxOK).ShowModal();
|
|
Refresh();
|
|
return;
|
|
}
|
|
#ifdef __WXMSW__
|
|
auto wfile = boost::filesystem::path(file.local_path).wstring();
|
|
SHELLEXECUTEINFO info{sizeof(info), 0, NULL, NULL, wfile.c_str(), L"", SW_HIDE};
|
|
::ShellExecuteEx(&info);
|
|
#else
|
|
wxShell("open " + file.local_path);
|
|
#endif
|
|
} else {
|
|
fs->DownloadCancel(index);
|
|
}
|
|
return;
|
|
}
|
|
}
|
|
fs->DownloadFiles(index, wxGetApp().app_config->get("download_path"));
|
|
} else if (action == 2) {
|
|
if (index != -1) {
|
|
auto &file = fs->GetFile(index);
|
|
if (file.IsDownload() && file.DownloadProgress() >= -1) {
|
|
if (!file.local_path.empty()) {
|
|
if (!fs->DownloadCheckFile(index)) {
|
|
MessageDialog(this,
|
|
wxString::Format(_L("File '%s' was lost! Please download it again."), from_u8(file.name)),
|
|
_L("Error"), wxOK).ShowModal();
|
|
Refresh();
|
|
return;
|
|
}
|
|
desktop_open_any_folder(file.local_path);
|
|
} else if (fs->GetFileType() == PrinterFileSystem::F_MODEL) {
|
|
fs->DownloadCancel(index);
|
|
}
|
|
return;
|
|
}
|
|
}
|
|
fs->DownloadFiles(index, wxGetApp().app_config->get("download_path"));
|
|
}
|
|
}
|
|
|
|
MediaFileFrame::MediaFileFrame(wxWindow* parent)
|
|
: DPIFrame(parent, wxID_ANY, "Media Files", wxDefaultPosition, { 1600, 900 })
|
|
{
|
|
m_panel = new MediaFilePanel(this);
|
|
wxBoxSizer * sizer = new wxBoxSizer(wxVERTICAL);
|
|
sizer->Add(m_panel, 1, wxEXPAND);
|
|
SetSizer(sizer);
|
|
|
|
Bind(wxEVT_CLOSE_WINDOW, [this](auto & e){
|
|
Hide();
|
|
e.Veto();
|
|
});
|
|
}
|
|
|
|
void MediaFileFrame::on_dpi_changed(const wxRect& suggested_rect) { m_panel->Rescale(); Refresh(); }
|
|
|
|
}}
|