mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 10:11:10 -06:00 
			
		
		
		
	Finished picking by color with a checksum in the alpha channel
to guard against unwanted alpha blending and / or multi sampling.
This commit is contained in:
		
							parent
							
								
									2ad3c05a65
								
							
						
					
					
						commit
						2d7f478dac
					
				
					 10 changed files with 89 additions and 74 deletions
				
			
		|  | @ -3753,19 +3753,6 @@ void GLCanvas3D::_refresh_if_shown_on_screen() | |||
|     } | ||||
| } | ||||
| 
 | ||||
| static inline unsigned char picking_checksum(unsigned char red, unsigned char green, unsigned char blue) | ||||
| { | ||||
| 	// 8 bit hash for the color
 | ||||
| 	unsigned char b = ((((37 * red) + green) & 0x0ff) * 37 + blue) & 0x0ff; | ||||
| 	// Increase enthropy by a bit reversal
 | ||||
| 	b = (b & 0xF0) >> 4 | (b & 0x0F) << 4; | ||||
| 	b = (b & 0xCC) >> 2 | (b & 0x33) << 2; | ||||
| 	b = (b & 0xAA) >> 1 | (b & 0x55) << 1; | ||||
| 	// Flip every second bit to increase the enthropy even more.
 | ||||
| 	b ^= 0x55; | ||||
| 	return b; | ||||
| } | ||||
| 
 | ||||
| void GLCanvas3D::_picking_pass() const | ||||
| { | ||||
|     if (m_picking_enabled && !m_mouse.dragging && (m_mouse.position != Vec2d(DBL_MAX, DBL_MAX))) | ||||
|  | @ -3807,7 +3794,7 @@ void GLCanvas3D::_picking_pass() const | |||
|         if (inside) | ||||
|         { | ||||
|             glsafe(::glReadPixels(m_mouse.position(0), cnv_size.get_height() - m_mouse.position(1) - 1, 1, 1, GL_RGBA, GL_UNSIGNED_BYTE, (void*)color)); | ||||
|             if (picking_checksum(color[0], color[1], color[2]) == color[3]) | ||||
|             if (picking_checksum_alpha_channel(color[0], color[1], color[2]) == color[3]) | ||||
|             	// Only non-interpolated colors are valid, those have their lowest three bits zeroed.
 | ||||
|             	volume_id = color[0] + (color[1] << 8) + (color[2] << 16); | ||||
|         } | ||||
|  | @ -3859,7 +3846,7 @@ void GLCanvas3D::_rectangular_selection_picking_pass() const | |||
|             { | ||||
|                 std::array<GLubyte, 4> data; | ||||
|             	// Only non-interpolated colors are valid, those have their lowest three bits zeroed.
 | ||||
|                 bool valid() const { return picking_checksum(data[0], data[1], data[2]) == data[3]; } | ||||
|                 bool valid() const { return picking_checksum_alpha_channel(data[0], data[1], data[2]) == data[3]; } | ||||
|                 int id() const { return data[0] + (data[1] << 8) + (data[2] << 16); } | ||||
|             }; | ||||
| 
 | ||||
|  | @ -4070,7 +4057,7 @@ void GLCanvas3D::_render_volumes_for_picking() const | |||
| 		        unsigned int r = (id & (0x000000FF << 0)) << 0; | ||||
| 		        unsigned int g = (id & (0x000000FF << 8)) >> 8; | ||||
| 		        unsigned int b = (id & (0x000000FF << 16)) >> 16; | ||||
| 		        unsigned int a = picking_checksum(r, g, b); | ||||
| 		        unsigned int a = picking_checksum_alpha_channel(r, g, b); | ||||
| 		        glsafe(::glColor4f((GLfloat)r * INV_255, (GLfloat)g * INV_255, (GLfloat)b * INV_255, (GLfloat)a * INV_255)); | ||||
| 	            volume.first->render(); | ||||
| 	        } | ||||
|  |  | |||
|  | @ -29,19 +29,21 @@ GLGizmoBase::Grabber::Grabber() | |||
|     color[0] = 1.0f; | ||||
|     color[1] = 1.0f; | ||||
|     color[2] = 1.0f; | ||||
|     color[3] = 1.0f; | ||||
| } | ||||
| 
 | ||||
