mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-22 08:11:11 -06:00 
			
		
		
		
	Fixed opengl initialization on linux
This commit is contained in:
		
							parent
							
								
									af8e869880
								
							
						
					
					
						commit
						9729c71691
					
				
					 6 changed files with 0 additions and 90 deletions
				
			
		|  | @ -1758,16 +1758,10 @@ void _3DScene::remove_all_canvases() | |||
|     s_canvas_mgr.remove_all(); | ||||
| } | ||||
| 
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
| bool _3DScene::init(wxGLCanvas* canvas) | ||||
| { | ||||
|     return s_canvas_mgr.init(canvas); | ||||
| } | ||||
| //bool _3DScene::init(wxGLCanvas* canvas, bool useVBOs)
 | ||||
| //{
 | ||||
| //    return s_canvas_mgr.init(canvas, useVBOs);
 | ||||
| //}
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
| 
 | ||||
| bool _3DScene::is_shown_on_screen(wxGLCanvas* canvas) | ||||
| { | ||||
|  |  | |||
|  | @ -545,10 +545,7 @@ public: | |||
|     static bool remove_canvas(wxGLCanvas* canvas); | ||||
|     static void remove_all_canvases(); | ||||
| 
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
|     static bool init(wxGLCanvas* canvas); | ||||
| //    static bool init(wxGLCanvas* canvas, bool useVBOs);
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
| 
 | ||||
|     static bool is_shown_on_screen(wxGLCanvas* canvas); | ||||
| 
 | ||||
|  |  | |||
|  | @ -943,10 +943,7 @@ GLCanvas3D::GLCanvas3D(wxGLCanvas* canvas, wxGLContext* context) | |||
|     , m_print(nullptr) | ||||
|     , m_dirty(true) | ||||
|     , m_use_VBOs(false) | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
|     , m_first_render(true) | ||||
| //    , m_late_init(false)
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
|     , m_apply_zoom_to_volumes_filter(false) | ||||
|     , m_hover_volume_id(-1) | ||||
|     , m_warning_texture_enabled(false) | ||||
|  | @ -973,11 +970,6 @@ GLCanvas3D::~GLCanvas3D() | |||
| 
 | ||||
| bool GLCanvas3D::init(bool useVBOs, bool use_legacy_opengl) | ||||
| { | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
| //    if (!set_current())
 | ||||
| //        return false;
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
| 
 | ||||
|     ::glClearColor(1.0f, 1.0f, 1.0f, 1.0f); | ||||
|     ::glClearDepth(1.0f); | ||||
| 
 | ||||
|  | @ -1027,17 +1019,6 @@ bool GLCanvas3D::init(bool useVBOs, bool use_legacy_opengl) | |||
|     if (useVBOs && !m_layers_editing.init("variable_layer_height.vs", "variable_layer_height.fs")) | ||||
|         return false; | ||||
| 
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
|     // This is a special path for wxWidgets on GTK, where an OpenGL context is initialized
 | ||||
|     // first when an OpenGL widget is shown for the first time. How ugly.
 | ||||
|     // In that case the volumes are wainting to be moved to Vertex Buffer Objects
 | ||||
|     // after the OpenGL context is being initialized.
 | ||||
| #if defined(__LINUX__) | ||||
|     if (useVBOs && (m_volumes != nullptr)) | ||||
|         m_volumes->finalize_geometry(useVBOs); | ||||
| #endif // __LINUX__
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
| 
 | ||||
|     m_use_VBOs = useVBOs; | ||||
|     m_layers_editing.set_use_legacy_opengl(use_legacy_opengl); | ||||
| 
 | ||||
|  | @ -1285,17 +1266,11 @@ void GLCanvas3D::render() | |||
|     if (!set_current()) | ||||
|         return; | ||||
| 
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
|     if (!_3DScene::init(m_canvas)) | ||||
|         return; | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
| 
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
|     if (m_first_render) | ||||
|         _before_first_render(); | ||||
| //    if (!m_late_init)
 | ||||
| //        _late_init();
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
| 
 | ||||
|     _camera_tranform(); | ||||
| 
 | ||||
|  | @ -1749,27 +1724,10 @@ Point GLCanvas3D::get_local_mouse_position() const | |||
|     return Point(mouse_pos.x, mouse_pos.y); | ||||
| } | ||||
| 
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
| void GLCanvas3D::_before_first_render() | ||||
| //void GLCanvas3D::_late_init()
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
| { | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
| //    // This is a special path for wxWidgets on GTK, where an OpenGL context is initialized
 | ||||
| //    // first when an OpenGL widget is shown for the first time. How ugly.
 | ||||
| //    // In that case the volumes are wainting to be moved to Vertex Buffer Objects
 | ||||
| //    // after the OpenGL context is being initialized.
 | ||||
| //#if defined(__LINUX__)
 | ||||
| //    if (m_use_VBOs && (m_volumes != nullptr))
 | ||||
| //        m_volumes->finalize_geometry(m_use_VBOs);
 | ||||
| //#endif // __LINUX__
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
| 
 | ||||
|     zoom_to_bed(); | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
|     m_first_render = false; | ||||
| //    m_late_init = true;
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
| } | ||||
| 
 | ||||
| void GLCanvas3D::_resize(unsigned int w, unsigned int h) | ||||
|  |  | |||
|  | @ -303,10 +303,7 @@ private: | |||
| 
 | ||||
|     bool m_dirty; | ||||
|     bool m_use_VBOs; | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
|     bool m_first_render; | ||||
| //    bool m_late_init;
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
|     bool m_apply_zoom_to_volumes_filter; | ||||
|     mutable int m_hover_volume_id; | ||||
|     bool m_warning_texture_enabled; | ||||
|  | @ -398,10 +395,7 @@ public: | |||
|     Point get_local_mouse_position() const; | ||||
| 
 | ||||
| private: | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
|     void _before_first_render(); | ||||
| //    void _late_init();
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
| 
 | ||||
|     void _resize(unsigned int w, unsigned int h); | ||||
| 
 | ||||
|  |  | |||
|  | @ -138,21 +138,6 @@ bool GLCanvas3DManager::add(wxGLCanvas* canvas, wxGLContext* context) | |||
|     if (canvas3D == nullptr) | ||||
|         return false; | ||||
| 
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
| //    if (!m_gl_initialized)
 | ||||
| //    {
 | ||||
| //        canvas3D->set_current();
 | ||||
| //        init_gl();
 | ||||
| //    }
 | ||||
| //
 | ||||
| //    if (!canvas3D->init(m_use_VBOs, m_use_legacy_opengl))
 | ||||
| //    {
 | ||||
| //        delete canvas3D;
 | ||||
| //        canvas3D = nullptr;
 | ||||
| //        return false;
 | ||||
| //    }
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
| 
 | ||||
|     canvas->Bind(wxEVT_SIZE, [canvas3D](wxSizeEvent& evt) { canvas3D->on_size(evt); }); | ||||
|     canvas->Bind(wxEVT_IDLE, [canvas3D](wxIdleEvent& evt) { canvas3D->on_idle(evt); }); | ||||
|     canvas->Bind(wxEVT_CHAR, [canvas3D](wxKeyEvent& evt)  { canvas3D->on_char(evt); }); | ||||
|  | @ -241,7 +226,6 @@ bool GLCanvas3DManager::use_VBOs() const | |||
|     return m_use_VBOs; | ||||
| } | ||||
| 
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
| bool GLCanvas3DManager::init(wxGLCanvas* canvas) | ||||
| { | ||||
|     CanvasesMap::const_iterator it = _get_canvas(canvas); | ||||
|  | @ -251,13 +235,6 @@ bool GLCanvas3DManager::init(wxGLCanvas* canvas) | |||
|         return false; | ||||
| } | ||||
| 
 | ||||
