mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-24 17:21:11 -06:00 
			
		
		
		
	3DConnexion devices: added option to swap y/z translations
This commit is contained in:
		
							parent
							
								
									170650169c
								
							
						
					
					
						commit
						f912fecad5
					
				
					 4 changed files with 30 additions and 11 deletions
				
			
		|  | @ -280,7 +280,7 @@ void AppConfig::set_recent_projects(const std::vector<std::string>& recent_proje | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void AppConfig::set_mouse_device(const std::string& name, double translation_speed, double translation_deadzone, float rotation_speed, float rotation_deadzone, double zoom_speed) | void AppConfig::set_mouse_device(const std::string& name, double translation_speed, double translation_deadzone, float rotation_speed, float rotation_deadzone, double zoom_speed, bool swap_yz_translations) | ||||||
| { | { | ||||||
|     std::string key = std::string("mouse_device:") + name; |     std::string key = std::string("mouse_device:") + name; | ||||||
|     auto it = m_storage.find(key); |     auto it = m_storage.find(key); | ||||||
|  | @ -293,6 +293,7 @@ void AppConfig::set_mouse_device(const std::string& name, double translation_spe | ||||||
|     it->second["rotation_speed"] = std::to_string(rotation_speed); |     it->second["rotation_speed"] = std::to_string(rotation_speed); | ||||||
|     it->second["rotation_deadzone"] = std::to_string(rotation_deadzone); |     it->second["rotation_deadzone"] = std::to_string(rotation_deadzone); | ||||||
|     it->second["zoom_speed"] = std::to_string(zoom_speed); |     it->second["zoom_speed"] = std::to_string(zoom_speed); | ||||||
|  |     it->second["swap_yz_translations"] = swap_yz_translations ? "1" : "0"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| std::vector<std::string> AppConfig::get_mouse_device_names() const | std::vector<std::string> AppConfig::get_mouse_device_names() const | ||||||
|  |  | ||||||
|  | @ -141,7 +141,7 @@ public: | ||||||
|     std::vector<std::string> get_recent_projects() const; |     std::vector<std::string> get_recent_projects() const; | ||||||
|     void set_recent_projects(const std::vector<std::string>& recent_projects); |     void set_recent_projects(const std::vector<std::string>& recent_projects); | ||||||
| 
 | 
 | ||||||
| 	void set_mouse_device(const std::string& name, double translation_speed, double translation_deadzone, float rotation_speed, float rotation_deadzone, double zoom_speed); | 	void set_mouse_device(const std::string& name, double translation_speed, double translation_deadzone, float rotation_speed, float rotation_deadzone, double zoom_speed, bool swap_yz_translations); | ||||||
| 	std::vector<std::string> get_mouse_device_names() const; | 	std::vector<std::string> get_mouse_device_names() const; | ||||||
| 	bool get_mouse_device_translation_speed(const std::string& name, double& speed) const | 	bool get_mouse_device_translation_speed(const std::string& name, double& speed) const | ||||||
| 		{ return get_3dmouse_device_numeric_value(name, "translation_speed", speed); } | 		{ return get_3dmouse_device_numeric_value(name, "translation_speed", speed); } | ||||||
|  | @ -153,6 +153,8 @@ public: | ||||||
| 		{ return get_3dmouse_device_numeric_value(name, "rotation_deadzone", deadzone); } | 		{ return get_3dmouse_device_numeric_value(name, "rotation_deadzone", deadzone); } | ||||||
| 	bool get_mouse_device_zoom_speed(const std::string& name, double& speed) const | 	bool get_mouse_device_zoom_speed(const std::string& name, double& speed) const | ||||||
| 		{ return get_3dmouse_device_numeric_value(name, "zoom_speed", speed); } | 		{ return get_3dmouse_device_numeric_value(name, "zoom_speed", speed); } | ||||||
|  | 	bool get_mouse_device_swap_yz_translations(const std::string& name, bool& swap) const | ||||||
|  | 		{ return get_3dmouse_device_numeric_value(name, "swap_yz_translations", swap); } | ||||||
| 
 | 
 | ||||||
| 	static const std::string SECTION_FILAMENTS; | 	static const std::string SECTION_FILAMENTS; | ||||||
|     static const std::string SECTION_MATERIALS; |     static const std::string SECTION_MATERIALS; | ||||||
|  |  | ||||||
|  | @ -150,7 +150,7 @@ bool Mouse3DController::State::apply(const Mouse3DController::Params ¶ms, Ca | ||||||
| 
 | 
 | ||||||
|     for (const QueueItem &input_queue_item : input_queue) { |     for (const QueueItem &input_queue_item : input_queue) { | ||||||
|     	if (input_queue_item.is_translation()) { |     	if (input_queue_item.is_translation()) { | ||||||
| 	        const Vec3d& translation = input_queue_item.vector; |             Vec3d translation = params.swap_yz_translations ? Vec3d(input_queue_item.vector(0), input_queue_item.vector(2), input_queue_item.vector(1)) : input_queue_item.vector; | ||||||
|             double zoom_factor = camera.min_zoom() / camera.get_zoom(); |             double zoom_factor = camera.min_zoom() / camera.get_zoom(); | ||||||
| 	        camera.set_target(camera.get_target() + zoom_factor * params.translation.scale * (translation.x() * camera.get_dir_right() + translation.z() * camera.get_dir_up())); | 	        camera.set_target(camera.get_target() + zoom_factor * params.translation.scale * (translation.x() * camera.get_dir_right() + translation.z() * camera.get_dir_up())); | ||||||
|             if (translation.y() != 0.0) |             if (translation.y() != 0.0) | ||||||
|  | @ -185,11 +185,13 @@ void Mouse3DController::load_config(const AppConfig &appconfig) | ||||||
| 	    double translation_deadzone = Params::DefaultTranslationDeadzone; | 	    double translation_deadzone = Params::DefaultTranslationDeadzone; | ||||||
| 	    float  rotation_deadzone 	= Params::DefaultRotationDeadzone; | 	    float  rotation_deadzone 	= Params::DefaultRotationDeadzone; | ||||||
| 	    double zoom_speed 			= 2.0; | 	    double zoom_speed 			= 2.0; | ||||||
|  |         bool   swap_yz_translations = false; | ||||||
|         appconfig.get_mouse_device_translation_speed(device_name, translation_speed); |         appconfig.get_mouse_device_translation_speed(device_name, translation_speed); | ||||||
| 	    appconfig.get_mouse_device_translation_deadzone(device_name, translation_deadzone); | 	    appconfig.get_mouse_device_translation_deadzone(device_name, translation_deadzone); | ||||||
| 	    appconfig.get_mouse_device_rotation_speed(device_name, rotation_speed); | 	    appconfig.get_mouse_device_rotation_speed(device_name, rotation_speed); | ||||||
| 	    appconfig.get_mouse_device_rotation_deadzone(device_name, rotation_deadzone); | 	    appconfig.get_mouse_device_rotation_deadzone(device_name, rotation_deadzone); | ||||||
| 	    appconfig.get_mouse_device_zoom_speed(device_name, zoom_speed); | 	    appconfig.get_mouse_device_zoom_speed(device_name, zoom_speed); | ||||||
|  |         appconfig.get_mouse_device_swap_yz_translations(device_name, swap_yz_translations); | ||||||
|         // clamp to valid values
 |         // clamp to valid values
 | ||||||
| 	    Params params; | 	    Params params; | ||||||
| 	    params.translation.scale = Params::DefaultTranslationScale * std::clamp(translation_speed, 0.1, 10.0); | 	    params.translation.scale = Params::DefaultTranslationScale * std::clamp(translation_speed, 0.1, 10.0); | ||||||
|  | @ -197,6 +199,7 @@ void Mouse3DController::load_config(const AppConfig &appconfig) | ||||||
| 	    params.rotation.scale = Params::DefaultRotationScale * std::clamp(rotation_speed, 0.1f, 10.0f); | 	    params.rotation.scale = Params::DefaultRotationScale * std::clamp(rotation_speed, 0.1f, 10.0f); | ||||||
| 	    params.rotation.deadzone = std::clamp(rotation_deadzone, 0.0f, Params::MaxRotationDeadzone); | 	    params.rotation.deadzone = std::clamp(rotation_deadzone, 0.0f, Params::MaxRotationDeadzone); | ||||||
| 	    params.zoom.scale = Params::DefaultZoomScale * std::clamp(zoom_speed, 0.1, 10.0); | 	    params.zoom.scale = Params::DefaultZoomScale * std::clamp(zoom_speed, 0.1, 10.0); | ||||||
|  |         params.swap_yz_translations = swap_yz_translations; | ||||||
|         m_params_by_device[device_name] = std::move(params); |         m_params_by_device[device_name] = std::move(params); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  | @ -211,7 +214,7 @@ void Mouse3DController::save_config(AppConfig &appconfig) const | ||||||
| 		const Params      ¶ms      = key_value_pair.second; | 		const Params      ¶ms      = key_value_pair.second; | ||||||
| 	    // Store current device parameters into the config
 | 	    // Store current device parameters into the config
 | ||||||
|         appconfig.set_mouse_device(device_name, params.translation.scale / Params::DefaultTranslationScale, params.translation.deadzone, |         appconfig.set_mouse_device(device_name, params.translation.scale / Params::DefaultTranslationScale, params.translation.deadzone, | ||||||
| 	        params.rotation.scale / Params::DefaultRotationScale, params.rotation.deadzone, params.zoom.scale / Params::DefaultZoomScale); |             params.rotation.scale / Params::DefaultRotationScale, params.rotation.deadzone, params.zoom.scale / Params::DefaultZoomScale, params.swap_yz_translations); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -315,6 +318,17 @@ void Mouse3DController::render_settings_dialog(GLCanvas3D& canvas) const | ||||||
|             	params_changed = true; |             	params_changed = true; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|  |             ImGui::Separator(); | ||||||
|  |             ImGui::PushStyleColor(ImGuiCol_Text, color); | ||||||
|  |             imgui.text(_(L("Options:"))); | ||||||
|  |             ImGui::PopStyleColor(); | ||||||
|  | 
 | ||||||
|  |             bool swap_yz = params_copy.swap_yz_translations; | ||||||
|  |             if (imgui.checkbox("Swap Y/Z translations", swap_yz)) { | ||||||
|  |                 params_copy.swap_yz_translations = swap_yz; | ||||||
|  |                 params_changed = true; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
| #if ENABLE_3DCONNEXION_DEVICES_DEBUG_OUTPUT | #if ENABLE_3DCONNEXION_DEVICES_DEBUG_OUTPUT | ||||||
|             ImGui::Separator(); |             ImGui::Separator(); | ||||||
|             ImGui::Separator(); |             ImGui::Separator(); | ||||||
|  |  | ||||||
|  | @ -56,6 +56,8 @@ class Mouse3DController | ||||||
|         // The effects of changing this value can be tested by setting ENABLE_3DCONNEXION_DEVICES_DEBUG_OUTPUT to 1
 |         // The effects of changing this value can be tested by setting ENABLE_3DCONNEXION_DEVICES_DEBUG_OUTPUT to 1
 | ||||||
|         // and playing with the imgui dialog which shows by pressing CTRL+M
 |         // and playing with the imgui dialog which shows by pressing CTRL+M
 | ||||||
|         size_t 					 input_queue_max_size { 15 }; |         size_t 					 input_queue_max_size { 15 }; | ||||||
|  |         // Whether to swap Y/Z axis when translating or not.
 | ||||||
|  |         bool 					 swap_yz_translations{ false }; | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
| 	// Queue of the 3DConnexion input events (translations, rotations, button presses).
 | 	// Queue of the 3DConnexion input events (translations, rotations, button presses).
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Enrico Turri
						Enrico Turri