mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-25 17:51:10 -06:00 
			
		
		
		
	New Export Finished notification showing path and opening containing folder. Fix of #4917. Fixed wrongly grayed eject button in File menu. Hopefully fix of ctrl shortcut of tooltips at sidebar.
This commit is contained in:
		
							parent
							
								
									729304c129
								
							
						
					
					
						commit
						3ca3a544a8
					
				
					 13 changed files with 552 additions and 92 deletions
				
			
		|  | @ -32,7 +32,11 @@ enum class NotificationType | |||
| 	SlicingComplete, | ||||
| //	SlicingNotPossible,
 | ||||
| 	// Notification on end of export to a removable media, with hyperling to eject the external media.
 | ||||
| 	ExportToRemovableFinished, | ||||
| 	// Obsolete by ExportFinished
 | ||||
| //	ExportToRemovableFinished,
 | ||||
| 	// Notification on end of export, with hyperling to see folder and eject if export was to external media.
 | ||||
| 	// Own subclass.
 | ||||
| 	ExportFinished, | ||||
| 	// Works on OSX only.
 | ||||
| 	//FIXME Do we want to have it on Linux and Windows? Is it possible to get the Disconnect event on Windows?
 | ||||
| 	Mouse3dDisconnected, | ||||
|  | @ -115,15 +119,21 @@ public: | |||
| 	// Called when the side bar changes its visibility, as the "slicing complete" notification supplements
 | ||||
| 	// the "slicing info" normally shown at the side bar.
 | ||||
| 	void set_slicing_complete_large(bool large); | ||||
| 	// Exporting finished, show this information with path, button to open containing folder and if ejectable - eject button
 | ||||
| 	void push_exporting_finished_notification(GLCanvas3D& canvas, std::string path, std::string dir_path, bool on_removable); | ||||
|     // Close old notification ExportFinished.
 | ||||
| 	void new_export_began(bool on_removable); | ||||
| 	// finds ExportFinished notification and closes it if it was to removable device
 | ||||
| 	void device_ejected(); | ||||
| 	// renders notifications in queue and deletes expired ones
 | ||||
| 	void render_notifications(GLCanvas3D& canvas, float overlay_width); | ||||
| 	// finds and closes all notifications of given type
 | ||||
| 	void close_notification_of_type(const NotificationType type); | ||||
| 	// Which view is active? Plater or G-code preview? Hide warnings in G-code preview.
 | ||||
|     void set_in_preview(bool preview); | ||||
| 	// Move to left to avoid colision with variable layer height gizmo
 | ||||
| 	// Move to left to avoid colision with variable layer height gizmo.
 | ||||
| 	void set_move_from_overlay(bool move) { m_move_from_overlay = move; } | ||||
| 
 | ||||
| 	 | ||||
| private: | ||||
| 	// duration 0 means not disapearing
 | ||||
