[feat] change recent connections layout

This commit is contained in:
dijunkun
2024-11-14 17:13:38 +08:00
parent 6eac8380b6
commit a067441fb9
3 changed files with 105 additions and 53 deletions

View File

@@ -74,29 +74,36 @@ int Render::ShowRecentConnections() {
int recent_connection_sub_container_width = int recent_connection_sub_container_width =
recent_connection_image_width_ + 16.0f; recent_connection_image_width_ + 16.0f;
int recent_connection_sub_container_height = int recent_connection_sub_container_height =
recent_connection_image_height_ + 32.0f; recent_connection_image_height_ + 36.0f;
ImGui::PushStyleColor(ImGuiCol_ChildBg, ImVec4(1.0f, 1.0f, 1.0f, 1.0f)); ImGui::PushStyleColor(ImGuiCol_ChildBg,
ImVec4(239.0 / 255, 240.0 / 255, 242.0 / 255, 1.0f));
ImGui::PushStyleVar(ImGuiStyleVar_ChildRounding, 10.0f);
ImGui::BeginChild("RecentConnectionsContainer", ImGui::BeginChild("RecentConnectionsContainer",
ImVec2(main_window_width_default_ - 50.0f, 152.0f), ImVec2(main_window_width_default_ - 50.0f, 145.0f),
ImGuiChildFlags_Border, ImGuiChildFlags_Border,
ImGuiWindowFlags_NoResize | ImGuiWindowFlags_NoCollapse | ImGuiWindowFlags_NoResize | ImGuiWindowFlags_NoCollapse |
ImGuiWindowFlags_NoMove | ImGuiWindowFlags_NoTitleBar | ImGuiWindowFlags_NoMove | ImGuiWindowFlags_NoTitleBar |
ImGuiWindowFlags_NoBringToFrontOnFocus | ImGuiWindowFlags_NoBringToFrontOnFocus |
ImGuiWindowFlags_AlwaysHorizontalScrollbar); ImGuiWindowFlags_AlwaysHorizontalScrollbar |
ImGuiWindowFlags_NoScrollbar |
ImGuiWindowFlags_NoScrollWithMouse);
ImGui::PopStyleVar();
ImGui::PopStyleColor(); ImGui::PopStyleColor();
int recent_connections_count = recent_connection_textures_.size(); int recent_connections_count = recent_connection_textures_.size();
int count = 0; int count = 0;
int button_width = 20; int button_width = 22;
int button_height = 20; int button_height = 22;
for (auto it = recent_connection_textures_.begin(); for (auto it = recent_connection_textures_.begin();
it != recent_connection_textures_.end(); ++it) { it != recent_connection_textures_.end(); ++it) {
sub_containers_pos[it->first] = ImGui::GetCursorPos(); sub_containers_pos[it->first] = ImGui::GetCursorPos();
std::string recent_connection_sub_window_name = std::string recent_connection_sub_window_name =
"RecentConnectionsSubContainer" + it->first; "RecentConnectionsSubContainer" + it->first;
// recent connections sub container
ImGui::BeginChild(recent_connection_sub_window_name.c_str(), ImGui::BeginChild(recent_connection_sub_window_name.c_str(),
ImVec2(recent_connection_sub_container_width, ImVec2(recent_connection_sub_container_width,
recent_connection_sub_container_height), recent_connection_sub_container_height),
ImGuiChildFlags_Border, ImGuiChildFlags_None,
ImGuiWindowFlags_NoResize | ImGuiWindowFlags_NoCollapse | ImGuiWindowFlags_NoResize | ImGuiWindowFlags_NoCollapse |
ImGuiWindowFlags_NoMove | ImGuiWindowFlags_NoMove |
ImGuiWindowFlags_NoTitleBar | ImGuiWindowFlags_NoTitleBar |
@@ -109,8 +116,8 @@ int Render::ShowRecentConnections() {
// remote id length is 9 // remote id length is 9
// password length is 6 // password length is 6
// connection_info -> remote_id + Y + password + host_name // connection_info -> remote_id + 'Y' + password + host_name
// -> remote_id + N + host_name // -> remote_id + 'N' + host_name
if ('Y' == connection_info[9] && connection_info.size() >= 16) { if ('Y' == connection_info[9] && connection_info.size() >= 16) {
remote_id = connection_info.substr(0, 9); remote_id = connection_info.substr(0, 9);
password = connection_info.substr(10, 6); password = connection_info.substr(10, 6);
@@ -122,66 +129,111 @@ int Render::ShowRecentConnections() {
host_name = "unknown"; host_name = "unknown";
} }
ImGui::SetWindowFontScale(0.4f); ImVec2 image_screen_pos = ImVec2(ImGui::GetCursorScreenPos().x + 5.0f,
ImVec2 window_size = ImGui::GetWindowSize(); ImGui::GetCursorScreenPos().y + 5.0f);
ImVec2 text_size = ImGui::CalcTextSize(host_name.c_str()); ImVec2 image_pos =
ImVec2 pos = ImGui::GetCursorPos(); ImVec2(ImGui::GetCursorPosX() + 5.0f, ImGui::GetCursorPosY() + 5.0f);
pos.x = (window_size.x - text_size.x) / 2.0f; ImGui::SetCursorPos(image_pos);
ImGui::SetCursorPos(pos);
ImGui::Text(host_name.c_str());
ImGui::SetWindowFontScale(1.0f);
ImVec2 image_pos = ImGui::GetCursorPos();
ImGui::Image((ImTextureID)(intptr_t)it->second, ImGui::Image((ImTextureID)(intptr_t)it->second,
ImVec2((float)recent_connection_image_width_, ImVec2((float)recent_connection_image_width_,
(float)recent_connection_image_height_)); (float)recent_connection_image_height_));
ImGui::PushStyleColor(ImGuiCol_Button, ImVec4(1.0f, 1.0f, 1.0f, 0.8f)); // remote id display button
{
ImGui::PushStyleColor(ImGuiCol_Button, ImVec4(0, 0, 0, 0.2f));
ImGui::PushStyleColor(ImGuiCol_ButtonHovered, ImVec4(0, 0, 0, 0.2f));
ImGui::PushStyleColor(ImGuiCol_ButtonActive, ImVec4(0, 0, 0, 0.2f));
ImVec2 dummy_button_pos =
ImVec2(image_pos.x, image_pos.y + recent_connection_image_height_);
std::string dummy_button_name = "##DummyButton" + remote_id;
ImGui::SetCursorPos(dummy_button_pos);
ImGui::SetWindowFontScale(0.6f);
ImGui::Button(dummy_button_name.c_str(),
ImVec2(recent_connection_image_width_ - 2 * button_width,
button_height));
ImGui::SetCursorPos(
ImVec2(dummy_button_pos.x + 2.0f, dummy_button_pos.y + 1.0f));
ImGui::Text(remote_id.c_str());
ImGui::PopStyleColor(3);
if (ImGui::IsItemHovered()) {
ImGui::BeginTooltip();
ImGui::SetWindowFontScale(0.5f);
ImGui::Text(host_name.c_str());
ImGui::SetWindowFontScale(1.0f);
ImGui::EndTooltip();
}
}
ImGui::PushStyleColor(ImGuiCol_Button, ImVec4(0, 0, 0, 0.2f));
ImGui::PushStyleColor(ImGuiCol_ButtonHovered, ImGui::PushStyleColor(ImGuiCol_ButtonHovered,
ImVec4(0.1f, 0.4f, 0.8f, 1.0f)); ImVec4(0.1f, 0.4f, 0.8f, 1.0f));
ImGui::PushStyleColor(ImGuiCol_ButtonActive, ImGui::PushStyleColor(ImGuiCol_ButtonActive,
ImVec4(1.0f, 1.0f, 1.0f, 0.7f)); ImVec4(1.0f, 1.0f, 1.0f, 0.7f));
ImVec2 trash_can_button_pos =
ImVec2(image_pos.x,
image_pos.y + recent_connection_image_height_ - button_height);
ImGui::SetCursorPos(trash_can_button_pos);
ImGui::SetWindowFontScale(0.5f);
std::string trash_can = ICON_FA_TRASH_CAN;
std::string recent_connection_delete_button_name =
trash_can + "##RecentConnectionDelete" +
std::to_string(trash_can_button_pos.x);
if (ImGui::Button(recent_connection_delete_button_name.c_str())) {
show_confirm_delete_connection_ = true;
}
if (delete_connection_) { // trash button
if (!thumbnail_->DeleteThumbnail(it->first)) { {
reload_recent_connections_ = true; ImVec2 trash_can_button_pos = ImVec2(
delete_connection_ = false; image_pos.x + recent_connection_image_width_ - 2 * button_width,
image_pos.y + recent_connection_image_height_);
ImGui::SetCursorPos(trash_can_button_pos);
ImGui::SetWindowFontScale(0.5f);
std::string trash_can = ICON_FA_TRASH_CAN;
std::string recent_connection_delete_button_name =
trash_can + "##RecentConnectionDelete" +
std::to_string(trash_can_button_pos.x);
if (ImGui::Button(recent_connection_delete_button_name.c_str(),
ImVec2(button_width, button_height))) {
show_confirm_delete_connection_ = true;
}
if (delete_connection_) {
if (!thumbnail_->DeleteThumbnail(it->first)) {
reload_recent_connections_ = true;
delete_connection_ = false;
}
} }
} }
ImVec2 connect_button_pos = // connect button
ImVec2(image_pos.x + recent_connection_image_width_ - button_width, {
image_pos.y + recent_connection_image_height_ - button_height); ImVec2 connect_button_pos =
ImGui::SetCursorPos(connect_button_pos); ImVec2(image_pos.x + recent_connection_image_width_ - button_width,
std::string connect = ICON_FA_ARROW_RIGHT_LONG; image_pos.y + recent_connection_image_height_);
std::string connect_to_this_connection_button_name = ImGui::SetCursorPos(connect_button_pos);
connect + "##ConnectionTo" + it->first; std::string connect = ICON_FA_ARROW_RIGHT_LONG;
if (ImGui::Button(connect_to_this_connection_button_name.c_str(), std::string connect_to_this_connection_button_name =
ImVec2(button_width, button_height))) { connect + "##ConnectionTo" + it->first;
LOG_ERROR("Connect to [{}], password [{}]", remote_id.c_str(), if (ImGui::Button(connect_to_this_connection_button_name.c_str(),
password.c_str()); ImVec2(button_width, button_height))) {
remote_id_ = remote_id; LOG_ERROR("Connect to [{}], password [{}]", remote_id.c_str(),
strncpy(remote_password_, password.c_str(), 6); password.c_str());
ConnectTo(); remote_id_ = remote_id;
strncpy(remote_password_, password.c_str(), 6);
ConnectTo();
}
} }
ImGui::SetWindowFontScale(1.0f); ImGui::SetWindowFontScale(1.0f);
ImGui::PopStyleColor(3); ImGui::PopStyleColor(3);
ImGui::EndChild(); ImGui::EndChild();
// 绘制纵向分割线
if (count != recent_connections_count - 1) {
ImVec2 line_start =
ImVec2(image_screen_pos.x + recent_connection_image_width_ + 20.0f,
image_screen_pos.y); // 起点
ImVec2 line_end = ImVec2(
image_screen_pos.x + recent_connection_image_width_ + 20.0f,
image_screen_pos.y + recent_connection_image_height_ + button_height);
ImGui::GetForegroundDrawList()->AddLine(line_start, line_end,
IM_COL32(0, 0, 0, 122), 1.0f);
}
count++; count++;
ImGui::SameLine(0, count != recent_connections_count ? 23.0f : 0.0f); ImGui::SameLine(0, count != recent_connections_count ? 26.0f : 0.0f);
} }
ImGui::EndChild(); ImGui::EndChild();

View File

@@ -533,7 +533,6 @@ int Render::SetupFontAndStyle() {
30.0f, &config, icon_ranges); 30.0f, &config, icon_ranges);
io.Fonts->Build(); io.Fonts->Build();
// Setup Dear ImGui style // Setup Dear ImGui style
// ImGui::StyleColorsDark(); // ImGui::StyleColorsDark();
ImGui::StyleColorsLight(); ImGui::StyleColorsLight();
@@ -842,6 +841,7 @@ int Render::Run() {
audio_capture_button_pressed_ = false; audio_capture_button_pressed_ = false;
fullscreen_button_pressed_ = false; fullscreen_button_pressed_ = false;
reload_recent_connections_ = true; reload_recent_connections_ = true;
remember_password_ = false;
SDL_SetWindowFullscreen(main_window_, SDL_FALSE); SDL_SetWindowFullscreen(main_window_, SDL_FALSE);
memset(audio_buffer_, 0, 720); memset(audio_buffer_, 0, 720);

View File

@@ -97,13 +97,13 @@ int Thumbnail::SaveToThumbnail(const char* yuv420p, int width, int height,
std::string image_name; std::string image_name;
if (password.empty()) { if (password.empty()) {
image_name = remote_id + "N" + host_name; image_name = remote_id + 'N' + host_name;
} else { } else {
// delete the file which has no password in its name // delete the file which has no password in its name
std::string filename_without_password = remote_id + "N" + host_name; std::string filename_without_password = remote_id + "N" + host_name;
DeleteThumbnail(filename_without_password); DeleteThumbnail(filename_without_password);
image_name = remote_id + "Y" + password + host_name; image_name = remote_id + 'Y' + password + host_name;
} }
std::string ciphertext = AES_encrypt(image_name, aes128_key_, aes128_iv_); std::string ciphertext = AES_encrypt(image_name, aes128_key_, aes128_iv_);