[feat] add close button in control bar

This commit is contained in:
dijunkun
2024-09-12 16:22:02 +08:00
parent d493b9a131
commit c3af40a3f0
4 changed files with 46 additions and 28 deletions

View File

@@ -44,27 +44,33 @@ int Render::ConnectionStatusWindow() {
text = localization::p2p_disconnected[localization_language_index_]; text = localization::p2p_disconnected[localization_language_index_];
ImGui::SetCursorPosX(connection_status_window_width_ * 3 / 7); ImGui::SetCursorPosX(connection_status_window_width_ * 3 / 7);
ImGui::SetCursorPosY(connection_status_window_height_ * 2 / 3); ImGui::SetCursorPosY(connection_status_window_height_ * 2 / 3);
// Cancel // ok
if (ImGui::Button( if (ImGui::Button(
localization::cancel[localization_language_index_].c_str())) { localization::ok[localization_language_index_].c_str()) ||
ImGui::IsKeyPressed(ImGuiKey_Enter) ||
ImGui::IsKeyPressed(ImGuiKey_Escape)) {
show_connection_status_window_ = false; show_connection_status_window_ = false;
} }
} else if (ConnectionStatus::Failed == connection_status_) { } else if (ConnectionStatus::Failed == connection_status_) {
text = localization::p2p_failed[localization_language_index_]; text = localization::p2p_failed[localization_language_index_];
ImGui::SetCursorPosX(connection_status_window_width_ * 3 / 7); ImGui::SetCursorPosX(connection_status_window_width_ * 3 / 7);
ImGui::SetCursorPosY(connection_status_window_height_ * 2 / 3); ImGui::SetCursorPosY(connection_status_window_height_ * 2 / 3);
// Cancel // ok
if (ImGui::Button( if (ImGui::Button(
localization::cancel[localization_language_index_].c_str())) { localization::ok[localization_language_index_].c_str()) ||
ImGui::IsKeyPressed(ImGuiKey_Enter) ||
ImGui::IsKeyPressed(ImGuiKey_Escape)) {
show_connection_status_window_ = false; show_connection_status_window_ = false;
} }
} else if (ConnectionStatus::Closed == connection_status_) { } else if (ConnectionStatus::Closed == connection_status_) {
text = localization::p2p_closed[localization_language_index_]; text = localization::p2p_closed[localization_language_index_];
ImGui::SetCursorPosX(connection_status_window_width_ * 3 / 7); ImGui::SetCursorPosX(connection_status_window_width_ * 3 / 7);
ImGui::SetCursorPosY(connection_status_window_height_ * 2 / 3); ImGui::SetCursorPosY(connection_status_window_height_ * 2 / 3);
// Cancel // ok
if (ImGui::Button( if (ImGui::Button(
localization::ok[localization_language_index_].c_str())) { localization::ok[localization_language_index_].c_str()) ||
ImGui::IsKeyPressed(ImGuiKey_Enter) ||
ImGui::IsKeyPressed(ImGuiKey_Escape)) {
show_connection_status_window_ = false; show_connection_status_window_ = false;
} }
} else if (ConnectionStatus::IncorrectPassword == connection_status_) { } else if (ConnectionStatus::IncorrectPassword == connection_status_) {
@@ -86,19 +92,18 @@ int Render::ConnectionStatusWindow() {
ImGui::SetKeyboardFocusHere(); ImGui::SetKeyboardFocusHere();
focus_on_input_widget_ = false; focus_on_input_widget_ = false;
} }
bool enter_pressed = ImGui::InputText( ImGui::InputText("##password", remote_password_,
"##password", remote_password_, IM_ARRAYSIZE(remote_password_), IM_ARRAYSIZE(remote_password_),
ImGuiInputTextFlags_CharsNoBlank | ImGuiInputTextFlags_CharsNoBlank);
ImGuiInputTextFlags_EnterReturnsTrue);
ImGui::PopStyleVar(); ImGui::PopStyleVar();
ImGui::SetCursorPosX(window_width * 0.315f); ImGui::SetCursorPosX(window_width * 0.315f);
ImGui::SetCursorPosY(window_height * 0.75f); ImGui::SetCursorPosY(window_height * 0.75f);
// OK // ok
if (enter_pressed || if (ImGui::Button(
ImGui::Button( localization::ok[localization_language_index_].c_str()) ||
localization::ok[localization_language_index_].c_str())) { ImGui::IsKeyPressed(ImGuiKey_Enter)) {
show_connection_status_window_ = true; show_connection_status_window_ = true;
password_validating_ = true; password_validating_ = true;
rejoin_ = true; rejoin_ = true;
@@ -106,27 +111,27 @@ int Render::ConnectionStatusWindow() {
} }
ImGui::SameLine(); ImGui::SameLine();
// cancel
if (ImGui::Button( if (ImGui::Button(
localization::cancel[localization_language_index_].c_str())) { localization::cancel[localization_language_index_].c_str()) ||
ImGui::IsKeyPressed(ImGuiKey_Escape)) {
memset(remote_password_, 0, sizeof(remote_password_)); memset(remote_password_, 0, sizeof(remote_password_));
show_connection_status_window_ = false; show_connection_status_window_ = false;
focus_on_input_widget_ = true; focus_on_input_widget_ = true;
} }
} else { } else if (password_validating_) {
text = localization::validate_password[localization_language_index_]; text = localization::validate_password[localization_language_index_];
ImGui::SetCursorPosX(connection_status_window_width_ * 3 / 7); ImGui::SetCursorPosX(connection_status_window_width_ * 3 / 7);
ImGui::SetCursorPosY(connection_status_window_height_ * 2 / 3); ImGui::SetCursorPosY(connection_status_window_height_ * 2 / 3);
} }
} } else if (ConnectionStatus::NoSuchTransmissionId == connection_status_) {
else if (ConnectionStatus::NoSuchTransmissionId == connection_status_) {
text = localization::no_such_id[localization_language_index_]; text = localization::no_such_id[localization_language_index_];
ImGui::SetCursorPosX(connection_status_window_width_ * 3 / 7); ImGui::SetCursorPosX(connection_status_window_width_ * 3 / 7);
ImGui::SetCursorPosY(connection_status_window_height_ * 2 / 3); ImGui::SetCursorPosY(connection_status_window_height_ * 2 / 3);
// Cancel // ok
if (ImGui::Button( if (ImGui::Button(
localization::cancel[localization_language_index_].c_str())) { localization::ok[localization_language_index_].c_str()) ||
ImGui::IsKeyPressed(ImGuiKey_Escape)) {
show_connection_status_window_ = false; show_connection_status_window_ = false;
} }
} }

