mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 02:01:12 -06:00 
			
		
		
		
	Merge remote-tracking branch 'remotes/origin/vk-bugfixes'
This commit is contained in:
		
						commit
						241283d956
					
				
					 14 changed files with 530 additions and 131 deletions
				
			
		|  | @ -2,7 +2,9 @@ | |||
| #define slic3r_GLCanvas3D_hpp_ | ||||
| 
 | ||||
| #include <stddef.h> | ||||
| #include <memory> | ||||
| 
 | ||||
| #include "libslic3r/Technologies.hpp" | ||||
| #include "3DScene.hpp" | ||||
| #include "GLToolbar.hpp" | ||||
| #include "Event.hpp" | ||||
|  | @ -20,6 +22,9 @@ class wxTimerEvent; | |||
| class wxPaintEvent; | ||||
| class wxGLCanvas; | ||||
| 
 | ||||
| // Support for Retina OpenGL on Mac OS
 | ||||
| #define ENABLE_RETINA_GL __APPLE__ | ||||
| 
 | ||||
| class GLUquadric; | ||||
| typedef class GLUquadric GLUquadricObj; | ||||
| 
 | ||||
|  | @ -36,6 +41,10 @@ namespace GUI { | |||
| 
 | ||||
| class GLGizmoBase; | ||||
| 
 | ||||
| #if ENABLE_RETINA_GL | ||||
| class RetinaHelper; | ||||
| #endif | ||||
| 
 | ||||
| class GeometryBuffer | ||||
| { | ||||
|     std::vector<float> m_vertices; | ||||
|  | @ -55,16 +64,20 @@ class Size | |||
| { | ||||
|     int m_width; | ||||
|     int m_height; | ||||
|     float m_scale_factor; | ||||
| 
 | ||||
| public: | ||||
|     Size(); | ||||
|     Size(int width, int height); | ||||
|     Size(int width, int height, float scale_factor = 1.0); | ||||
| 
 | ||||
|     int get_width() const; | ||||
|     void set_width(int width); | ||||
| 
 | ||||
|     int get_height() const; | ||||
|     void set_height(int height); | ||||
| 
 | ||||
|     int get_scale_factor() const; | ||||
|     void set_scale_factor(int height); | ||||
| }; | ||||
| 
 | ||||
| class Rect | ||||
|  | @ -209,6 +222,8 @@ class GLCanvas3D | |||
|         mutable GLBed m_model; | ||||
| #endif // ENABLE_PRINT_BED_MODELS
 | ||||
| 
 | ||||
|         mutable float m_scale_factor; | ||||
| 
 | ||||
|     public: | ||||
|         Bed(); | ||||
| 
 | ||||
|  | @ -224,9 +239,9 @@ class GLCanvas3D | |||
|         Point point_projection(const Point& point) const; | ||||
| 
 | ||||
| #if ENABLE_PRINT_BED_MODELS | ||||
|         void render(float theta, bool useVBOs) const; | ||||
|         void render(float theta, bool useVBOs, float scale_factor) const; | ||||
| #else | ||||
|         void render(float theta) const; | ||||
|         void render(float theta, float scale_factor) const; | ||||
| #endif // ENABLE_PRINT_BED_MODELS
 | ||||
| 
 | ||||
|     private: | ||||
|  | @ -297,6 +312,9 @@ class GLCanvas3D | |||
|         }; | ||||
| 
 | ||||
|     private: | ||||
|         static const float THICKNESS_BAR_WIDTH; | ||||
|         static const float THICKNESS_RESET_BUTTON_HEIGHT; | ||||
| 
 | ||||
|         bool                        m_use_legacy_opengl; | ||||
|         bool                        m_enabled; | ||||
|         Shader                      m_shader; | ||||
|  | @ -380,6 +398,9 @@ class GLCanvas3D | |||
|         void _render_active_object_annotations(const GLCanvas3D& canvas, const Rect& bar_rect) const; | ||||
|         void _render_profile(const Rect& bar_rect) const; | ||||
|         void update_slicing_parameters(); | ||||
| 
 | ||||
|         static float thickness_bar_width(const GLCanvas3D &canvas); | ||||
|         static float reset_button_height(const GLCanvas3D &canvas); | ||||
|     }; | ||||
| 
 | ||||
