Hide notifications in simple view, draw combobox upward if no space in scissor region to fully draw box

This commit is contained in:
dec05eba
2024-09-15 02:49:28 +02:00
parent ce78dd5b36
commit 5d6d57b881
5 changed files with 104 additions and 82 deletions

4
TODO
View File

@@ -39,4 +39,6 @@ Start recording/replay/streaming with correct data from settings.
Save recording/replay/streaming status to file. Save recording/replay/streaming status to file.
Save gsr info data to file to quick re-open. Save gsr info data to file to quick re-open.
Support wayland (excluding gnome, or force xwayland on gnome). Support wayland (excluding gnome, or force xwayland on gnome).
Restart replay on system start if monitor resolution changes.

View File

@@ -26,12 +26,16 @@ namespace gsr {
std::function<void(const std::string &text, const std::string &id)> on_selection_changed; std::function<void(const std::string &text, const std::string &id)> on_selection_changed;
private: private:
void draw_selected(mgl::Window &window, mgl::vec2f draw_pos);
void draw_unselected(mgl::Window &window, mgl::vec2f draw_pos);
void draw_item_outline(mgl::Window &window, mgl::vec2f pos, mgl::vec2f size);
void update_if_dirty(); void update_if_dirty();
float get_dropdown_arrow_height() const; float get_dropdown_arrow_height() const;
private: private:
struct Item { struct Item {
mgl::Text text; mgl::Text text;
std::string id; std::string id;
mgl::vec2f position;
}; };
mgl::vec2f max_size; mgl::vec2f max_size;

View File

@@ -328,7 +328,7 @@ namespace gsr {
button->add_item("Start", "start", "Alt+F8"); button->add_item("Start", "start", "Alt+F8");
button->add_item("Settings", "settings"); button->add_item("Settings", "settings");
button->set_item_icon("start", &get_theme().play_texture); button->set_item_icon("start", &get_theme().play_texture);
button->on_click = std::bind(&Overlay::on_press_start_replay, this, std::placeholders::_1); button->on_click = std::bind(&Overlay::on_press_start_stream, this, std::placeholders::_1);
main_buttons_list->add_widget(std::move(button)); main_buttons_list->add_widget(std::move(button));
} }

View File

