[fix] fix control bar width

This commit is contained in:
dijunkun
2024-08-06 10:35:25 +08:00
parent 8e03e8e79b
commit 5a992b6589
3 changed files with 35 additions and 83 deletions

View File

@@ -3,53 +3,13 @@
int Render::ControlWindow() {
auto time_duration = ImGui::GetTime() - control_bar_button_pressed_time_;
// if (time_duration <= 0.25f) {
// control_window_width_is_changing_ = true;
// } else {
// control_window_width_is_changing_ = false;
// }
// control_window_width_ =
// !control_bar_button_pressed_
// ? (time_duration < 0.25f
// ? control_window_max_width_ -
// (control_window_max_width_ -
// control_window_min_width_) *
// 4 * time_duration
// : control_window_min_width_)
// : (time_duration < 0.25f
// ? control_window_min_width_ +
// (control_window_max_width_ -
// control_window_min_width_) *
// 4 * time_duration
// : control_window_max_width_);
if (control_window_width_is_changing_) {
if (control_bar_button_pressed_) {
// control_window_width_ =
// control_window_width_is_changing_
// ? control_window_min_width_ +
// (control_window_max_width_ - control_window_min_width_) *
// 4
// *
// time_duration
// : control_window_max_width_;
control_window_width_ =
control_window_min_width_ +
(control_window_max_width_ - control_window_min_width_) * 4 *
time_duration;
} else {
// control_window_width_ =
// control_window_width_is_changing_
// ? control_window_max_width_ -
// (control_window_max_width_ - control_window_min_width_) *
// 4
// *
// time_duration
// : control_window_min_width_;
control_window_width_ =
control_window_max_width_ -
(control_window_max_width_ - control_window_min_width_) * 4 *
@@ -73,16 +33,31 @@ int Render::ControlWindow() {
(control_winodw_pos_.y < title_bar_height_ ||
control_winodw_pos_.y >
main_window_height_ - control_window_height_)) {
ImGui::SetNextWindowPos(
ImVec2(0,
(control_winodw_pos_.y >= title_bar_height_ &&
control_winodw_pos_.y <=
main_window_height_ - control_window_height_)
? control_winodw_pos_.y
: (control_winodw_pos_.y < title_bar_height_
? title_bar_height_
: (main_window_height_ - control_window_height_))),
ImGuiCond_Always);
int pos_x = 0;
int pos_y = (control_winodw_pos_.y >= title_bar_height_ &&
control_winodw_pos_.y <=
main_window_height_ - control_window_height_)
? control_winodw_pos_.y
: (control_winodw_pos_.y < title_bar_height_
? title_bar_height_
: (main_window_height_ - control_window_height_));
if (control_bar_button_pressed_) {
if (control_window_width_ >= control_window_max_width_) {
control_window_width_ = control_window_max_width_;
control_window_width_is_changing_ = false;
} else {
control_window_width_is_changing_ = true;
}
} else {
if (control_window_width_ <= control_window_min_width_) {
control_window_width_ = control_window_min_width_;
control_window_width_is_changing_ = false;
} else {
control_window_width_is_changing_ = true;
}
}
ImGui::SetNextWindowPos(ImVec2(pos_x, pos_y), ImGuiCond_Always);
is_control_bar_in_left_ = true;
} else if (control_winodw_pos_.x > main_window_width_ / 2 ||
(control_winodw_pos_.y < title_bar_height_ ||
@@ -98,7 +73,7 @@ int Render::ControlWindow() {
: (main_window_height_ - control_window_height_));
if (control_bar_button_pressed_) {
if (control_window_width_ > control_window_max_width_) {
if (control_window_width_ >= control_window_max_width_) {
control_window_width_ = control_window_max_width_;
control_window_width_is_changing_ = false;
pos_x = main_window_width_ - control_window_max_width_;
@@ -107,7 +82,7 @@ int Render::ControlWindow() {
pos_x = main_window_width_ - control_window_width_;
}
} else {
if (control_window_width_ < control_window_min_width_) {
if (control_window_width_ <= control_window_min_width_) {
control_window_width_ = control_window_min_width_;
control_window_width_is_changing_ = false;
pos_x = main_window_width_ - control_window_min_width_;
@@ -116,36 +91,11 @@ int Render::ControlWindow() {
pos_x = main_window_width_ - control_window_width_;
}
}
// int pos_x =
// control_bar_button_pressed_
// ? (control_window_width_is_changing_
// ? (main_window_width_ - control_window_width_)
// : (main_window_width_ - control_window_max_width_))
// : (control_window_width_is_changing_
// ? (main_window_width_ - control_window_width_)
// : (main_window_width_ - control_window_min_width_));
// int pos_y = (control_winodw_pos_.y >= title_bar_height_ &&
// control_winodw_pos_.y <=
// main_window_height_ - control_window_height_)
// ? control_winodw_pos_.y
// : (control_winodw_pos_.y < title_bar_height_
// ? title_bar_height_
// : (main_window_height_ -
// control_window_height_));
ImGui::SetNextWindowPos(ImVec2(pos_x, pos_y), ImGuiCond_Always);
is_control_bar_in_left_ = false;
LOG_ERROR("x [{}], y[{}], [{}] | [{}]", pos_x, pos_y, main_window_width_,
control_window_width_);
}
}
// LOG_ERROR("x[{}], y[{}], w[{}]", control_winodw_pos_.x,
// control_winodw_pos_.y,
// control_window_width_);
ImGui::Begin("ControlWindow", nullptr,
ImGuiWindowFlags_NoTitleBar | ImGuiWindowFlags_NoResize |
ImGuiWindowFlags_NoScrollbar |