| void GLGizmoBase::Grabber::render(bool hover, float size) const | ||||
| { | ||||
|     float render_color[3]; | ||||
|     float render_color[4]; | ||||
|     if (hover) | ||||
|     { | ||||
|         render_color[0] = 1.0f - color[0]; | ||||
|         render_color[1] = 1.0f - color[1]; | ||||
|         render_color[2] = 1.0f - color[2]; | ||||
|         render_color[3] = color[3]; | ||||
|     } | ||||
|     else | ||||
|         ::memcpy((void*)render_color, (const void*)color, 3 * sizeof(float)); | ||||
|         ::memcpy((void*)render_color, (const void*)color, 4 * sizeof(float)); | ||||
| 
 | ||||
|     render(size, render_color, true); | ||||
| } | ||||
|  | @ -63,7 +65,7 @@ void GLGizmoBase::Grabber::render(float size, const float* render_color, bool us | |||
|     if (use_lighting) | ||||
|         glsafe(::glEnable(GL_LIGHTING)); | ||||
| 
 | ||||
|     glsafe(::glColor3fv(render_color)); | ||||
|     glsafe(::glColor4fv(render_color)); | ||||
| 
 | ||||
|     glsafe(::glPushMatrix()); | ||||
|     glsafe(::glTranslated(center(0), center(1), center(2))); | ||||
|  | @ -144,9 +146,9 @@ GLGizmoBase::GLGizmoBase(GLCanvas3D& parent, const std::string& icon_filename, u | |||
|     , m_dragging(false) | ||||
|     , m_imgui(wxGetApp().imgui()) | ||||
| { | ||||
|     ::memcpy((void*)m_base_color, (const void*)DEFAULT_BASE_COLOR, 3 * sizeof(float)); | ||||
|     ::memcpy((void*)m_drag_color, (const void*)DEFAULT_DRAG_COLOR, 3 * sizeof(float)); | ||||
|     ::memcpy((void*)m_highlight_color, (const void*)DEFAULT_HIGHLIGHT_COLOR, 3 * sizeof(float)); | ||||
|     ::memcpy((void*)m_base_color, (const void*)DEFAULT_BASE_COLOR, 4 * sizeof(float)); | ||||
|     ::memcpy((void*)m_drag_color, (const void*)DEFAULT_DRAG_COLOR, 4 * sizeof(float)); | ||||
|     ::memcpy((void*)m_highlight_color, (const void*)DEFAULT_HIGHLIGHT_COLOR, 4 * sizeof(float)); | ||||
| } | ||||
| 
 | ||||
| void GLGizmoBase::set_hover_id(int id) | ||||
|  | @ -161,7 +163,7 @@ void GLGizmoBase::set_hover_id(int id) | |||
| void GLGizmoBase::set_highlight_color(const float* color) | ||||
| { | ||||
|     if (color != nullptr) | ||||
|         ::memcpy((void*)m_highlight_color, (const void*)color, 3 * sizeof(float)); | ||||
|         ::memcpy((void*)m_highlight_color, (const void*)color, 4 * sizeof(float)); | ||||
| } | ||||
| 
 | ||||
| void GLGizmoBase::enable_grabber(unsigned int id) | ||||
|  | @ -210,7 +212,7 @@ void GLGizmoBase::update(const UpdateData& data) | |||
|         on_update(data); | ||||
| } | ||||
| 
 | ||||
| std::array<float, 3> GLGizmoBase::picking_color_component(unsigned int id) const | ||||
| std::array<float, 4> GLGizmoBase::picking_color_component(unsigned int id) const | ||||
| { | ||||
|     static const float INV_255 = 1.0f / 255.0f; | ||||
| 
 | ||||
|  | @ -220,9 +222,12 @@ std::array<float, 3> GLGizmoBase::picking_color_component(unsigned int id) const | |||
|         id -= m_group_id; | ||||
| 
 | ||||
|     // color components are encoded to match the calculation of volume_id made into GLCanvas3D::_picking_pass()
 | ||||
|     return std::array<float, 3> { (float)((id >> 0) & 0xff) * INV_255, // red
 | ||||
|                                   (float)((id >> 8) & 0xff) * INV_255, // green
 | ||||
|                                   (float)((id >> 16) & 0xff) * INV_255 }; // blue
 | ||||
|     return std::array<float, 4> {  | ||||
| 		float((id >> 0) & 0xff) * INV_255, // red
 | ||||
| 		float((id >> 8) & 0xff) * INV_255, // green
 | ||||
| 		float((id >> 16) & 0xff) * INV_255, // blue
 | ||||
| 		float(picking_checksum_alpha_channel(id & 0xff, (id >> 8) & 0xff, (id >> 16) & 0xff))* INV_255 // checksum for validating against unwanted alpha blending and multi sampling
 | ||||
| 	}; | ||||
| } | ||||
| 
 | ||||
| void GLGizmoBase::render_grabbers(const BoundingBoxf3& box) const | ||||
|  | @ -247,10 +252,11 @@ void GLGizmoBase::render_grabbers_for_picking(const BoundingBoxf3& box) const | |||
|     { | ||||
|         if (m_grabbers[i].enabled) | ||||
|         { | ||||
|             std::array<float, 3> color = picking_color_component(i); | ||||
|             std::array<float, 4> color = picking_color_component(i); | ||||
|             m_grabbers[i].color[0] = color[0]; | ||||
|             m_grabbers[i].color[1] = color[1]; | ||||
|             m_grabbers[i].color[2] = color[2]; | ||||
|             m_grabbers[i].color[3] = color[3]; | ||||
|             m_grabbers[i].render_for_picking(mean_size); | ||||
|         } | ||||
|     } | ||||
|  | @ -267,5 +273,20 @@ std::string GLGizmoBase::format(float value, unsigned int decimals) const | |||
|     return Slic3r::string_printf("%.*f", decimals, value); | ||||
| } | ||||
| 
 | ||||