View File

@@ -10,7 +10,7 @@ int Render::ControlBar() {
if (control_bar_expand_) { if (control_bar_expand_) {
ImGui::SetCursorPosX( ImGui::SetCursorPosX(
is_control_bar_in_left_ ? (control_window_width_ + 5.0f) : 53.0f); is_control_bar_in_left_ ? (control_window_width_ + 5.0f) : 53.0f);
// Mouse control // mouse control button
ImDrawList* draw_list = ImGui::GetWindowDrawList(); ImDrawList* draw_list = ImGui::GetWindowDrawList();
if (is_control_bar_in_left_) { if (is_control_bar_in_left_) {
@@ -50,7 +50,7 @@ int Render::ControlBar() {
} }
ImGui::SameLine(); ImGui::SameLine();
// Audio capture // audio capture button
float disable_audio_x = ImGui::GetCursorScreenPos().x + 4; float disable_audio_x = ImGui::GetCursorScreenPos().x + 4;
float disable_audio_y = ImGui::GetCursorScreenPos().y + 4.0f; float disable_audio_y = ImGui::GetCursorScreenPos().y + 4.0f;
// std::string audio = audio_capture_button_pressed_ ? ICON_FA_VOLUME_HIGH // std::string audio = audio_capture_button_pressed_ ? ICON_FA_VOLUME_HIGH
@@ -87,7 +87,7 @@ int Render::ControlBar() {
} }
ImGui::SameLine(); ImGui::SameLine();
// Fullscreen // fullscreen button
std::string fullscreen = std::string fullscreen =
fullscreen_button_pressed_ ? ICON_FA_COMPRESS : ICON_FA_EXPAND; fullscreen_button_pressed_ ? ICON_FA_COMPRESS : ICON_FA_EXPAND;
if (ImGui::Button(fullscreen.c_str(), ImVec2(25, 25))) { if (ImGui::Button(fullscreen.c_str(), ImVec2(25, 25))) {
@@ -103,6 +103,15 @@ int Render::ControlBar() {
} }
} }
ImGui::SameLine();
// close button
std::string close_button = ICON_FA_XMARK;
if (ImGui::Button(close_button.c_str(), ImVec2(25, 25))) {
SDL_Event event;
event.type = SDL_QUIT;
SDL_PushEvent(&event);
}
ImGui::SameLine(); ImGui::SameLine();
if (!is_control_bar_in_left_) { if (!is_control_bar_in_left_) {

View File

@@ -24,6 +24,9 @@
SDL_HitTestResult Render::HitTestCallback(SDL_Window *window, SDL_HitTestResult Render::HitTestCallback(SDL_Window *window,
const SDL_Point *area, void *data) { const SDL_Point *area, void *data) {
Render *render = (Render *)data; Render *render = (Render *)data;
if (!render) {
return SDL_HITTEST_NORMAL;
}
int window_width, window_height; int window_width, window_height;
SDL_GetWindowSize(window, &window_width, &window_height); SDL_GetWindowSize(window, &window_width, &window_height);
@@ -387,7 +390,8 @@ int Render::Run() {
IMGUI_CHECKVERSION(); IMGUI_CHECKVERSION();
ImGui::CreateContext(); ImGui::CreateContext();
ImGuiIO &io = ImGui::GetIO(); ImGuiIO &io = ImGui::GetIO();
// Master keyboard navigation enable flag. Enable full Tabbing + directional
// arrows + space/enter to activate.
io.ConfigFlags |= io.ConfigFlags |=
ImGuiConfigFlags_NavEnableKeyboard; // Enable Keyboard Controls ImGuiConfigFlags_NavEnableKeyboard; // Enable Keyboard Controls
io.ConfigFlags |= io.ConfigFlags |=

View File

@@ -146,8 +146,8 @@ class Render {
int main_window_width_before_maximized_ = 960; int main_window_width_before_maximized_ = 960;
int main_window_height_before_maximized_ = 570; int main_window_height_before_maximized_ = 570;
int control_window_min_width_ = 20; int control_window_min_width_ = 20;
int control_window_max_width_ = 150; int control_window_max_width_ = 170;
int control_window_width_ = 150; int control_window_width_ = 170;
int control_window_height_ = 40; int control_window_height_ = 40;
int local_window_width_ = 350; int local_window_width_ = 350;
int status_bar_height_ = 20; int status_bar_height_ = 20;