|     struct Mouse | ||||
|  | @ -536,6 +557,8 @@ public: | |||
|         mutable GLArrow m_arrow; | ||||
|         mutable GLCurvedArrow m_curved_arrow; | ||||
| 
 | ||||
|         mutable float m_scale_factor; | ||||
| 
 | ||||
|     public: | ||||
|         Selection(); | ||||
| #if ENABLE_RENDER_SELECTION_CENTER | ||||
|  | @ -617,7 +640,7 @@ public: | |||
| 
 | ||||
|         void erase(); | ||||
| 
 | ||||
|         void render() const; | ||||
|         void render(float scale_factor = 1.0) const; | ||||
| #if ENABLE_RENDER_SELECTION_CENTER | ||||
|         void render_center() const; | ||||
| #endif // ENABLE_RENDER_SELECTION_CENTER
 | ||||
|  | @ -680,10 +703,6 @@ public: | |||
| private: | ||||
|     class Gizmos | ||||
|     { | ||||
|         static const float OverlayIconsScale; | ||||
|         static const float OverlayBorder; | ||||
|         static const float OverlayGapY; | ||||
| 
 | ||||
|     public: | ||||
|         enum EType : unsigned char | ||||
|         { | ||||
|  | @ -704,6 +723,10 @@ private: | |||
|         BackgroundTexture m_background_texture; | ||||
|         EType m_current; | ||||
| 
 | ||||
|         float m_overlay_icons_scale; | ||||
|         float m_overlay_border; | ||||
|         float m_overlay_gap_y; | ||||
| 
 | ||||
|     public: | ||||
|         Gizmos(); | ||||
|         ~Gizmos(); | ||||
|  | @ -713,6 +736,8 @@ private: | |||
|         bool is_enabled() const; | ||||
|         void set_enabled(bool enable); | ||||
| 
 | ||||
|         void set_overlay_scale(float scale); | ||||
| 
 | ||||
|         std::string update_hover_state(const GLCanvas3D& canvas, const Vec2d& mouse_pos, const Selection& selection); | ||||
|         void update_on_off_state(const GLCanvas3D& canvas, const Vec2d& mouse_pos, const Selection& selection); | ||||
|         void update_on_off_state(const Selection& selection); | ||||
|  | @ -802,7 +827,7 @@ private: | |||
|     public: | ||||
|         WarningTexture(); | ||||
| 
 | ||||
|         bool generate(const std::string& msg); | ||||
|         bool generate(const std::string& msg, const GLCanvas3D& canvas); | ||||
| 
 | ||||
|         void render(const GLCanvas3D& canvas) const; | ||||
|     }; | ||||
|  | @ -832,6 +857,9 @@ private: | |||
| 
 | ||||
|     wxGLCanvas* m_canvas; | ||||
|     wxGLContext* m_context; | ||||
| #if ENABLE_RETINA_GL | ||||
|     std::unique_ptr<RetinaHelper> m_retina_helper; | ||||
| #endif | ||||
|     bool m_in_render; | ||||
|     LegendTexture m_legend_texture; | ||||
|     WarningTexture m_warning_texture; | ||||
|  | @ -1030,6 +1058,8 @@ public: | |||
| 
 | ||||
|     void handle_sidebar_focus_event(const std::string& opt_key, bool focus_on); | ||||
| 
 | ||||
|     void update_ui_from_settings(); | ||||
| 
 | ||||
| private: | ||||
|     bool _is_shown_on_screen() const; | ||||
| #if !ENABLE_REWORKED_BED_SHAPE_CHANGE | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bubnikv
						bubnikv