| // Produce an alpha channel checksum for the red green blue components. The alpha channel may then be used to verify, whether the rgb components
 | ||||
| // were not interpolated by alpha blending or multi sampling.
 | ||||
| unsigned char picking_checksum_alpha_channel(unsigned char red, unsigned char green, unsigned char blue) | ||||
| { | ||||
| 	// 8 bit hash for the color
 | ||||
| 	unsigned char b = ((((37 * red) + green) & 0x0ff) * 37 + blue) & 0x0ff; | ||||
| 	// Increase enthropy by a bit reversal
 | ||||
| 	b = (b & 0xF0) >> 4 | (b & 0x0F) << 4; | ||||
| 	b = (b & 0xCC) >> 2 | (b & 0x33) << 2; | ||||
| 	b = (b & 0xAA) >> 1 | (b & 0x55) << 1; | ||||
| 	// Flip every second bit to increase the enthropy even more.
 | ||||
| 	b ^= 0x55; | ||||
| 	return b; | ||||
| } | ||||
| 
 | ||||
| } // namespace GUI
 | ||||
| } // namespace Slic3r
 | ||||
|  |  | |||
|  | @ -21,11 +21,11 @@ class ModelObject; | |||
| 
 | ||||
| namespace GUI { | ||||
| 
 | ||||
| static const float DEFAULT_BASE_COLOR[3] = { 0.625f, 0.625f, 0.625f }; | ||||
| static const float DEFAULT_DRAG_COLOR[3] = { 1.0f, 1.0f, 1.0f }; | ||||
| static const float DEFAULT_HIGHLIGHT_COLOR[3] = { 1.0f, 0.38f, 0.0f }; | ||||
| static const float AXES_COLOR[3][3] = { { 0.75f, 0.0f, 0.0f }, { 0.0f, 0.75f, 0.0f }, { 0.0f, 0.0f, 0.75f } }; | ||||
| static const float CONSTRAINED_COLOR[3] = { 0.5f, 0.5f, 0.5f }; | ||||
| static const float DEFAULT_BASE_COLOR[4] = { 0.625f, 0.625f, 0.625f, 1.0f }; | ||||
| static const float DEFAULT_DRAG_COLOR[4] = { 1.0f, 1.0f, 1.0f, 1.0f }; | ||||
| static const float DEFAULT_HIGHLIGHT_COLOR[4] = { 1.0f, 0.38f, 0.0f, 1.0f }; | ||||
| static const float AXES_COLOR[][4] = { { 0.75f, 0.0f, 0.0f, 1.0f }, { 0.0f, 0.75f, 0.0f, 1.0f }, { 0.0f, 0.0f, 0.75f, 1.0f } }; | ||||
| static const float CONSTRAINED_COLOR[4] = { 0.5f, 0.5f, 0.5f, 1.0f }; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
|  | @ -48,7 +48,7 @@ protected: | |||
| 
 | ||||
|         Vec3d center; | ||||
|         Vec3d angles; | ||||
|         float color[3]; | ||||
|         float color[4]; | ||||
|         bool enabled; | ||||
|         bool dragging; | ||||
| 
 | ||||
|  | @ -94,9 +94,9 @@ protected: | |||
|     unsigned int m_sprite_id; | ||||
|     int m_hover_id; | ||||
|     bool m_dragging; | ||||
|     float m_base_color[3]; | ||||
|     float m_drag_color[3]; | ||||
|     float m_highlight_color[3]; | ||||
|     float m_base_color[4]; | ||||
|     float m_drag_color[4]; | ||||
|     float m_highlight_color[4]; | ||||
|     mutable std::vector<Grabber> m_grabbers; | ||||
|     ImGuiWrapper* m_imgui; | ||||
| 
 | ||||
|  | @ -166,7 +166,7 @@ protected: | |||
| 
 | ||||
|     // Returns the picking color for the given id, based on the BASE_ID constant
 | ||||
|     // No check is made for clashing with other picking color (i.e. GLVolumes)
 | ||||
|     std::array<float, 3> picking_color_component(unsigned int id) const; | ||||
|     std::array<float, 4> picking_color_component(unsigned int id) const; | ||||
|     void render_grabbers(const BoundingBoxf3& box) const; | ||||
|     void render_grabbers(float size) const; | ||||
|     void render_grabbers_for_picking(const BoundingBoxf3& box) const; | ||||
|  | @ -175,6 +175,10 @@ protected: | |||
|     std::string format(float value, unsigned int decimals) const; | ||||
| }; | ||||
| 
 | ||||
