mirror of
				https://github.com/kunkundi/crossdesk.git
				synced 2025-10-26 20:25:34 +08:00 
			
		
		
		
	[feat] display selection supported on Windows platform
This commit is contained in:
		| @@ -65,6 +65,14 @@ int Render::ControlBar(std::shared_ptr<SubStreamWindowProperties>& props) { | ||||
|       for (int i = 0; i < display_list.size(); i++) { | ||||
|         if (ImGui::Selectable(display_list[i].name.c_str())) { | ||||
|           selected_display_ = i + 1; | ||||
|  | ||||
|           RemoteAction remote_action; | ||||
|           remote_action.type = ControlType::display_id; | ||||
|           remote_action.d = i; | ||||
|           if (props->connection_status_ == ConnectionStatus::Connected) { | ||||
|             SendDataFrame(props->peer_, (const char*)&remote_action, | ||||
|                           sizeof(remote_action)); | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|       ImGui::SetWindowFontScale(1.0f); | ||||
| @@ -118,7 +126,8 @@ int Render::ControlBar(std::shared_ptr<SubStreamWindowProperties>& props) { | ||||
|     float disable_audio_x = ImGui::GetCursorScreenPos().x + 4; | ||||
|     float disable_audio_y = ImGui::GetCursorScreenPos().y + 4.0f; | ||||
|     // std::string audio = audio_capture_button_pressed_ ? ICON_FA_VOLUME_HIGH | ||||
|     //                                                   : ICON_FA_VOLUME_XMARK; | ||||
|     //                                                   : | ||||
|     //                                                   ICON_FA_VOLUME_XMARK; | ||||
|     std::string audio = props->audio_capture_button_pressed_ | ||||
|                             ? ICON_FA_VOLUME_HIGH | ||||
|                             : ICON_FA_VOLUME_HIGH; | ||||
|   | ||||
| @@ -79,6 +79,8 @@ class Render { | ||||
|     int texture_height_ = 720; | ||||
|     int video_width_ = 0; | ||||
|     int video_height_ = 0; | ||||
|     int video_width_last_ = 0; | ||||
|     int video_height_last_ = 0; | ||||
|     size_t video_size_ = 0; | ||||
|     bool tab_selected_ = false; | ||||
|     bool tab_opened_ = true; | ||||
|   | ||||
| @@ -215,8 +215,11 @@ void Render::OnReceiveVideoBufferCb(const XVideoFrame *video_frame, | ||||
|  | ||||
|     memcpy(props->dst_buffer_, video_frame->data, video_frame->size); | ||||
|     bool need_to_update_render_rect = false; | ||||
|     if (props->video_width_ == 0 && props->video_height_ == 0) { | ||||
|     if (props->video_width_ != props->video_width_last_ || | ||||
|         props->video_height_ != props->video_height_last_) { | ||||
|       need_to_update_render_rect = true; | ||||
|       props->video_width_last_ = props->video_width_; | ||||
|       props->video_height_last_ = props->video_height_; | ||||
|     } | ||||
|     props->video_width_ = video_frame->width; | ||||
|     props->video_height_ = video_frame->height; | ||||
| @@ -261,6 +264,7 @@ void Render::OnReceiveDataBufferCb(const char *data, size_t size, | ||||
|   std::string remote_id(user_id, user_id_size); | ||||
|   if (render->client_properties_.find(remote_id) != | ||||
|       render->client_properties_.end()) { | ||||
|     // local | ||||
|     auto props = render->client_properties_.find(remote_id)->second; | ||||
|     if (ControlType::host_infomation == remote_action.type) { | ||||
|       props->remote_host_name_ = std::string(remote_action.i.host_name, | ||||
| @@ -268,6 +272,7 @@ void Render::OnReceiveDataBufferCb(const char *data, size_t size, | ||||
|       LOG_INFO("Remote hostname: [{}]", props->remote_host_name_); | ||||
|     } | ||||
|   } else { | ||||
|     // remote | ||||
|     if (ControlType::mouse == remote_action.type && render->mouse_controller_) { | ||||
|       render->mouse_controller_->SendMouseCommand(remote_action); | ||||
|     } else if (ControlType::audio_capture == remote_action.type) { | ||||
| @@ -283,6 +288,10 @@ void Render::OnReceiveDataBufferCb(const char *data, size_t size, | ||||
|       render->keyboard_capturer_->SendKeyboardCommand( | ||||
|           (int)remote_action.k.key_value, | ||||
|           remote_action.k.flag == KeyFlag::key_down); | ||||
|     } else if (ControlType::display_id == remote_action.type) { | ||||
|       if (render->screen_capturer_) { | ||||
|         render->screen_capturer_->SwitchTo(remote_action.d); | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -79,6 +79,7 @@ int Render::StreamWindow() { | ||||
|           props->render_window_y_ = pos.y; | ||||
|           props->render_window_width_ = size.x; | ||||
|           props->render_window_height_ = size.y; | ||||
|           UpdateRenderRect(); | ||||
|  | ||||
|           ControlWindow(props); | ||||
|  | ||||
| @@ -139,6 +140,7 @@ int Render::StreamWindow() { | ||||
|         props->render_window_y_ = pos.y; | ||||
|         props->render_window_width_ = size.x; | ||||
|         props->render_window_height_ = size.y; | ||||
|         UpdateRenderRect(); | ||||
|  | ||||
|         ControlWindow(props); | ||||
|         ImGui::End(); | ||||
| @@ -161,7 +163,7 @@ int Render::StreamWindow() { | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   UpdateRenderRect(); | ||||
|   // UpdateRenderRect(); | ||||
|   ImGui::End();  // End VideoBg | ||||
|  | ||||
|   return 0; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user