| //bool GLCanvas3DManager::init(wxGLCanvas* canvas, bool useVBOs)
 | ||||
| //{
 | ||||
| //    CanvasesMap::const_iterator it = _get_canvas(canvas);
 | ||||
| //    return (it != m_canvases.end()) ? it->second->init(useVBOs, m_use_legacy_opengl) : false;
 | ||||
| //}
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
| 
 | ||||
| bool GLCanvas3DManager::is_shown_on_screen(wxGLCanvas* canvas) const | ||||
| { | ||||
|     CanvasesMap::const_iterator it = _get_canvas(canvas); | ||||
|  | @ -505,18 +482,13 @@ GLCanvas3DManager::CanvasesMap::const_iterator GLCanvas3DManager::_get_canvas(wx | |||
|     return (canvas == nullptr) ? m_canvases.end() : m_canvases.find(canvas); | ||||
| } | ||||
| 
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
| bool GLCanvas3DManager::_init(GLCanvas3D& canvas) | ||||
| { | ||||
|     if (!m_gl_initialized) | ||||
|     { | ||||
| //        canvas.set_current();
 | ||||
|         init_gl(); | ||||
|     } | ||||
| 
 | ||||
|     return canvas.init(m_use_VBOs, m_use_legacy_opengl); | ||||
| } | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
| 
 | ||||
| } // namespace GUI
 | ||||
| } // namespace Slic3r
 | ||||
|  |  | |||
|  | @ -49,10 +49,7 @@ public: | |||
|     bool use_VBOs() const; | ||||
|     bool layer_editing_allowed() const; | ||||
| 
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
|     bool init(wxGLCanvas* canvas); | ||||
| //    bool init(wxGLCanvas* canvas, bool useVBOs);
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
| 
 | ||||
|     bool is_shown_on_screen(wxGLCanvas* canvas) const; | ||||
| 
 | ||||
|  | @ -105,9 +102,7 @@ private: | |||
|     CanvasesMap::iterator _get_canvas(wxGLCanvas* canvas); | ||||
|     CanvasesMap::const_iterator _get_canvas(wxGLCanvas* canvas) const; | ||||
| 
 | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
|     bool _init(GLCanvas3D& canvas); | ||||
| //@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
 | ||||
| }; | ||||
| 
 | ||||
| } // namespace GUI
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Enrico Turri
						Enrico Turri