| // Produce an alpha channel checksum for the red green blue components. The alpha channel may then be used to verify, whether the rgb components
 | ||||
| // were not interpolated by alpha blending or multi sampling.
 | ||||
| extern unsigned char picking_checksum_alpha_channel(unsigned char red, unsigned char green, unsigned char blue); | ||||
| 
 | ||||
| } // namespace GUI
 | ||||
| } // namespace Slic3r
 | ||||
| 
 | ||||
|  |  | |||
|  | @ -17,7 +17,7 @@ namespace GUI { | |||
| 
 | ||||
| const double GLGizmoCut::Offset = 10.0; | ||||
| const double GLGizmoCut::Margin = 20.0; | ||||
| const std::array<float, 3> GLGizmoCut::GrabberColor = { 1.0, 0.5, 0.0 }; | ||||
| const std::array<float, 4> GLGizmoCut::GrabberColor = { 1.0, 0.5, 0.0, 1.0 }; | ||||
| 
 | ||||
| GLGizmoCut::GLGizmoCut(GLCanvas3D& parent, const std::string& icon_filename, unsigned int sprite_id) | ||||
|     : GLGizmoBase(parent, icon_filename, sprite_id) | ||||
|  |  | |||
|  | @ -11,7 +11,7 @@ class GLGizmoCut : public GLGizmoBase | |||
| { | ||||
|     static const double Offset; | ||||
|     static const double Margin; | ||||
|     static const std::array<float, 3> GrabberColor; | ||||
|     static const std::array<float, 4> GrabberColor; | ||||
| 
 | ||||
|     mutable double m_cut_z; | ||||
|     double m_start_z; | ||||
|  |  | |||
|  | @ -115,7 +115,7 @@ void GLGizmoFlatten::on_render_for_picking() const | |||
| 			const_cast<GLGizmoFlatten*>(this)->update_planes(); | ||||
|         for (int i = 0; i < (int)m_planes.size(); ++i) | ||||
|         { | ||||
|             glsafe(::glColor3fv(picking_color_component(i).data())); | ||||
|             glsafe(::glColor4fv(picking_color_component(i).data())); | ||||
|             ::glBegin(GL_POLYGON); | ||||
|             for (const Vec3d& vertex : m_planes[i].vertices) | ||||
|             { | ||||
|  |  | |||
|  | @ -104,15 +104,15 @@ void GLGizmoMove3D::on_render() const | |||
| 
 | ||||
|     // x axis
 | ||||
|     m_grabbers[0].center = Vec3d(box.max(0) + Offset, center(1), center(2)); | ||||
|     ::memcpy((void*)m_grabbers[0].color, (const void*)&AXES_COLOR[0], 3 * sizeof(float)); | ||||
|     ::memcpy((void*)m_grabbers[0].color, (const void*)&AXES_COLOR[0], 4 * sizeof(float)); | ||||
| 
 | ||||
|     // y axis
 | ||||
|     m_grabbers[1].center = Vec3d(center(0), box.max(1) + Offset, center(2)); | ||||
|     ::memcpy((void*)m_grabbers[1].color, (const void*)&AXES_COLOR[1], 3 * sizeof(float)); | ||||
|     ::memcpy((void*)m_grabbers[1].color, (const void*)&AXES_COLOR[1], 4 * sizeof(float)); | ||||
| 
 | ||||
|     // z axis
 | ||||
|     m_grabbers[2].center = Vec3d(center(0), center(1), box.max(2) + Offset); | ||||
|     ::memcpy((void*)m_grabbers[2].color, (const void*)&AXES_COLOR[2], 3 * sizeof(float)); | ||||
|     ::memcpy((void*)m_grabbers[2].color, (const void*)&AXES_COLOR[2], 4 * sizeof(float)); | ||||
| 
 | ||||
|     glsafe(::glLineWidth((m_hover_id != -1) ? 2.0f : 1.5f)); | ||||
| 
 | ||||
|  | @ -123,7 +123,7 @@ void GLGizmoMove3D::on_render() const | |||
|         { | ||||
|             if (m_grabbers[i].enabled) | ||||
|             { | ||||
|                 glsafe(::glColor3fv(AXES_COLOR[i])); | ||||
|                 glsafe(::glColor4fv(AXES_COLOR[i])); | ||||
|                 ::glBegin(GL_LINES); | ||||
|                 ::glVertex3dv(center.data()); | ||||
|                 ::glVertex3dv(m_grabbers[i].center.data()); | ||||
|  | @ -142,7 +142,7 @@ void GLGizmoMove3D::on_render() const | |||
|     else | ||||
|     { | ||||
|         // draw axis
 | ||||
|         glsafe(::glColor3fv(AXES_COLOR[m_hover_id])); | ||||
|         glsafe(::glColor4fv(AXES_COLOR[m_hover_id])); | ||||
|         ::glBegin(GL_LINES); | ||||
|         ::glVertex3dv(center.data()); | ||||
|         ::glVertex3dv(m_grabbers[m_hover_id].center.data()); | ||||
|  | @ -220,19 +220,20 @@ void GLGizmoMove3D::render_grabber_extension(Axis axis, const BoundingBoxf3& box | |||
|     float mean_size = (float)((box.size()(0) + box.size()(1) + box.size()(2)) / 3.0); | ||||
|     double size = m_dragging ? (double)m_grabbers[axis].get_dragging_half_size(mean_size) : (double)m_grabbers[axis].get_half_size(mean_size); | ||||
| 
 | ||||
|     float color[3]; | ||||
|     ::memcpy((void*)color, (const void*)m_grabbers[axis].color, 3 * sizeof(float)); | ||||
|     float color[4]; | ||||
|     ::memcpy((void*)color, (const void*)m_grabbers[axis].color, 4 * sizeof(float)); | ||||
|     if (!picking && (m_hover_id != -1)) | ||||
|     { | ||||
|         color[0] = 1.0f - color[0]; | ||||
|         color[1] = 1.0f - color[1]; | ||||
|         color[2] = 1.0f - color[2]; | ||||
|         color[3] = color[3]; | ||||
|     } | ||||
| 
 | ||||
|     if (!picking) | ||||
|         glsafe(::glEnable(GL_LIGHTING)); | ||||
| 
 | ||||
|     glsafe(::glColor3fv(color)); | ||||
|     glsafe(::glColor4fv(color)); | ||||
|     glsafe(::glPushMatrix()); | ||||
|     glsafe(::glTranslated(m_grabbers[axis].center(0), m_grabbers[axis].center(1), m_grabbers[axis].center(2))); | ||||
|     if (axis == X) | ||||
|  |  | |||
|  | @ -155,7 +155,7 @@ void GLGizmoRotate::on_render() const | |||
|     transform_to_local(selection); | ||||
| 
 | ||||
|     glsafe(::glLineWidth((m_hover_id != -1) ? 2.0f : 1.5f)); | ||||
|     glsafe(::glColor3fv((m_hover_id != -1) ? m_drag_color : m_highlight_color)); | ||||
|     glsafe(::glColor4fv((m_hover_id != -1) ? m_drag_color : m_highlight_color)); | ||||
| 
 | ||||
|     render_circle(); | ||||
| 
 | ||||
|  | @ -166,7 +166,7 @@ void GLGizmoRotate::on_render() const | |||
|         render_reference_radius(); | ||||
|     } | ||||
| 
 | ||||
|     glsafe(::glColor3fv(m_highlight_color)); | ||||
|     glsafe(::glColor4fv(m_highlight_color)); | ||||
| 
 | ||||
|     if (m_hover_id != -1) | ||||
|         render_angle(); | ||||
|  | @ -287,14 +287,14 @@ void GLGizmoRotate::render_grabber(const BoundingBoxf3& box) const | |||
|     m_grabbers[0].center = Vec3d(::cos(m_angle) * grabber_radius, ::sin(m_angle) * grabber_radius, 0.0); | ||||
|     m_grabbers[0].angles(2) = m_angle; | ||||
| 
 | ||||
|     glsafe(::glColor3fv((m_hover_id != -1) ? m_drag_color : m_highlight_color)); | ||||
|     glsafe(::glColor4fv((m_hover_id != -1) ? m_drag_color : m_highlight_color)); | ||||
| 
 | ||||
|     ::glBegin(GL_LINES); | ||||
|     ::glVertex3f(0.0f, 0.0f, 0.0f); | ||||
|     ::glVertex3dv(m_grabbers[0].center.data()); | ||||
|     glsafe(::glEnd()); | ||||
| 
 | ||||
|     ::memcpy((void*)m_grabbers[0].color, (const void*)m_highlight_color, 3 * sizeof(float)); | ||||
|     ::memcpy((void*)m_grabbers[0].color, (const void*)m_highlight_color, 4 * sizeof(float)); | ||||
|     render_grabbers(box); | ||||
| } | ||||
| 
 | ||||
|  | @ -306,8 +306,8 @@ void GLGizmoRotate::render_grabber_extension(const BoundingBoxf3& box, bool pick | |||
|     float mean_size = (float)((box.size()(0) + box.size()(1) + box.size()(2)) / 3.0); | ||||
|     double size = m_dragging ? (double)m_grabbers[0].get_dragging_half_size(mean_size) : (double)m_grabbers[0].get_half_size(mean_size); | ||||
| 
 | ||||
|     float color[3]; | ||||
|     ::memcpy((void*)color, (const void*)m_grabbers[0].color, 3 * sizeof(float)); | ||||
|     float color[4]; | ||||
|     ::memcpy((void*)color, (const void*)m_grabbers[0].color, 4 * sizeof(float)); | ||||
|     if (!picking && (m_hover_id != -1)) | ||||
|     { | ||||
|         color[0] = 1.0f - color[0]; | ||||
|  | @ -318,7 +318,7 @@ void GLGizmoRotate::render_grabber_extension(const BoundingBoxf3& box, bool pick | |||
|     if (!picking) | ||||
|         glsafe(::glEnable(GL_LIGHTING)); | ||||
| 
 | ||||
|     glsafe(::glColor3fv(color)); | ||||
|     glsafe(::glColor4fv(color)); | ||||
|     glsafe(::glPushMatrix()); | ||||
|     glsafe(::glTranslated(m_grabbers[0].center(0), m_grabbers[0].center(1), m_grabbers[0].center(2))); | ||||
|     glsafe(::glRotated(Geometry::rad2deg(m_angle), 0.0, 0.0, 1.0)); | ||||
|  |  | |||
|  | @ -172,20 +172,20 @@ void GLGizmoScale3D::on_render() const | |||
|     // x axis
 | ||||
|     m_grabbers[0].center = m_transform * Vec3d(m_box.min(0), center(1), center(2)) - offset_x; | ||||
|     m_grabbers[1].center = m_transform * Vec3d(m_box.max(0), center(1), center(2)) + offset_x; | ||||
|     ::memcpy((void*)m_grabbers[0].color, (ctrl_down && (m_hover_id == 1)) ? (const void*)CONSTRAINED_COLOR : (const void*)&AXES_COLOR[0], 3 * sizeof(float)); | ||||
|     ::memcpy((void*)m_grabbers[1].color, (ctrl_down && (m_hover_id == 0)) ? (const void*)CONSTRAINED_COLOR : (const void*)&AXES_COLOR[0], 3 * sizeof(float)); | ||||
|     ::memcpy((void*)m_grabbers[0].color, (ctrl_down && (m_hover_id == 1)) ? (const void*)CONSTRAINED_COLOR : (const void*)&AXES_COLOR[0], 4 * sizeof(float)); | ||||
|     ::memcpy((void*)m_grabbers[1].color, (ctrl_down && (m_hover_id == 0)) ? (const void*)CONSTRAINED_COLOR : (const void*)&AXES_COLOR[0], 4 * sizeof(float)); | ||||
| 
 | ||||
|     // y axis
 | ||||
|     m_grabbers[2].center = m_transform * Vec3d(center(0), m_box.min(1), center(2)) - offset_y; | ||||
|     m_grabbers[3].center = m_transform * Vec3d(center(0), m_box.max(1), center(2)) + offset_y; | ||||
|     ::memcpy((void*)m_grabbers[2].color, (ctrl_down && (m_hover_id == 3)) ? (const void*)CONSTRAINED_COLOR : (const void*)&AXES_COLOR[1], 3 * sizeof(float)); | ||||
|     ::memcpy((void*)m_grabbers[3].color, (ctrl_down && (m_hover_id == 2)) ? (const void*)CONSTRAINED_COLOR : (const void*)&AXES_COLOR[1], 3 * sizeof(float)); | ||||
|     ::memcpy((void*)m_grabbers[2].color, (ctrl_down && (m_hover_id == 3)) ? (const void*)CONSTRAINED_COLOR : (const void*)&AXES_COLOR[1], 4 * sizeof(float)); | ||||
|     ::memcpy((void*)m_grabbers[3].color, (ctrl_down && (m_hover_id == 2)) ? (const void*)CONSTRAINED_COLOR : (const void*)&AXES_COLOR[1], 4 * sizeof(float)); | ||||
| 
 | ||||
|     // z axis
 | ||||
|     m_grabbers[4].center = m_transform * Vec3d(center(0), center(1), m_box.min(2)) - offset_z; | ||||
|     m_grabbers[5].center = m_transform * Vec3d(center(0), center(1), m_box.max(2)) + offset_z; | ||||
|     ::memcpy((void*)m_grabbers[4].color, (ctrl_down && (m_hover_id == 5)) ? (const void*)CONSTRAINED_COLOR : (const void*)&AXES_COLOR[2], 3 * sizeof(float)); | ||||
|     ::memcpy((void*)m_grabbers[5].color, (ctrl_down && (m_hover_id == 4)) ? (const void*)CONSTRAINED_COLOR : (const void*)&AXES_COLOR[2], 3 * sizeof(float)); | ||||
|     ::memcpy((void*)m_grabbers[4].color, (ctrl_down && (m_hover_id == 5)) ? (const void*)CONSTRAINED_COLOR : (const void*)&AXES_COLOR[2], 4 * sizeof(float)); | ||||
|     ::memcpy((void*)m_grabbers[5].color, (ctrl_down && (m_hover_id == 4)) ? (const void*)CONSTRAINED_COLOR : (const void*)&AXES_COLOR[2], 4 * sizeof(float)); | ||||
| 
 | ||||
|     // uniform
 | ||||
|     m_grabbers[6].center = m_transform * Vec3d(m_box.min(0), m_box.min(1), center(2)) - offset_x - offset_y; | ||||
|  | @ -194,7 +194,7 @@ void GLGizmoScale3D::on_render() const | |||
|     m_grabbers[9].center = m_transform * Vec3d(m_box.min(0), m_box.max(1), center(2)) - offset_x + offset_y; | ||||
|     for (int i = 6; i < 10; ++i) | ||||
|     { | ||||
|         ::memcpy((void*)m_grabbers[i].color, (const void*)m_highlight_color, 3 * sizeof(float)); | ||||
|         ::memcpy((void*)m_grabbers[i].color, (const void*)m_highlight_color, 4 * sizeof(float)); | ||||
|     } | ||||
| 
 | ||||
|     // sets grabbers orientation
 | ||||
|  | @ -214,20 +214,20 @@ void GLGizmoScale3D::on_render() const | |||
|         // draw connections
 | ||||
|         if (m_grabbers[0].enabled && m_grabbers[1].enabled) | ||||
|         { | ||||
|             glsafe(::glColor3fv(m_grabbers[0].color)); | ||||
|             glsafe(::glColor4fv(m_grabbers[0].color)); | ||||
|             render_grabbers_connection(0, 1); | ||||
|         } | ||||
|         if (m_grabbers[2].enabled && m_grabbers[3].enabled) | ||||
|         { | ||||
|             glsafe(::glColor3fv(m_grabbers[2].color)); | ||||
|             glsafe(::glColor4fv(m_grabbers[2].color)); | ||||
|             render_grabbers_connection(2, 3); | ||||
|         } | ||||
|         if (m_grabbers[4].enabled && m_grabbers[5].enabled) | ||||
|         { | ||||
|             glsafe(::glColor3fv(m_grabbers[4].color)); | ||||
|             glsafe(::glColor4fv(m_grabbers[4].color)); | ||||
|             render_grabbers_connection(4, 5); | ||||
|         } | ||||
|         glsafe(::glColor3fv(m_base_color)); | ||||
|         glsafe(::glColor4fv(m_base_color)); | ||||
|         render_grabbers_connection(6, 7); | ||||
|         render_grabbers_connection(7, 8); | ||||
|         render_grabbers_connection(8, 9); | ||||
|  | @ -238,7 +238,7 @@ void GLGizmoScale3D::on_render() const | |||
|     else if ((m_hover_id == 0) || (m_hover_id == 1)) | ||||
|     { | ||||
|         // draw connection
 | ||||
|         glsafe(::glColor3fv(m_grabbers[0].color)); | ||||
|         glsafe(::glColor4fv(m_grabbers[0].color)); | ||||
|         render_grabbers_connection(0, 1); | ||||
|         // draw grabbers
 | ||||
|         m_grabbers[0].render(true, grabber_mean_size); | ||||
|  | @ -247,7 +247,7 @@ void GLGizmoScale3D::on_render() const | |||
|     else if ((m_hover_id == 2) || (m_hover_id == 3)) | ||||
|     { | ||||
|         // draw connection
 | ||||
|         glsafe(::glColor3fv(m_grabbers[2].color)); | ||||
|         glsafe(::glColor4fv(m_grabbers[2].color)); | ||||
|         render_grabbers_connection(2, 3); | ||||
|         // draw grabbers
 | ||||
|         m_grabbers[2].render(true, grabber_mean_size); | ||||
|  | @ -256,7 +256,7 @@ void GLGizmoScale3D::on_render() const | |||
|     else if ((m_hover_id == 4) || (m_hover_id == 5)) | ||||
|     { | ||||
|         // draw connection
 | ||||
|         glsafe(::glColor3fv(m_grabbers[4].color)); | ||||
|         glsafe(::glColor4fv(m_grabbers[4].color)); | ||||
|         render_grabbers_connection(4, 5); | ||||
|         // draw grabbers
 | ||||
|         m_grabbers[4].render(true, grabber_mean_size); | ||||
|  | @ -265,7 +265,7 @@ void GLGizmoScale3D::on_render() const | |||
|     else if (m_hover_id >= 6) | ||||
|     { | ||||
|         // draw connection
 | ||||
|         glsafe(::glColor3fv(m_drag_color)); | ||||
|         glsafe(::glColor4fv(m_drag_color)); | ||||
|         render_grabbers_connection(6, 7); | ||||
|         render_grabbers_connection(7, 8); | ||||
|         render_grabbers_connection(8, 9); | ||||
|  |  | |||
|  | @ -286,7 +286,7 @@ void GLGizmoSlaSupports::render_points(const Selection& selection, bool picking) | |||
|     glsafe(::glTranslated(0.0, 0.0, m_z_shift)); | ||||
|     glsafe(::glMultMatrixd(instance_matrix.data())); | ||||
| 
 | ||||
|     float render_color[3]; | ||||
|     float render_color[4]; | ||||
|     size_t cache_size = m_editing_mode ? m_editing_cache.size() : m_normal_cache.size(); | ||||
|     for (size_t i = 0; i < cache_size; ++i) | ||||
|     { | ||||
|  | @ -298,12 +298,14 @@ void GLGizmoSlaSupports::render_points(const Selection& selection, bool picking) | |||
| 
 | ||||
|         // First decide about the color of the point.
 | ||||
|         if (picking) { | ||||
|             std::array<float, 3> color = picking_color_component(i); | ||||
|             std::array<float, 4> color = picking_color_component(i); | ||||
|             render_color[0] = color[0]; | ||||
|             render_color[1] = color[1]; | ||||
|             render_color[2] = color[2]; | ||||
| 	        render_color[3] = picking_checksum_alpha_channel(render_color[0], render_color[1], render_color[2]); | ||||
|         } | ||||
|         else { | ||||
|             render_color[3] = 1.f; | ||||
|             if ((m_hover_id == i && m_editing_mode)) { // ignore hover state unless editing mode is active
 | ||||
|                 render_color[0] = 0.f; | ||||
|                 render_color[1] = 1.0f; | ||||
|  | @ -320,7 +322,7 @@ void GLGizmoSlaSupports::render_points(const Selection& selection, bool picking) | |||
|                     for (unsigned char i=0; i<3; ++i) render_color[i] = 0.5f; | ||||
|             } | ||||
|         } | ||||
|         glsafe(::glColor3fv(render_color)); | ||||
|         glsafe(::glColor4fv(render_color)); | ||||
|         float render_color_emissive[4] = { 0.5f * render_color[0], 0.5f * render_color[1], 0.5f * render_color[2], 1.f}; | ||||
|         glsafe(::glMaterialfv(GL_FRONT, GL_EMISSION, render_color_emissive)); | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bubnikv
						bubnikv