| 	struct NotificationData { | ||||
|  | @ -169,7 +179,7 @@ private: | |||
| 		void                   close() { m_close_pending = true; } | ||||
| 		// data from newer notification of same type
 | ||||
| 		void                   update(const NotificationData& n); | ||||
| 		bool                   get_finished() const { return m_finished; } | ||||
| 		bool                   get_finished() const { return m_finished || m_close_pending; } | ||||
| 		// returns top after movement
 | ||||
| 		float                  get_top() const { return m_top_y; } | ||||
| 		//returns top in actual frame
 | ||||
|  | @ -187,25 +197,29 @@ private: | |||
| 	protected: | ||||
| 		// Call after every size change
 | ||||
| 		void         init(); | ||||
| 		// Part of init() 
 | ||||
| 		virtual void count_spaces(); | ||||
| 		// Calculetes correct size but not se it in imgui!
 | ||||
| 		virtual void set_next_window_size(ImGuiWrapper& imgui); | ||||
| 		virtual void render_text(ImGuiWrapper& imgui, | ||||
| 			                     const float win_size_x, const float win_size_y, | ||||
| 			                     const float win_pos_x , const float win_pos_y); | ||||
| 		void         render_close_button(ImGuiWrapper& imgui, | ||||
| 		virtual void render_close_button(ImGuiWrapper& imgui, | ||||
| 			                             const float win_size_x, const float win_size_y, | ||||
| 			                             const float win_pos_x , const float win_pos_y); | ||||
| 		void         render_countdown(ImGuiWrapper& imgui, | ||||
| 			                          const float win_size_x, const float win_size_y, | ||||
| 			                          const float win_pos_x , const float win_pos_y); | ||||
| 		void         render_hypertext(ImGuiWrapper& imgui, | ||||
| 		virtual void render_hypertext(ImGuiWrapper& imgui, | ||||
| 			                          const float text_x, const float text_y, | ||||
| 		                              const std::string text, | ||||
| 		                              bool more = false); | ||||
| 		// Left sign could be error or warning sign
 | ||||
| 		void         render_left_sign(ImGuiWrapper& imgui); | ||||
| 		void         render_minimize_button(ImGuiWrapper& imgui, | ||||
| 		virtual void render_minimize_button(ImGuiWrapper& imgui, | ||||
| 			                                const float win_pos_x, const float win_pos_y); | ||||
| 		void         on_text_click(); | ||||
| 		// Hypertext action, returns if close notification
 | ||||
| 		virtual bool on_text_click(); | ||||
| 
 | ||||
| 		const NotificationData m_data; | ||||
| 
 | ||||
|  | @ -236,7 +250,9 @@ private: | |||
| 		// Will go to m_finished next render
 | ||||
| 		bool             m_close_pending        { false };  | ||||
| 		// variables to count positions correctly
 | ||||
| 		// all space without text
 | ||||
| 		float            m_window_width_offset; | ||||
| 		// Space on left side without text
 | ||||
| 		float            m_left_indentation; | ||||
| 		// Total size of notification window - varies based on monitor
 | ||||
| 		float            m_window_height        { 56.0f };   | ||||
|  | @ -252,6 +268,8 @@ private: | |||
| 		bool             m_is_gray              { false }; | ||||
| 		//if multiline = true, notification is showing all lines(>2)
 | ||||
| 		bool             m_multiline            { false }; | ||||
| 		// True if minimized button is rendered, helps to decide where is area for invisible close button
 | ||||
| 		bool             m_minimize_b_visible   { false }; | ||||
| 		int              m_lines_count{ 1 }; | ||||
| 	    // Target for wxWidgets events sent by clicking on the hyperlink available at some notifications.
 | ||||
| 		wxEvtHandler*    m_evt_handler; | ||||
|  | @ -270,7 +288,6 @@ private: | |||
| 			                     const float win_size_x, const float win_size_y, | ||||
| 			                     const float win_pos_x, const float win_pos_y)  | ||||
| 			                     override; | ||||
| 
 | ||||
| 		bool        m_is_large; | ||||
| 		bool        m_has_print_info { false }; | ||||
| 		std::string m_print_info { std::string() }; | ||||
|  | @ -284,6 +301,40 @@ private: | |||
| 		int    		warning_step; | ||||
| 	}; | ||||
| 
 | ||||
| 	class ExportFinishedNotification : public PopNotification | ||||
| 	{ | ||||
| 	public: | ||||
| 		ExportFinishedNotification(const NotificationData& n, NotificationIDProvider& id_provider, wxEvtHandler* evt_handler, bool to_removable,const std::string& export_path,const std::string& export_dir_path) | ||||
| 			: PopNotification(n, id_provider, evt_handler) | ||||
| 			, m_to_removable(to_removable) | ||||
| 			, m_export_path(export_path) | ||||
| 			, m_export_dir_path(export_dir_path) | ||||
| 		    { | ||||
| 				m_multiline = true; | ||||
| 			} | ||||
| 		bool        m_to_removable; | ||||
| 		std::string m_export_path; | ||||
| 		std::string m_export_dir_path; | ||||
| 	protected: | ||||
| 		// Reserves space on right for more buttons
 | ||||
| 		virtual void count_spaces() override; | ||||
| 		virtual void render_text(ImGuiWrapper& imgui, | ||||
| 			                     const float win_size_x, const float win_size_y, | ||||
| 			                     const float win_pos_x, const float win_pos_y) override; | ||||
| 		// Renders also button to open directory with exported path and eject removable media
 | ||||
| 		virtual void render_close_button(ImGuiWrapper& imgui, | ||||
| 			                             const float win_size_x, const float win_size_y, | ||||
| 			                             const float win_pos_x, const float win_pos_y) override; | ||||
| 		void         render_eject_button(ImGuiWrapper& imgui, | ||||
| 			                             const float win_size_x, const float win_size_y, | ||||
| 			                             const float win_pos_x, const float win_pos_y); | ||||
| 		virtual void render_minimize_button(ImGuiWrapper& imgui, const float win_pos_x, const float win_pos_y) override  | ||||
| 			{ m_minimize_b_visible = false; } | ||||
| 		virtual bool on_text_click() override;  | ||||
| 		// local time of last hover for showing tooltip
 | ||||
| 		long      m_hover_time { 0 }; | ||||
| 	}; | ||||
| 
 | ||||
| 	//pushes notification into the queue of notifications that are rendered
 | ||||
| 	//can be used to create custom notification
 | ||||
| 	bool push_notification_data(const NotificationData& notification_data, GLCanvas3D& canvas, int timestamp); | ||||
|  | @ -314,7 +365,7 @@ private: | |||
| 	//prepared (basic) notifications
 | ||||
| 	const std::vector<NotificationData> basic_notifications = { | ||||
| //		{NotificationType::SlicingNotPossible, NotificationLevel::RegularNotification, 10,  _u8L("Slicing is not possible.")},
 | ||||
| 		{NotificationType::ExportToRemovableFinished, NotificationLevel::ImportantNotification, 0,  _u8L("Exporting finished."),  _u8L("Eject drive.") }, | ||||
| //		{NotificationType::ExportToRemovableFinished, NotificationLevel::ImportantNotification, 0,  _u8L("Exporting finished."),  _u8L("Eject drive.") },
 | ||||
| 		{NotificationType::Mouse3dDisconnected, NotificationLevel::RegularNotification, 10,  _u8L("3D Mouse disconnected.") }, | ||||
| //		{NotificationType::Mouse3dConnected, NotificationLevel::RegularNotification, 5,  _u8L("3D Mouse connected.") },
 | ||||
| //		{NotificationType::NewPresetsAviable, NotificationLevel::ImportantNotification, 20,  _u8L("New Presets are available."),  _u8L("See here.") },
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 David Kocik
						David Kocik