mirror of
				https://github.com/kunkundi/crossdesk.git
				synced 2025-10-26 20:25:34 +08:00 
			
		
		
		
	[fix] fix control bar display error in fullscreen mode when multiple connections established
This commit is contained in:
		| @@ -179,7 +179,8 @@ int Render::ControlWindow(std::shared_ptr<SubStreamWindowProperties> &props) { | |||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   ImGui::Begin("ControlWindow", nullptr, |   std::string control_window_title = props->remote_id_ + "ControlWindow"; | ||||||
|  |   ImGui::Begin(control_window_title.c_str(), nullptr, | ||||||
|                ImGuiWindowFlags_NoTitleBar | ImGuiWindowFlags_NoResize | |                ImGuiWindowFlags_NoTitleBar | ImGuiWindowFlags_NoResize | | ||||||
|                    ImGuiWindowFlags_NoScrollbar | ImGuiWindowFlags_NoDocking); |                    ImGuiWindowFlags_NoScrollbar | ImGuiWindowFlags_NoDocking); | ||||||
|   ImGui::PopStyleVar(); |   ImGui::PopStyleVar(); | ||||||
| @@ -201,8 +202,10 @@ int Render::ControlWindow(std::shared_ptr<SubStreamWindowProperties> &props) { | |||||||
|       ImGuiCond_Always); |       ImGuiCond_Always); | ||||||
|   ImGui::SetWindowFontScale(0.5f); |   ImGui::SetWindowFontScale(0.5f); | ||||||
|  |  | ||||||
|  |   std::string control_child_window_title = | ||||||
|  |       props->remote_id_ + "ControlChildWindow"; | ||||||
|   ImGui::BeginChild( |   ImGui::BeginChild( | ||||||
|       "ControlBar", |       control_child_window_title.c_str(), | ||||||
|       ImVec2(props->control_window_width_ * 2, props->control_window_height_), |       ImVec2(props->control_window_width_ * 2, props->control_window_height_), | ||||||
|       ImGuiChildFlags_Border, ImGuiWindowFlags_NoDecoration); |       ImGuiChildFlags_Border, ImGuiWindowFlags_NoDecoration); | ||||||
|   ImGui::SetWindowFontScale(1.0f); |   ImGui::SetWindowFontScale(1.0f); | ||||||
|   | |||||||
| @@ -15,16 +15,14 @@ int Render::StreamWindow() { | |||||||
|                ImGuiWindowFlags_NoMove | ImGuiWindowFlags_NoDecoration | |                ImGuiWindowFlags_NoMove | ImGuiWindowFlags_NoDecoration | | ||||||
|                    ImGuiWindowFlags_NoBringToFrontOnFocus | |                    ImGuiWindowFlags_NoBringToFrontOnFocus | | ||||||
|                    ImGuiWindowFlags_NoDocking); |                    ImGuiWindowFlags_NoDocking); | ||||||
|  |  | ||||||
|   ImGui::PopStyleColor(2); |   ImGui::PopStyleColor(2); | ||||||
|   ImGui::PopStyleVar(); |   ImGui::PopStyleVar(); | ||||||
|  |  | ||||||
|   ImGuiTabBarFlags tab_bar_flags = |  | ||||||
|       ImGuiTabBarFlags_Reorderable | ImGuiTabBarFlags_AutoSelectNewTabs; |  | ||||||
|   ImGuiWindowFlags stream_window_flag = |   ImGuiWindowFlags stream_window_flag = | ||||||
|       ImGuiWindowFlags_NoSavedSettings | ImGuiWindowFlags_NoDecoration | |       ImGuiWindowFlags_NoSavedSettings | ImGuiWindowFlags_NoDecoration | | ||||||
|       ImGuiWindowFlags_NoBringToFrontOnFocus | ImGuiWindowFlags_NoMove; |       ImGuiWindowFlags_NoBringToFrontOnFocus | ImGuiWindowFlags_NoMove; | ||||||
|  |  | ||||||
|  |   if (!fullscreen_button_pressed_) { | ||||||
|     ImGui::SetNextWindowPos(ImVec2(20, 0), ImGuiCond_Always); |     ImGui::SetNextWindowPos(ImVec2(20, 0), ImGuiCond_Always); | ||||||
|     ImGui::SetNextWindowSize(ImVec2(0, 20), ImGuiCond_Always); |     ImGui::SetNextWindowSize(ImVec2(0, 20), ImGuiCond_Always); | ||||||
|     ImGui::PushStyleVar(ImGuiStyleVar_WindowPadding, ImVec2(0.0f, 8.0f)); |     ImGui::PushStyleVar(ImGuiStyleVar_WindowPadding, ImVec2(0.0f, 8.0f)); | ||||||
| @@ -36,22 +34,32 @@ int Render::StreamWindow() { | |||||||
|                      ImGuiWindowFlags_NoDocking); |                      ImGuiWindowFlags_NoDocking); | ||||||
|     ImGui::PopStyleColor(); |     ImGui::PopStyleColor(); | ||||||
|     ImGui::PopStyleVar(2); |     ImGui::PopStyleVar(2); | ||||||
|   if (ImGui::BeginTabBar("StreamTabBar", tab_bar_flags)) { |  | ||||||
|     if (ImGui::IsWindowHovered()) { |     if (ImGui::BeginTabBar("StreamTabBar", | ||||||
|       is_tab_bar_hovered_ = true; |                            ImGuiTabBarFlags_Reorderable | | ||||||
|     } else { |                                ImGuiTabBarFlags_AutoSelectNewTabs)) { | ||||||
|       is_tab_bar_hovered_ = false; |       is_tab_bar_hovered_ = ImGui::IsWindowHovered(); | ||||||
|     } |  | ||||||
|  |  | ||||||
|       for (auto it = client_properties_.begin(); |       for (auto it = client_properties_.begin(); | ||||||
|            it != client_properties_.end();) { |            it != client_properties_.end();) { | ||||||
|         auto& props = it->second; |         auto& props = it->second; | ||||||
|       if (props->tab_opened_) { |         if (!props->tab_opened_) { | ||||||
|  |           CleanupPeer(props); | ||||||
|  |           it = client_properties_.erase(it); | ||||||
|  |           if (client_properties_.empty()) { | ||||||
|  |             SDL_Event event; | ||||||
|  |             event.type = SDL_QUIT; | ||||||
|  |             SDL_PushEvent(&event); | ||||||
|  |           } | ||||||
|  |           continue; | ||||||
|  |         } | ||||||
|  |  | ||||||
|         ImGui::SetWindowFontScale(0.6f); |         ImGui::SetWindowFontScale(0.6f); | ||||||
|         if (ImGui::BeginTabItem(props->remote_id_.c_str(), &props->tab_opened_, |         if (ImGui::BeginTabItem(props->remote_id_.c_str(), | ||||||
|                                 ImGuiTabItemFlags_None)) { |                                 &props->tab_opened_)) { | ||||||
|           props->tab_selected_ = true; |           props->tab_selected_ = true; | ||||||
|           ImGui::SetWindowFontScale(1.0f); |           ImGui::SetWindowFontScale(1.0f); | ||||||
|  |  | ||||||
|           ImGui::SetNextWindowSize( |           ImGui::SetNextWindowSize( | ||||||
|               ImVec2(stream_window_width_, stream_window_height_), |               ImVec2(stream_window_width_, stream_window_height_), | ||||||
|               ImGuiCond_Always); |               ImGuiCond_Always); | ||||||
| @@ -65,15 +73,15 @@ int Render::StreamWindow() { | |||||||
|           ImGui::PopStyleColor(); |           ImGui::PopStyleColor(); | ||||||
|           ImGui::PopStyleVar(2); |           ImGui::PopStyleVar(2); | ||||||
|  |  | ||||||
|           ImVec2 stream_window_pos = ImGui::GetWindowPos(); |           ImVec2 pos = ImGui::GetWindowPos(); | ||||||
|           ImGuiViewport* viewport = ImGui::GetWindowViewport(); |           ImVec2 size = ImGui::GetWindowSize(); | ||||||
|           ImVec2 stream_window_size = ImGui::GetWindowSize(); |           props->render_window_x_ = pos.x; | ||||||
|           props->render_window_x_ = stream_window_pos.x; |           props->render_window_y_ = pos.y; | ||||||
|           props->render_window_y_ = stream_window_pos.y; |           props->render_window_width_ = size.x; | ||||||
|           props->render_window_width_ = stream_window_size.x; |           props->render_window_height_ = size.y; | ||||||
|           props->render_window_height_ = stream_window_size.y; |  | ||||||
|  |  | ||||||
|           ControlWindow(props); |           ControlWindow(props); | ||||||
|  |  | ||||||
|           if (!props->peer_) { |           if (!props->peer_) { | ||||||
|             it = client_properties_.erase(it); |             it = client_properties_.erase(it); | ||||||
|             if (client_properties_.empty()) { |             if (client_properties_.empty()) { | ||||||
| @@ -92,7 +100,17 @@ int Render::StreamWindow() { | |||||||
|           ImGui::SetWindowFontScale(1.0f); |           ImGui::SetWindowFontScale(1.0f); | ||||||
|           ++it; |           ++it; | ||||||
|         } |         } | ||||||
|  |       } | ||||||
|  |  | ||||||
|  |       ImGui::EndTabBar(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     ImGui::End();  // End TabBar | ||||||
|   } else { |   } else { | ||||||
|  |     for (auto it = client_properties_.begin(); | ||||||
|  |          it != client_properties_.end();) { | ||||||
|  |       auto& props = it->second; | ||||||
|  |       if (!props->tab_opened_) { | ||||||
|         CleanupPeer(props); |         CleanupPeer(props); | ||||||
|         it = client_properties_.erase(it); |         it = client_properties_.erase(it); | ||||||
|         if (client_properties_.empty()) { |         if (client_properties_.empty()) { | ||||||
| @@ -100,15 +118,51 @@ int Render::StreamWindow() { | |||||||
|           event.type = SDL_QUIT; |           event.type = SDL_QUIT; | ||||||
|           SDL_PushEvent(&event); |           SDL_PushEvent(&event); | ||||||
|         } |         } | ||||||
|  |         continue; | ||||||
|       } |       } | ||||||
|     } |  | ||||||
|     ImGui::EndTabBar(); |       if (props->tab_selected_) { | ||||||
|   } |         ImGui::SetNextWindowSize( | ||||||
|  |             ImVec2(stream_window_width_, stream_window_height_), | ||||||
|  |             ImGuiCond_Always); | ||||||
|  |         ImGui::SetNextWindowPos(ImVec2(0, 0), ImGuiCond_Always); | ||||||
|  |         ImGui::PushStyleVar(ImGuiStyleVar_WindowPadding, ImVec2(0.0f, 0.0f)); | ||||||
|  |         ImGui::PushStyleVar(ImGuiStyleVar_WindowBorderSize, 0.0f); | ||||||
|  |         ImGui::PushStyleColor(ImGuiCol_WindowBg, ImVec4(0, 0, 0, 0.0f)); | ||||||
|  |         ImGui::Begin(props->remote_id_.c_str(), nullptr, stream_window_flag); | ||||||
|  |         ImGui::PopStyleColor(); | ||||||
|  |         ImGui::PopStyleVar(2); | ||||||
|  |  | ||||||
|  |         ImVec2 pos = ImGui::GetWindowPos(); | ||||||
|  |         ImVec2 size = ImGui::GetWindowSize(); | ||||||
|  |         props->render_window_x_ = pos.x; | ||||||
|  |         props->render_window_y_ = pos.y; | ||||||
|  |         props->render_window_width_ = size.x; | ||||||
|  |         props->render_window_height_ = size.y; | ||||||
|  |  | ||||||
|  |         ControlWindow(props); | ||||||
|         ImGui::End(); |         ImGui::End(); | ||||||
|  |  | ||||||
|  |         if (!props->peer_) { | ||||||
|  |           fullscreen_button_pressed_ = false; | ||||||
|  |           SDL_SetWindowFullscreen(stream_window_, SDL_FALSE); | ||||||
|  |           it = client_properties_.erase(it); | ||||||
|  |           if (client_properties_.empty()) { | ||||||
|  |             SDL_Event event; | ||||||
|  |             event.type = SDL_QUIT; | ||||||
|  |             SDL_PushEvent(&event); | ||||||
|  |           } | ||||||
|  |         } else { | ||||||
|  |           ++it; | ||||||
|  |         } | ||||||
|  |       } else { | ||||||
|  |         ++it; | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  |  | ||||||
|   UpdateRenderRect(); |   UpdateRenderRect(); | ||||||
|  |   ImGui::End();  // End VideoBg | ||||||
|   ImGui::End(); |  | ||||||
|  |  | ||||||
|   return 0; |   return 0; | ||||||
| } | } | ||||||
		Reference in New Issue
	
	Block a user