@@ -25,23 +25,14 @@ namespace gsr {
if(items.empty()) if(items.empty())
return true; return true;
const int padding_top = padding_top_scale * get_theme().window_height;
const int padding_bottom = padding_bottom_scale * get_theme().window_height;
const int padding_left = padding_left_scale * get_theme().window_height;
if(event.type == mgl::Event::MouseButtonPressed && event.mouse_button.button == mgl::Mouse::Left) { if(event.type == mgl::Event::MouseButtonPressed && event.mouse_button.button == mgl::Mouse::Left) {
const mgl::vec2f draw_pos = position + offset;
const mgl::vec2f mouse_pos = { (float)event.mouse_button.x, (float)event.mouse_button.y }; const mgl::vec2f mouse_pos = { (float)event.mouse_button.x, (float)event.mouse_button.y };
const mgl::vec2f item_size(max_size.x, font->get_character_size() + padding_top + padding_bottom); const mgl::vec2f item_size = get_size();
if(show_dropdown && !items.empty()) {
mgl::vec2f pos = draw_pos + mgl::vec2f(padding_left, padding_top);
pos.y += items[selected_item].text.get_bounds().size.y + padding_top + padding_bottom;
if(show_dropdown) {
for(size_t i = 0; i < items.size(); ++i) { for(size_t i = 0; i < items.size(); ++i) {
Item &item = items[i]; Item &item = items[i];
const mgl::FloatRect text_bounds = item.text.get_bounds(); if(mgl::FloatRect(item.position, item_size).contains(mouse_pos)) {
if(mgl::FloatRect(pos - mgl::vec2f(padding_left, padding_top), item_size).contains(mouse_pos)) {
const size_t prev_selected_item = selected_item; const size_t prev_selected_item = selected_item;
selected_item = i; selected_item = i;
show_dropdown = false; show_dropdown = false;
@@ -52,10 +43,10 @@ namespace gsr {
return false; return false;
} }
pos.y += text_bounds.size.y + padding_top + padding_bottom;
} }
} }
const mgl::vec2f draw_pos = position + offset;
if(mgl::FloatRect(draw_pos, item_size).contains(mouse_pos)) { if(mgl::FloatRect(draw_pos, item_size).contains(mouse_pos)) {
show_dropdown = !show_dropdown; show_dropdown = !show_dropdown;
if(show_dropdown) if(show_dropdown)
@@ -67,6 +58,7 @@ namespace gsr {
remove_widget_as_selected_in_parent(); remove_widget_as_selected_in_parent();
} }
} }
return true; return true;
} }
@@ -76,75 +68,16 @@ namespace gsr {
update_if_dirty(); update_if_dirty();
const int padding_top = padding_top_scale * get_theme().window_height;
const int padding_bottom = padding_bottom_scale * get_theme().window_height;
const int padding_left = padding_left_scale * get_theme().window_height;
const int padding_right = padding_right_scale * get_theme().window_height;
const mgl::vec2f draw_pos = (position + offset).floor(); const mgl::vec2f draw_pos = (position + offset).floor();
const mgl::vec2f item_size(max_size.x, font->get_character_size() + padding_top + padding_bottom); if(show_dropdown)
const mgl::vec2i mouse_pos = window.get_mouse_position(); draw_selected(window, draw_pos);
bool inside = false; else
draw_unselected(window, draw_pos);
mgl::Rectangle background(draw_pos, item_size.floor());
if(show_dropdown) {
background.set_size(max_size.floor());
background.set_color(mgl::Color(0, 0, 0));
} else {
background.set_color(mgl::Color(0, 0, 0, 120));
}
window.draw(background);
if(!show_dropdown) {
dropdown_arrow.set_height(get_dropdown_arrow_height());
dropdown_arrow.set_position(draw_pos + mgl::vec2f(item_size.x - dropdown_arrow.get_size().x - padding_right, item_size.y * 0.5f - dropdown_arrow.get_size().y * 0.5f).floor());
dropdown_arrow.set_color(mgl::Color(255, 255, 255, 30));
window.draw(dropdown_arrow);
}
const bool mouse_inside = mgl::FloatRect(draw_pos, item_size).contains(window.get_mouse_position().to_vec2f()) && !has_parent_with_selected_child_widget();
mgl::vec2f pos = draw_pos + mgl::vec2f(padding_left, padding_top);
if(selected_item < items.size()) {
Item &selected_item_widget = items[selected_item];
selected_item_widget.text.set_position(pos.floor());
if(show_dropdown || mouse_inside) {
const int border_size = std::max(1.0f, border_scale * get_theme().window_height);
const mgl::Color border_color = get_theme().tint_color;
draw_rectangle_outline(window, pos - mgl::vec2f(padding_left, padding_top), item_size.floor(), border_color, border_size);
}
window.draw(selected_item_widget.text);
pos.y += selected_item_widget.text.get_bounds().size.y + padding_top + padding_bottom;
}
for(size_t i = 0; i < items.size(); ++i) {
Item &item = items[i];
item.text.set_position(pos.floor());
const mgl::FloatRect text_bounds = item.text.get_bounds();
if(show_dropdown) {
if(!inside) {
inside = mgl::FloatRect(text_bounds.position - mgl::vec2f(padding_left, padding_top), item_size).contains({ (float)mouse_pos.x, (float)mouse_pos.y });
if(inside) {
mgl::Rectangle item_background((text_bounds.position - mgl::vec2f(padding_left, padding_top)).floor(), item_size.floor());
item_background.set_color(get_theme().tint_color);
window.draw(item_background);
} else {
/*const int border_size = 3;
const mgl::Color border_color(150, 150, 150);
draw_rectangle_outline(window, text_bounds.position, item_size, border_color, border_size);*/
}
}
window.draw(item.text);
}
pos.y += text_bounds.size.y + padding_top + padding_bottom;
}
} }
void ComboBox::add_item(const std::string &text, const std::string &id) { void ComboBox::add_item(const std::string &text, const std::string &id) {
items.push_back({mgl::Text(text, *font), id}); items.push_back({mgl::Text(text, *font), id, {0.0f, 0.0f}});
dirty = true; dirty = true;
} }
@@ -172,6 +105,89 @@ namespace gsr {
} }
} }
void ComboBox::draw_selected(mgl::Window &window, mgl::vec2f draw_pos) {
const int padding_top = padding_top_scale * get_theme().window_height;
const int padding_left = padding_left_scale * get_theme().window_height;
mgl_scissor scissor;
mgl_window_get_scissor(window.internal_window(), &scissor);
const bool bottom_is_outside_scissor = draw_pos.y + max_size.y > scissor.position.y + scissor.size.y;
const mgl::vec2f item_size = get_size();
mgl::vec2f items_draw_pos = draw_pos + mgl::vec2f(0.0f, item_size.y);
mgl::Rectangle background(draw_pos, item_size.floor());
background.set_size(max_size.floor());
background.set_color(mgl::Color(0, 0, 0));
if(bottom_is_outside_scissor) {
background.set_position((draw_pos - mgl::vec2f(0.0f, background.get_size().y - item_size.y)).floor());
items_draw_pos = background.get_position();
}
window.draw(background);
if(selected_item < items.size()) {
draw_item_outline(window, draw_pos, item_size);
Item &selected_item_widget = items[selected_item];
selected_item_widget.text.set_position(draw_pos + mgl::vec2f(padding_left, padding_top).floor());
window.draw(selected_item_widget.text);
}
bool cursor_inside = false;
const mgl::vec2f mouse_pos = window.get_mouse_position().to_vec2f();
for(size_t i = 0; i < items.size(); ++i) {
if(!cursor_inside) {
cursor_inside = mgl::FloatRect(items_draw_pos, item_size).contains(mouse_pos);
if(cursor_inside) {
mgl::Rectangle item_background(items_draw_pos.floor(), item_size.floor());
item_background.set_color(get_theme().tint_color);
window.draw(item_background);
}
}
Item &item = items[i];
item.text.set_position((items_draw_pos + mgl::vec2f(padding_left, padding_top)).floor());
window.draw(item.text);
item.position = items_draw_pos;
items_draw_pos.y += item_size.y;
}
}
void ComboBox::draw_unselected(mgl::Window &window, mgl::vec2f draw_pos) {
const int padding_top = padding_top_scale * get_theme().window_height;
const int padding_left = padding_left_scale * get_theme().window_height;
const int padding_right = padding_right_scale * get_theme().window_height;
const mgl::vec2f item_size = get_size();
mgl::Rectangle background(draw_pos.floor(), item_size.floor());
background.set_color(mgl::Color(0, 0, 0, 120));
window.draw(background);
dropdown_arrow.set_height(get_dropdown_arrow_height());
dropdown_arrow.set_position(draw_pos + mgl::vec2f(item_size.x - dropdown_arrow.get_size().x - padding_right, item_size.y * 0.5f - dropdown_arrow.get_size().y * 0.5f).floor());
dropdown_arrow.set_color(mgl::Color(255, 255, 255, 30));
window.draw(dropdown_arrow);
if(selected_item < items.size()) {
const mgl::vec2f mouse_pos = window.get_mouse_position().to_vec2f();
const bool mouse_inside = mgl::FloatRect(draw_pos, item_size).contains(mouse_pos) && !has_parent_with_selected_child_widget();
if(mouse_inside)
draw_item_outline(window, draw_pos, item_size);
Item &selected_item_widget = items[selected_item];
selected_item_widget.text.set_position(draw_pos + mgl::vec2f(padding_left, padding_top).floor());
window.draw(selected_item_widget.text);
}
}
void ComboBox::draw_item_outline(mgl::Window &window, mgl::vec2f pos, mgl::vec2f size) {
const int border_size = std::max(1.0f, border_scale * get_theme().window_height);
const mgl::Color border_color = get_theme().tint_color;
draw_rectangle_outline(window, pos.floor(), size.floor(), border_color, border_size);
}
void ComboBox::update_if_dirty() { void ComboBox::update_if_dirty() {
if(!dirty) if(!dirty)
return; return;

View File

@@ -486,7 +486,7 @@ namespace gsr {
audio_codec_ptr->set_visible(advanced_view); audio_codec_ptr->set_visible(advanced_view);
video_codec_ptr->set_visible(advanced_view); video_codec_ptr->set_visible(advanced_view);
framerate_mode_list_ptr->set_visible(advanced_view); framerate_mode_list_ptr->set_visible(advanced_view);
//notifications_subsection_ptr->set_visible(advanced_view); notifications_subsection_ptr->set_visible(advanced_view);
settings_scrollable_page_ptr->reset_scroll(); settings_scrollable_page_ptr->reset_scroll();
}; };
view_radio_button_ptr->on_selection_changed("Simple", "simple"); view_radio_button_ptr->on_selection_changed("Simple", "simple");
@@ -521,7 +521,7 @@ namespace gsr {
audio_codec_ptr->set_visible(advanced_view); audio_codec_ptr->set_visible(advanced_view);
video_codec_ptr->set_visible(advanced_view); video_codec_ptr->set_visible(advanced_view);
framerate_mode_list_ptr->set_visible(advanced_view); framerate_mode_list_ptr->set_visible(advanced_view);
//notifications_subsection_ptr->set_visible(advanced_view); notifications_subsection_ptr->set_visible(advanced_view);
settings_scrollable_page_ptr->reset_scroll(); settings_scrollable_page_ptr->reset_scroll();
}; };
view_radio_button_ptr->on_selection_changed("Simple", "simple"); view_radio_button_ptr->on_selection_changed("Simple", "simple");
@@ -633,7 +633,7 @@ namespace gsr {
audio_codec_ptr->set_visible(advanced_view); audio_codec_ptr->set_visible(advanced_view);
video_codec_ptr->set_visible(advanced_view); video_codec_ptr->set_visible(advanced_view);
framerate_mode_list_ptr->set_visible(advanced_view); framerate_mode_list_ptr->set_visible(advanced_view);
//notifications_subsection_ptr->set_visible(advanced_view); notifications_subsection_ptr->set_visible(advanced_view);
settings_scrollable_page_ptr->reset_scroll(); settings_scrollable_page_ptr->reset_scroll();
}; };
view_radio_button_ptr->on_selection_changed("Simple", "simple"); view_radio_button_ptr->on_selection_changed("Simple", "simple");