mirror of
				https://github.com/kunkundi/crossdesk.git
				synced 2025-10-27 04:35:34 +08:00 
			
		
		
		
	Finish remote desk gui
This commit is contained in:
		| @@ -1,207 +0,0 @@ | ||||
| // Dear ImGui: standalone example application for SDL2 + SDL_Renderer | ||||
| // (SDL is a cross-platform general purpose library for handling windows, | ||||
| // inputs, OpenGL/Vulkan/Metal graphics context creation, etc.) | ||||
|  | ||||
| // Learn about Dear ImGui: | ||||
| // - FAQ                  https://dearimgui.com/faq | ||||
| // - Getting Started      https://dearimgui.com/getting-started | ||||
| // - Documentation        https://dearimgui.com/docs (same as your local docs/ | ||||
| // folder). | ||||
| // - Introduction, links and more at the top of imgui.cpp | ||||
|  | ||||
| // Important to understand: SDL_Renderer is an _optional_ component of SDL2. | ||||
| // For a multi-platform app consider using e.g. SDL+DirectX on Windows and | ||||
| // SDL+OpenGL on Linux/OSX. | ||||
|  | ||||
| #include <SDL.h> | ||||
| #include <stdio.h> | ||||
|  | ||||
| #include "imgui.h" | ||||
| #include "imgui_impl_sdl2.h" | ||||
| #include "imgui_impl_sdlrenderer2.h" | ||||
|  | ||||
| #if !SDL_VERSION_ATLEAST(2, 0, 17) | ||||
| #error This backend requires SDL 2.0.17+ because of SDL_RenderGeometry() function | ||||
| #endif | ||||
|  | ||||
| // Main code | ||||
| int main(int, char**) { | ||||
|   // Setup SDL | ||||
|   if (SDL_Init(SDL_INIT_VIDEO | SDL_INIT_TIMER | SDL_INIT_GAMECONTROLLER) != | ||||
|       0) { | ||||
|     printf("Error: %s\n", SDL_GetError()); | ||||
|     return -1; | ||||
|   } | ||||
|  | ||||
|   // From 2.0.18: Enable native IME. | ||||
| #ifdef SDL_HINT_IME_SHOW_UI | ||||
|   SDL_SetHint(SDL_HINT_IME_SHOW_UI, "1"); | ||||
| #endif | ||||
|  | ||||
|   // Create window with SDL_Renderer graphics context | ||||
|   SDL_WindowFlags window_flags = | ||||
|       (SDL_WindowFlags)(SDL_WINDOW_RESIZABLE | SDL_WINDOW_ALLOW_HIGHDPI); | ||||
|   SDL_Window* window = SDL_CreateWindow( | ||||
|       "Dear ImGui SDL2+SDL_Renderer example", SDL_WINDOWPOS_CENTERED, | ||||
|       SDL_WINDOWPOS_CENTERED, 1280, 720, window_flags); | ||||
|   SDL_Renderer* renderer = SDL_CreateRenderer( | ||||
|       window, -1, SDL_RENDERER_PRESENTVSYNC | SDL_RENDERER_ACCELERATED); | ||||
|   if (renderer == nullptr) { | ||||
|     SDL_Log("Error creating SDL_Renderer!"); | ||||
|     return 0; | ||||
|   } | ||||
|   // SDL_RendererInfo info; | ||||
|   // SDL_GetRendererInfo(renderer, &info); | ||||
|   // SDL_Log("Current SDL_Renderer: %s", info.name); | ||||
|  | ||||
|   // Setup Dear ImGui context | ||||
|   IMGUI_CHECKVERSION(); | ||||
|   ImGui::CreateContext(); | ||||
|   ImGuiIO& io = ImGui::GetIO(); | ||||
|   (void)io; | ||||
|   io.ConfigFlags |= | ||||
|       ImGuiConfigFlags_NavEnableKeyboard;  // Enable Keyboard Controls | ||||
|   io.ConfigFlags |= | ||||
|       ImGuiConfigFlags_NavEnableGamepad;  // Enable Gamepad Controls | ||||
|  | ||||
|   // Setup Dear ImGui style | ||||
|   ImGui::StyleColorsDark(); | ||||
|   // ImGui::StyleColorsLight(); | ||||
|  | ||||
|   // Setup Platform/Renderer backends | ||||
|   ImGui_ImplSDL2_InitForSDLRenderer(window, renderer); | ||||
|   ImGui_ImplSDLRenderer2_Init(renderer); | ||||
|  | ||||
|   // Load Fonts | ||||
|   // - If no fonts are loaded, dear imgui will use the default font. You can | ||||
|   // also load multiple fonts and use ImGui::PushFont()/PopFont() to select | ||||
|   // them. | ||||
|   // - AddFontFromFileTTF() will return the ImFont* so you can store it if you | ||||
|   // need to select the font among multiple. | ||||
|   // - If the file cannot be loaded, the function will return a nullptr. Please | ||||
|   // handle those errors in your application (e.g. use an assertion, or display | ||||
|   // an error and quit). | ||||
|   // - The fonts will be rasterized at a given size (w/ oversampling) and stored | ||||
|   // into a texture when calling ImFontAtlas::Build()/GetTexDataAsXXXX(), which | ||||
|   // ImGui_ImplXXXX_NewFrame below will call. | ||||
|   // - Use '#define IMGUI_ENABLE_FREETYPE' in your imconfig file to use Freetype | ||||
|   // for higher quality font rendering. | ||||
|   // - Read 'docs/FONTS.md' for more instructions and details. | ||||
|   // - Remember that in C/C++ if you want to include a backslash \ in a string | ||||
|   // literal you need to write a double backslash \\ ! | ||||
|   // io.Fonts->AddFontDefault(); | ||||
|   // io.Fonts->AddFontFromFileTTF("c:\\Windows\\Fonts\\segoeui.ttf", 18.0f); | ||||
|   // io.Fonts->AddFontFromFileTTF("../../misc/fonts/DroidSans.ttf", 16.0f); | ||||
|   // io.Fonts->AddFontFromFileTTF("../../misc/fonts/Roboto-Medium.ttf", 16.0f); | ||||
|   // io.Fonts->AddFontFromFileTTF("../../misc/fonts/Cousine-Regular.ttf", 15.0f); | ||||
|   // ImFont* font = | ||||
|   // io.Fonts->AddFontFromFileTTF("c:\\Windows\\Fonts\\ArialUni.ttf", 18.0f, | ||||
|   // nullptr, io.Fonts->GetGlyphRangesJapanese()); IM_ASSERT(font != nullptr); | ||||
|  | ||||
|   // Our state | ||||
|   bool show_demo_window = true; | ||||
|   bool show_another_window = false; | ||||
|   ImVec4 clear_color = ImVec4(0.45f, 0.55f, 0.60f, 1.00f); | ||||
|  | ||||
|   // Main loop | ||||
|   bool done = false; | ||||
|   while (!done) { | ||||
|     // Poll and handle events (inputs, window resize, etc.) | ||||
|     // You can read the io.WantCaptureMouse, io.WantCaptureKeyboard flags to | ||||
|     // tell if dear imgui wants to use your inputs. | ||||
|     // - When io.WantCaptureMouse is true, do not dispatch mouse input data to | ||||
|     // your main application, or clear/overwrite your copy of the mouse data. | ||||
|     // - When io.WantCaptureKeyboard is true, do not dispatch keyboard input | ||||
|     // data to your main application, or clear/overwrite your copy of the | ||||
|     // keyboard data. Generally you may always pass all inputs to dear imgui, | ||||
|     // and hide them from your application based on those two flags. | ||||
|     SDL_Event event; | ||||
|     while (SDL_PollEvent(&event)) { | ||||
|       ImGui_ImplSDL2_ProcessEvent(&event); | ||||
|       if (event.type == SDL_QUIT) done = true; | ||||
|       if (event.type == SDL_WINDOWEVENT && | ||||
|           event.window.event == SDL_WINDOWEVENT_CLOSE && | ||||
|           event.window.windowID == SDL_GetWindowID(window)) | ||||
|         done = true; | ||||
|     } | ||||
|  | ||||
|     // Start the Dear ImGui frame | ||||
|     ImGui_ImplSDLRenderer2_NewFrame(); | ||||
|     ImGui_ImplSDL2_NewFrame(); | ||||
|     ImGui::NewFrame(); | ||||
|  | ||||
|     // 1. Show the big demo window (Most of the sample code is in | ||||
|     // ImGui::ShowDemoWindow()! You can browse its code to learn more about Dear | ||||
|     // ImGui!). | ||||
|     if (show_demo_window) ImGui::ShowDemoWindow(&show_demo_window); | ||||
|  | ||||
|     // 2. Show a simple window that we create ourselves. We use a Begin/End pair | ||||
|     // to create a named window. | ||||
|     { | ||||
|       static float f = 0.0f; | ||||
|       static int counter = 0; | ||||
|  | ||||
|       ImGui::Begin("Hello, world!");  // Create a window called "Hello, world!" | ||||
|                                       // and append into it. | ||||
|  | ||||
|       ImGui::Text("This is some useful text.");  // Display some text (you can | ||||
|                                                  // use a format strings too) | ||||
|       ImGui::Checkbox( | ||||
|           "Demo Window", | ||||
|           &show_demo_window);  // Edit bools storing our window open/close state | ||||
|       ImGui::Checkbox("Another Window", &show_another_window); | ||||
|  | ||||
|       ImGui::SliderFloat( | ||||
|           "float", &f, 0.0f, | ||||
|           1.0f);  // Edit 1 float using a slider from 0.0f to 1.0f | ||||
|       ImGui::ColorEdit3( | ||||
|           "clear color", | ||||
|           (float*)&clear_color);  // Edit 3 floats representing a color | ||||
|  | ||||
|       if (ImGui::Button( | ||||
|               "Button"))  // Buttons return true when clicked (most widgets | ||||
|                           // return true when edited/activated) | ||||
|         counter++; | ||||
|       ImGui::SameLine(); | ||||
|       ImGui::Text("counter = %d", counter); | ||||
|  | ||||
|       ImGui::Text("Application average %.3f ms/frame (%.1f FPS)", | ||||
|                   1000.0f / io.Framerate, io.Framerate); | ||||
|       ImGui::End(); | ||||
|     } | ||||
|  | ||||
|     // 3. Show another simple window. | ||||
|     if (show_another_window) { | ||||
|       ImGui::Begin( | ||||
|           "Another Window", | ||||
|           &show_another_window);  // Pass a pointer to our bool variable (the | ||||
|                                   // window will have a closing button that will | ||||
|                                   // clear the bool when clicked) | ||||
|       ImGui::Text("Hello from another window!"); | ||||
|       if (ImGui::Button("Close Me")) show_another_window = false; | ||||
|       ImGui::End(); | ||||
|     } | ||||
|  | ||||
|     // Rendering | ||||
|     ImGui::Render(); | ||||
|     SDL_RenderSetScale(renderer, io.DisplayFramebufferScale.x, | ||||
|                        io.DisplayFramebufferScale.y); | ||||
|     SDL_SetRenderDrawColor( | ||||
|         renderer, (Uint8)(clear_color.x * 255), (Uint8)(clear_color.y * 255), | ||||
|         (Uint8)(clear_color.z * 255), (Uint8)(clear_color.w * 255)); | ||||
|     SDL_RenderClear(renderer); | ||||
|     ImGui_ImplSDLRenderer2_RenderDrawData(ImGui::GetDrawData()); | ||||
|     SDL_RenderPresent(renderer); | ||||
|   } | ||||
|  | ||||
|   // Cleanup | ||||
|   ImGui_ImplSDLRenderer2_Shutdown(); | ||||
|   ImGui_ImplSDL2_Shutdown(); | ||||
|   ImGui::DestroyContext(); | ||||
|  | ||||
|   SDL_DestroyRenderer(renderer); | ||||
|   SDL_DestroyWindow(window); | ||||
|   SDL_Quit(); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
| @@ -1,6 +1,7 @@ | ||||
| #include <SDL.h> | ||||
| #include <stdio.h> | ||||
| #ifdef _WIN32 | ||||
| #pragma comment(linker, "/subsystem:\"windows\" /entry:\"mainCRTStartup\"") | ||||
| #include <Winsock2.h> | ||||
| #include <iphlpapi.h> | ||||
| #elif __APPLE__ | ||||
| @@ -57,7 +58,8 @@ std::string window_title = "Remote Desk Client"; | ||||
| #define QUIT_EVENT (SDL_USEREVENT + 2) | ||||
|  | ||||
| int thread_exit = 0; | ||||
| PeerPtr *peer = nullptr; | ||||
| PeerPtr *peer_server = nullptr; | ||||
| PeerPtr *peer_client = nullptr; | ||||
| bool joined = false; | ||||
| bool received_frame = false; | ||||
|  | ||||
| @@ -119,7 +121,7 @@ inline int ProcessMouseKeyEven(SDL_Event &ev) { | ||||
|       remote_action.m.x = ev.button.x * ratio; | ||||
|       remote_action.m.y = ev.button.y * ratio; | ||||
|  | ||||
|       SendData(peer, DATA_TYPE::DATA, (const char *)&remote_action, | ||||
|       SendData(peer_client, DATA_TYPE::DATA, (const char *)&remote_action, | ||||
|                sizeof(remote_action)); | ||||
|  | ||||
|     } else if (SDL_BUTTON_RIGHT == ev.button.button) { | ||||
| @@ -132,7 +134,7 @@ inline int ProcessMouseKeyEven(SDL_Event &ev) { | ||||
|       remote_action.m.x = ev.button.x * ratio; | ||||
|       remote_action.m.y = ev.button.y * ratio; | ||||
|  | ||||
|       SendData(peer, DATA_TYPE::DATA, (const char *)&remote_action, | ||||
|       SendData(peer_client, DATA_TYPE::DATA, (const char *)&remote_action, | ||||
|                sizeof(remote_action)); | ||||
|     } | ||||
|   } else if (SDL_MOUSEBUTTONUP == ev.type) { | ||||
| @@ -146,7 +148,7 @@ inline int ProcessMouseKeyEven(SDL_Event &ev) { | ||||
|       remote_action.m.x = ev.button.x * ratio; | ||||
|       remote_action.m.y = ev.button.y * ratio; | ||||
|  | ||||
|       SendData(peer, DATA_TYPE::DATA, (const char *)&remote_action, | ||||
|       SendData(peer_client, DATA_TYPE::DATA, (const char *)&remote_action, | ||||
|                sizeof(remote_action)); | ||||
|  | ||||
|     } else if (SDL_BUTTON_RIGHT == ev.button.button) { | ||||
| @@ -159,7 +161,7 @@ inline int ProcessMouseKeyEven(SDL_Event &ev) { | ||||
|       remote_action.m.x = ev.button.x * ratio; | ||||
|       remote_action.m.y = ev.button.y * ratio; | ||||
|  | ||||
|       SendData(peer, DATA_TYPE::DATA, (const char *)&remote_action, | ||||
|       SendData(peer_client, DATA_TYPE::DATA, (const char *)&remote_action, | ||||
|                sizeof(remote_action)); | ||||
|     } | ||||
|   } else if (SDL_MOUSEMOTION == ev.type) { | ||||
| @@ -173,7 +175,7 @@ inline int ProcessMouseKeyEven(SDL_Event &ev) { | ||||
|     remote_action.m.x = ev.button.x * ratio; | ||||
|     remote_action.m.y = ev.button.y * ratio; | ||||
|  | ||||
|     SendData(peer, DATA_TYPE::DATA, (const char *)&remote_action, | ||||
|     SendData(peer_client, DATA_TYPE::DATA, (const char *)&remote_action, | ||||
|              sizeof(remote_action)); | ||||
|   } else if (SDL_QUIT == ev.type) { | ||||
|     SDL_Event event; | ||||
| @@ -205,8 +207,46 @@ void ReceiveAudioBuffer(const char *data, size_t size, const char *user_id, | ||||
|  | ||||
| void ReceiveDataBuffer(const char *data, size_t size, const char *user_id, | ||||
|                        size_t user_id_size) { | ||||
|   std::cout << "Receive data, size " << size << ", user [" << user_id << "] " | ||||
|             << std::endl; | ||||
|   std::string user(user_id, user_id_size); | ||||
|  | ||||
|   RemoteAction remote_action; | ||||
|   memcpy(&remote_action, data, sizeof(remote_action)); | ||||
|  | ||||
|   std::cout << "remote_action: " << remote_action.type << " " | ||||
|             << remote_action.m.flag << " " << remote_action.m.x << " " | ||||
|             << remote_action.m.y << std::endl; | ||||
|  | ||||
|   INPUT ip; | ||||
|  | ||||
|   if (remote_action.type == ControlType::mouse) { | ||||
|     ip.type = INPUT_MOUSE; | ||||
|     ip.mi.dx = remote_action.m.x * screen_w / 1280; | ||||
|     ip.mi.dy = remote_action.m.y * screen_h / 720; | ||||
|     if (remote_action.m.flag == MouseFlag::left_down) { | ||||
|       ip.mi.dwFlags = MOUSEEVENTF_LEFTDOWN | MOUSEEVENTF_ABSOLUTE; | ||||
|     } else if (remote_action.m.flag == MouseFlag::left_up) { | ||||
|       ip.mi.dwFlags = MOUSEEVENTF_LEFTUP | MOUSEEVENTF_ABSOLUTE; | ||||
|     } else if (remote_action.m.flag == MouseFlag::right_down) { | ||||
|       ip.mi.dwFlags = MOUSEEVENTF_RIGHTDOWN | MOUSEEVENTF_ABSOLUTE; | ||||
|     } else if (remote_action.m.flag == MouseFlag::right_up) { | ||||
|       ip.mi.dwFlags = MOUSEEVENTF_RIGHTUP | MOUSEEVENTF_ABSOLUTE; | ||||
|     } else { | ||||
|       ip.mi.dwFlags = MOUSEEVENTF_MOVE; | ||||
|     } | ||||
|     ip.mi.mouseData = 0; | ||||
|     ip.mi.time = 0; | ||||
|  | ||||
|     // Set cursor pos | ||||
|     SetCursorPos(ip.mi.dx, ip.mi.dy); | ||||
|     // Send the press | ||||
|     if (ip.mi.dwFlags != MOUSEEVENTF_MOVE) { | ||||
|       SendInput(1, &ip, sizeof(INPUT)); | ||||
|     } | ||||
|  | ||||
|     std::cout << "Receive data from [" << user << "], " << ip.type << " " | ||||
|               << ip.mi.dwFlags << " " << ip.mi.dx << " " << ip.mi.dy | ||||
|               << std::endl; | ||||
|   } | ||||
| } | ||||
|  | ||||
| std::string GetMac(char *mac_addr) { | ||||
| @@ -328,7 +368,8 @@ int main() { | ||||
|   char mac_addr[10]; | ||||
|   GetMac(mac_addr); | ||||
|  | ||||
|   peer = CreatePeer(¶ms); | ||||
|   peer_server = CreatePeer(¶ms); | ||||
|   peer_client = CreatePeer(¶ms); | ||||
|  | ||||
|   // Setup SDL | ||||
|   if (SDL_Init(SDL_INIT_VIDEO | SDL_INIT_TIMER | SDL_INIT_GAMECONTROLLER) != | ||||
| @@ -402,7 +443,7 @@ int main() { | ||||
|  | ||||
|       const ImGuiViewport *main_viewport = ImGui::GetMainViewport(); | ||||
|       ImGui::SetNextWindowPos(ImVec2(0, 0), ImGuiCond_Once); | ||||
|       ImGui::SetNextWindowSize(ImVec2(180, 185)); | ||||
|       ImGui::SetNextWindowSize(ImVec2(180, 138)); | ||||
|  | ||||
|       ImGui::Begin("Menu", nullptr, ImGuiWindowFlags_NoResize); | ||||
|  | ||||
| @@ -418,82 +459,89 @@ int main() { | ||||
|         } | ||||
|  | ||||
|         ImGui::Spacing(); | ||||
|         static bool buttonPressed = false; | ||||
|         static const char *label = "Online"; | ||||
|         { | ||||
|           static bool online_button_pressed = false; | ||||
|           static const char *online_label = "Online"; | ||||
|  | ||||
|         if (ImGui::Button(label)) { | ||||
|           std::string user_id = "S-" + std::string(GetMac(mac_addr)); | ||||
|           if (ImGui::Button(online_label)) { | ||||
|             std::string user_id = "S-" + std::string(GetMac(mac_addr)); | ||||
|  | ||||
|           if (strcmp(label, "Online") == 0) { | ||||
|             CreateConnection(peer, mac_addr, user_id.c_str()); | ||||
|             if (strcmp(online_label, "Online") == 0) { | ||||
|               CreateConnection(peer_server, mac_addr, user_id.c_str()); | ||||
|  | ||||
|             nv12_buffer_ = new char[NV12_BUFFER_SIZE]; | ||||
|               nv12_buffer_ = new char[NV12_BUFFER_SIZE]; | ||||
|  | ||||
|             screen_capture = new ScreenCaptureWgc(); | ||||
|               screen_capture = new ScreenCaptureWgc(); | ||||
|  | ||||
|             RECORD_DESKTOP_RECT rect; | ||||
|             rect.left = 0; | ||||
|             rect.top = 0; | ||||
|             rect.right = GetSystemMetrics(SM_CXSCREEN); | ||||
|             rect.bottom = GetSystemMetrics(SM_CYSCREEN); | ||||
|               RECORD_DESKTOP_RECT rect; | ||||
|               rect.left = 0; | ||||
|               rect.top = 0; | ||||
|               rect.right = GetSystemMetrics(SM_CXSCREEN); | ||||
|               rect.bottom = GetSystemMetrics(SM_CYSCREEN); | ||||
|  | ||||
|             screen_w = GetSystemMetrics(SM_CXSCREEN); | ||||
|             screen_h = GetSystemMetrics(SM_CYSCREEN); | ||||
|               screen_w = GetSystemMetrics(SM_CXSCREEN); | ||||
|               screen_h = GetSystemMetrics(SM_CYSCREEN); | ||||
|  | ||||
|             last_frame_time_ = std::chrono::high_resolution_clock::now(); | ||||
|             screen_capture->Init( | ||||
|                 rect, 60, | ||||
|                 [](unsigned char *data, int size, int width, | ||||
|                    int height) -> void { | ||||
|                   // std::cout << "Send" << std::endl; | ||||
|               last_frame_time_ = std::chrono::high_resolution_clock::now(); | ||||
|               screen_capture->Init( | ||||
|                   rect, 60, | ||||
|                   [](unsigned char *data, int size, int width, | ||||
|                      int height) -> void { | ||||
|                     // std::cout << "Send" << std::endl; | ||||
|  | ||||
|                   auto now_time = std::chrono::high_resolution_clock::now(); | ||||
|                   std::chrono::duration<double> duration = | ||||
|                       now_time - last_frame_time_; | ||||
|                   auto tc = duration.count() * 1000; | ||||
|                     auto now_time = std::chrono::high_resolution_clock::now(); | ||||
|                     std::chrono::duration<double> duration = | ||||
|                         now_time - last_frame_time_; | ||||
|                     auto tc = duration.count() * 1000; | ||||
|  | ||||
|                   if (tc >= 0) { | ||||
|                     BGRAToNV12FFmpeg(data, width, height, | ||||
|                                      (unsigned char *)nv12_buffer_); | ||||
|                     SendData(peer, DATA_TYPE::VIDEO, (const char *)nv12_buffer_, | ||||
|                              NV12_BUFFER_SIZE); | ||||
|                     last_frame_time_ = now_time; | ||||
|                   } | ||||
|                 }); | ||||
|                     if (tc >= 0) { | ||||
|                       BGRAToNV12FFmpeg(data, width, height, | ||||
|                                        (unsigned char *)nv12_buffer_); | ||||
|                       SendData(peer_server, DATA_TYPE::VIDEO, | ||||
|                                (const char *)nv12_buffer_, NV12_BUFFER_SIZE); | ||||
|                       last_frame_time_ = now_time; | ||||
|                     } | ||||
|                   }); | ||||
|  | ||||
|             screen_capture->Start(); | ||||
|           } else { | ||||
|             LeaveConnection(peer); | ||||
|               screen_capture->Start(); | ||||
|             } else { | ||||
|               LeaveConnection(peer_server); | ||||
|             } | ||||
|             online_button_pressed = !online_button_pressed; | ||||
|             online_label = online_button_pressed ? "Offline" : "Online"; | ||||
|           } | ||||
|           buttonPressed = !buttonPressed; | ||||
|           label = buttonPressed ? "Offline" : "Online"; | ||||
|         } | ||||
|       } | ||||
|  | ||||
|       ImGui::Spacing(); | ||||
|  | ||||
|       ImGui::Separator(); | ||||
|  | ||||
|       ImGui::Spacing(); | ||||
|  | ||||
|       { | ||||
|         static char buf[20] = ""; | ||||
|         ImGui::Text("REMOTE ID:"); | ||||
|         ImGui::SameLine(); | ||||
|         ImGui::SetNextItemWidth(114); | ||||
|         ImGui::InputTextWithHint("", "000000", buf, IM_ARRAYSIZE(buf), | ||||
|                                  ImGuiInputTextFlags_AllowTabInput); | ||||
|  | ||||
|         ImGui::Spacing(); | ||||
|         if (ImGui::Button("Connect") && !joined) { | ||||
|           std::string user_id = "C-" + std::string(GetMac(mac_addr)); | ||||
|           JoinConnection(peer, buf, user_id.c_str()); | ||||
|           joined = true; | ||||
|         } | ||||
|         ImGui::SameLine(); | ||||
|         if (ImGui::Button("Disconnect")) { | ||||
|           LeaveConnection(peer); | ||||
|           joined = false; | ||||
|  | ||||
|         ImGui::Separator(); | ||||
|  | ||||
|         ImGui::Spacing(); | ||||
|         { | ||||
|           static bool connect_button_pressed = false; | ||||
|           static const char *connect_label = "Connect"; | ||||
|           { | ||||
|             static char buf[20] = ""; | ||||
|             ImGui::Text("REMOTE ID:"); | ||||
|             ImGui::SameLine(); | ||||
|             ImGui::SetNextItemWidth(114); | ||||
|             ImGui::InputTextWithHint("", "000000", buf, IM_ARRAYSIZE(buf), | ||||
|                                      ImGuiInputTextFlags_AllowTabInput); | ||||
|  | ||||
|             ImGui::Spacing(); | ||||
|             if (ImGui::Button(connect_label)) { | ||||
|               if (strcmp(connect_label, "Connect") == 0 && !joined) { | ||||
|                 std::string user_id = "C-" + std::string(GetMac(mac_addr)); | ||||
|                 JoinConnection(peer_client, buf, user_id.c_str()); | ||||
|                 joined = true; | ||||
|               } else if (strcmp(connect_label, "Disconnect") == 0 && joined) { | ||||
|                 LeaveConnection(peer_client); | ||||
|                 joined = false; | ||||
|               } | ||||
|               connect_button_pressed = !connect_button_pressed; | ||||
|               connect_label = connect_button_pressed ? "Disconnect" : "Connect"; | ||||
|             } | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user