mirror of
https://github.com/kunkundi/crossdesk.git
synced 2025-10-26 20:25:34 +08:00
[fix] fix control bar width
This commit is contained in:
@@ -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 |
|
||||
|
||||
Reference in New Issue
Block a user