From b03f190e56529b0ddc5c1f72b1c48798f5473deb Mon Sep 17 00:00:00 2001 From: noy zini Date: Wed, 1 Jan 2025 14:29:08 +0200 Subject: [PATCH] add dds enable to viewer settings --- common/dds-model.cpp | 51 ++++++++++--------------------------------- common/dds-model.h | 2 -- common/device-model.h | 5 +++++ common/ux-window.cpp | 7 ++++++ common/viewer.cpp | 28 ++++++++++++++++++++++++ 5 files changed, 51 insertions(+), 42 deletions(-) diff --git a/common/dds-model.cpp b/common/dds-model.cpp index 16a8432497..50d95c75e6 100644 --- a/common/dds-model.cpp +++ b/common/dds-model.cpp @@ -64,33 +64,6 @@ void rs2::dds_model::set_eth_config( eth_config & new_config, std::string & erro } } -void rs2::dds_model::enable_dds( std::string & error_message ) -{ - if( _device.get_type() == "DDS" ) - { - auto const filename - = rsutils::os::get_special_folder( rsutils::os::special_folder::app_data ) + RS2_CONFIG_FILENAME; - auto config = rsutils::json_config::load_from_file( filename ); - - bool enabled; - if( ! config.nested( "context", "dds", "enabled" ).get_ex( enabled ) ) - { - config["context"]["dds"]["enabled"] = true; - try - { - std::ofstream out( filename ); - out << std::setw( 2 ) << config; - out.close(); - } - catch( std::exception const & e ) - { - error_message = e.what(); - close_window(); - } - } - } -} - bool rs2::dds_model::supports_DDS() { return _dds_supported; @@ -199,11 +172,8 @@ void dds_model::render_dds_config_window( ux_window & window, std::string & erro ImGui::Separator(); ImGui::SetCursorPosY( ImGui::GetCursorPosY() + 15 ); - // Version Display - ImGui::Text( "Version: %s", RS2_API_FULL_VERSION_STR ); - // Main Scrollable Section - ImGui::BeginChild( "MainContent", ImVec2( w - 10, h - 120 ), true ); + ImGui::BeginChild( "MainContent", ImVec2( w - 10, h - 100 ), true ); ImGui::PushItemWidth( 150.0f ); // Connection Priority Section @@ -261,12 +231,15 @@ void dds_model::render_dds_config_window( ux_window & window, std::string & erro ImGui::SetCursorPosX( textbox_align ); ipInputText( "Gateway", _changed_config.configured.gateway ); } - ImGui::Text( "DHCP Timeout (seconds)" ); - ImGui::SameLine(); - int tempTimeout = static_cast< int >( _changed_config.dhcp.timeout ); - if( ImGui::InputInt( "##DHCP Timeout (seconds)", &tempTimeout ) ) + else { - _changed_config.dhcp.timeout = static_cast< uint16_t >( std::max( 0, tempTimeout ) ); + ImGui::Text( "DHCP Timeout (seconds)" ); + ImGui::SameLine(); + int tempTimeout = static_cast< int >( _changed_config.dhcp.timeout ); + if( ImGui::InputInt( "##DHCP Timeout (seconds)", &tempTimeout ) ) + { + _changed_config.dhcp.timeout = static_cast< uint16_t >( std::max( 0, tempTimeout ) ); + } } } @@ -281,7 +254,7 @@ void dds_model::render_dds_config_window( ux_window & window, std::string & erro } ImGui::Checkbox( "No Reset after changes", &_no_reset ); - if( ImGui::Checkbox( "Set to defult values", &_set_defult ) ) + if( ImGui::Checkbox( "Load to defult values", &_set_defult ) ) { if( _set_defult ) _changed_config = _defult_config; @@ -293,7 +266,7 @@ void dds_model::render_dds_config_window( ux_window & window, std::string & erro ImGui::EndChild(); // window buttons - float button_width = 105.0f; + float button_width = 115.0f; float spacing = 10.0f; float total_buttons_width = button_width * 4 + spacing * 2; float start_x = ( w - total_buttons_width ) / 2.0f; @@ -315,7 +288,6 @@ void dds_model::render_dds_config_window( ux_window & window, std::string & erro ImGui::SameLine(); if( ImGui::Button( "Factory Reset", ImVec2( button_width, 25 ) ) ) { - enable_dds( error_message ); set_eth_config( _defult_config, error_message ); close_window(); } @@ -345,7 +317,6 @@ void dds_model::render_dds_config_window( ux_window & window, std::string & erro { if( ImGui::ButtonEx( "Apply", ImVec2( button_width, 25 ) ) ) { - enable_dds( error_message ); set_eth_config( _changed_config, error_message ); close_window(); }; diff --git a/common/dds-model.h b/common/dds-model.h index 084497d81e..2a804a4edf 100644 --- a/common/dds-model.h +++ b/common/dds-model.h @@ -44,8 +44,6 @@ namespace rs2 void set_eth_config(eth_config &new_config , std::string& error_message); - void enable_dds(std::string& error_message); - bool supports_DDS(); diff --git a/common/device-model.h b/common/device-model.h index d988f83bdd..eadf32e548 100644 --- a/common/device-model.h +++ b/common/device-model.h @@ -109,6 +109,11 @@ namespace rs2 { static const char* enable_writing{ "calibration.enable_writing" }; } + namespace dds + { + static const char* enable_dds{ "context.dds.enabled" }; + static const char* domain_id{ "context.dds.domain" }; + } namespace viewer { static const char* is_3d_view{ "viewer_model.is_3d_view" }; diff --git a/common/ux-window.cpp b/common/ux-window.cpp index 95a16e6dec..bf4258edf1 100644 --- a/common/ux-window.cpp +++ b/common/ux-window.cpp @@ -102,6 +102,13 @@ namespace rs2 config_file::instance().set_default(configurations::viewer::log_filename, path + "librealsense.log"); config_file::instance().set_default(configurations::record::default_path, path); + auto const filename + = rsutils::os::get_special_folder( rsutils::os::special_folder::app_data ) + RS2_CONFIG_FILENAME; + auto config = rsutils::json_config::load_from_file( filename ); + bool enable_dds = config.nested( "context", "dds", "enabled" ).get_ex( enable_dds ); + int domain_id = config.nested("context", "dds", "domain").get_ex(domain_id); + config_file::instance().set_default( configurations::dds::enable_dds, enable_dds ); + config_file::instance().set_default( configurations::dds::domain_id, domain_id ); #ifdef __APPLE__ config_file::instance().set_default(configurations::performance::font_oversample, 2); diff --git a/common/viewer.cpp b/common/viewer.cpp index 7b7ea21fa4..cb00668571 100644 --- a/common/viewer.cpp +++ b/common/viewer.cpp @@ -2813,6 +2813,34 @@ namespace rs2 catch (...){} } } + + ImGui::Separator(); + bool enable_dds = temp_cfg.get( configurations::dds::enable_dds ); + int domain_id = temp_cfg.get( configurations::dds::domain_id ); + if( ImGui::Checkbox( "Enable DDS", &enable_dds ) ) + { + temp_cfg.set( configurations::dds::enable_dds, enable_dds ); + } + if( enable_dds ) + { + ImGui::SameLine(); + ImGui::SetCursorPosX( ImGui::GetCursorPosX() + 50 ); + ImGui::PushItemWidth( 150.0f ); + ImGui::Text( "Domain ID" ); + ImGui::SameLine(); + if( ImGui::InputInt( "##Domain ID", &domain_id ) ) + { + if( domain_id < 0 ) + domain_id = 0; + else if( domain_id > 232 ) + domain_id = 232; + temp_cfg.set( configurations::dds::domain_id, domain_id ); + } + } + ImGui::SameLine(); + ImGui::SetCursorPosX( w - 700 ); + ImGui::Text(u8"\uf071 Changes will take effect only after restarting the application "); + } if (tab == 3)