Combine server and client into a single program

This commit is contained in:
dijunkun
2023-10-09 17:31:55 +08:00
parent 50c6a24e26
commit 9f0653211e
3 changed files with 131 additions and 16 deletions

View File

@@ -23,12 +23,21 @@
#include <string>
#include <thread>
extern "C" {
#include <libavformat/avformat.h>
#include <libavutil/imgutils.h>
#include <libswscale/swscale.h>
};
#include "imgui.h"
#include "imgui_impl_sdl2.h"
#include "imgui_impl_sdlrenderer2.h"
#include "log.h"
#include "screen_capture_wgc.h"
#include "x.h"
#define NV12_BUFFER_SIZE 1280 * 720 * 3 / 2
int screen_w = 1280, screen_h = 720;
const int pixel_w = 1280, pixel_h = 720;
@@ -52,6 +61,11 @@ PeerPtr *peer = nullptr;
bool joined = false;
bool received_frame = false;
ScreenCaptureWgc *screen_capture = nullptr;
char *nv12_buffer_ = nullptr;
std::chrono::steady_clock::time_point last_frame_time_;
typedef enum { mouse = 0, keyboard } ControlType;
typedef enum { move = 0, left_down, left_up, right_down, right_up } MouseFlag;
typedef enum { key_down = 0, key_up } KeyFlag;
@@ -275,6 +289,30 @@ std::string GetMac(char *mac_addr) {
return mac_addr;
}
int BGRAToNV12FFmpeg(unsigned char *src_buffer, int width, int height,
unsigned char *dst_buffer) {
AVFrame *Input_pFrame = av_frame_alloc();
AVFrame *Output_pFrame = av_frame_alloc();
struct SwsContext *img_convert_ctx =
sws_getContext(width, height, AV_PIX_FMT_BGRA, 1280, 720, AV_PIX_FMT_NV12,
SWS_FAST_BILINEAR, nullptr, nullptr, nullptr);
av_image_fill_arrays(Input_pFrame->data, Input_pFrame->linesize, src_buffer,
AV_PIX_FMT_BGRA, width, height, 1);
av_image_fill_arrays(Output_pFrame->data, Output_pFrame->linesize, dst_buffer,
AV_PIX_FMT_NV12, 1280, 720, 1);
sws_scale(img_convert_ctx, (uint8_t const **)Input_pFrame->data,
Input_pFrame->linesize, 0, height, Output_pFrame->data,
Output_pFrame->linesize);
if (Input_pFrame) av_free(Input_pFrame);
if (Output_pFrame) av_free(Output_pFrame);
if (img_convert_ctx) sws_freeContext(img_convert_ctx);
return 0;
}
int main() {
LOG_INFO("Remote desk");
std::string default_cfg_path = "../../../../config/config.ini";
@@ -288,7 +326,7 @@ int main() {
std::string transmission_id = "000001";
char mac_addr[10];
std::string user_id = "C-" + std::string(GetMac(mac_addr));
GetMac(mac_addr);
peer = CreatePeer(&params);
@@ -364,18 +402,91 @@ int main() {
const ImGuiViewport *main_viewport = ImGui::GetMainViewport();
ImGui::SetNextWindowPos(ImVec2(0, 0), ImGuiCond_Once);
ImGui::SetNextWindowSize(ImVec2(160, 85));
ImGui::SetNextWindowSize(ImVec2(180, 185));
ImGui::Begin("Menu", nullptr, ImGuiWindowFlags_NoResize);
static char buf[10] = "";
ImGui::Text("ID:");
{
ImGui::Text("LOCAL ID:");
ImGui::SameLine();
ImGui::Selectable(mac_addr, false,
ImGuiSelectableFlags_AllowDoubleClick);
if (ImGui::IsItemHovered() && ImGui::IsMouseDoubleClicked(0)) {
ImGui::SetClipboardText(mac_addr);
}
ImGui::Spacing();
static bool buttonPressed = false;
static const char *label = "Online";
if (ImGui::Button(label)) {
std::string user_id = "S-" + std::string(GetMac(mac_addr));
if (strcmp(label, "Online") == 0) {
CreateConnection(peer, mac_addr, user_id.c_str());
nv12_buffer_ = new char[NV12_BUFFER_SIZE];
screen_capture = new ScreenCaptureWgc();
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);
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;
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;
}
});
screen_capture->Start();
} else {
LeaveConnection(peer);
}
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));
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;
}
@@ -384,6 +495,7 @@ int main() {
LeaveConnection(peer);
joined = false;
}
}
ImGui::End();
}

View File

@@ -77,7 +77,7 @@ target("remote_desk_client")
target("remote_desk_gui")
set_kind("binary")
add_deps("projectx")
add_deps("projectx", "screen_capture")
add_packages("log", "imgui", "sdl2")
add_files("remote_desk_gui/*.cpp")
add_includedirs("../../src/interface")

View File

@@ -36,6 +36,7 @@ int CreateConnection(PeerPtr *peer_ptr, const char *transmission_id,
peer_ptr->peer_connection->Create(peer_ptr->pc_params, transmission_id,
user_id);
LOG_INFO("CreateConnection");
return 0;
}
@@ -46,11 +47,13 @@ int JoinConnection(PeerPtr *peer_ptr, const char *transmission_id,
peer_ptr->peer_connection->Join(peer_ptr->pc_params, transmission_id,
user_id);
LOG_INFO("JoinConnection");
return 0;
}
int LeaveConnection(PeerPtr *peer_ptr) {
peer_ptr->peer_connection->Leave();
LOG_INFO("LeaveConnection");
return 0;
}