mirror of
https://repo.dec05eba.com/gpu-screen-recorder-ui
synced 2026-05-06 06:50:44 +09:00
Use scissor for pages
This commit is contained in:
@@ -5,11 +5,15 @@
|
|||||||
namespace gsr {
|
namespace gsr {
|
||||||
class StaticPage : public Page {
|
class StaticPage : public Page {
|
||||||
public:
|
public:
|
||||||
StaticPage() = default;
|
StaticPage(mgl::vec2f size);
|
||||||
StaticPage(const StaticPage&) = delete;
|
StaticPage(const StaticPage&) = delete;
|
||||||
StaticPage& operator=(const StaticPage&) = delete;
|
StaticPage& operator=(const StaticPage&) = delete;
|
||||||
|
|
||||||
bool on_event(mgl::Event &event, mgl::Window &window, mgl::vec2f offset) override;
|
bool on_event(mgl::Event &event, mgl::Window &window, mgl::vec2f offset) override;
|
||||||
void draw(mgl::Window &window, mgl::vec2f offset) override;
|
void draw(mgl::Window &window, mgl::vec2f offset) override;
|
||||||
|
|
||||||
|
mgl::vec2f get_size() const { return size; }
|
||||||
|
private:
|
||||||
|
mgl::vec2f size;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
@@ -28,8 +28,8 @@ namespace gsr {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void Button::draw(mgl::Window &window, mgl::vec2f offset) {
|
void Button::draw(mgl::Window &window, mgl::vec2f offset) {
|
||||||
mgl::Rectangle background(size);
|
mgl::Rectangle background(size.floor());
|
||||||
background.set_position(position + offset);
|
background.set_position((position + offset).floor());
|
||||||
background.set_color(bg_color);
|
background.set_color(bg_color);
|
||||||
window.draw(background);
|
window.draw(background);
|
||||||
|
|
||||||
|
|||||||
@@ -41,7 +41,8 @@ namespace gsr {
|
|||||||
|
|
||||||
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;
|
||||||
move_to_top = true;
|
if(show_dropdown)
|
||||||
|
move_to_top = true;
|
||||||
} else {
|
} else {
|
||||||
show_dropdown = false;
|
show_dropdown = false;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -38,8 +38,13 @@ namespace gsr {
|
|||||||
} else if(event.type == mgl::Event::MouseButtonPressed) {
|
} else if(event.type == mgl::Event::MouseButtonPressed) {
|
||||||
const bool clicked_inside = mouse_inside;
|
const bool clicked_inside = mouse_inside;
|
||||||
show_dropdown = clicked_inside;
|
show_dropdown = clicked_inside;
|
||||||
if(on_click && mouse_inside_item >= 0 && mouse_inside_item < (int)items.size())
|
if(show_dropdown)
|
||||||
on_click(items[mouse_inside_item].id);
|
move_to_top = true;
|
||||||
|
if(mouse_inside_item >= 0 && mouse_inside_item < (int)items.size()) {
|
||||||
|
if(on_click)
|
||||||
|
on_click(items[mouse_inside_item].id);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@@ -82,7 +87,7 @@ namespace gsr {
|
|||||||
// Background
|
// Background
|
||||||
mgl::Rectangle rect(size);
|
mgl::Rectangle rect(size);
|
||||||
rect.set_position(draw_pos);
|
rect.set_position(draw_pos);
|
||||||
rect.set_color(mgl::Color(0, 0, 0, 120));
|
rect.set_color(mgl::Color(0, 0, 0, 180));
|
||||||
window.draw(rect);
|
window.draw(rect);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -24,7 +24,16 @@ namespace gsr {
|
|||||||
const mgl::vec2f draw_pos = position + offset;
|
const mgl::vec2f draw_pos = position + offset;
|
||||||
offset = draw_pos + mgl::vec2f(0.0f, get_border_size(window)).floor();
|
offset = draw_pos + mgl::vec2f(0.0f, get_border_size(window)).floor();
|
||||||
|
|
||||||
mgl::Rectangle background(size);
|
mgl_scissor prev_scissor;
|
||||||
|
mgl_window_get_scissor(window.internal_window(), &prev_scissor);
|
||||||
|
|
||||||
|
mgl_scissor new_scissor = {
|
||||||
|
mgl_vec2i{(int)draw_pos.x, (int)draw_pos.y},
|
||||||
|
mgl_vec2i{(int)size.x, (int)size.y}
|
||||||
|
};
|
||||||
|
mgl_window_set_scissor(window.internal_window(), &new_scissor);
|
||||||
|
|
||||||
|
mgl::Rectangle background(size.floor());
|
||||||
background.set_position(draw_pos);
|
background.set_position(draw_pos);
|
||||||
background.set_color(get_theme().scrollable_page_bg_color);
|
background.set_color(get_theme().scrollable_page_bg_color);
|
||||||
window.draw(background);
|
window.draw(background);
|
||||||
@@ -39,12 +48,13 @@ namespace gsr {
|
|||||||
widget->move_to_top = false;
|
widget->move_to_top = false;
|
||||||
std::swap(widget, widgets.back());
|
std::swap(widget, widgets.back());
|
||||||
}
|
}
|
||||||
widget->draw(window, offset);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for(auto &widget : widgets) {
|
for(auto &widget : widgets) {
|
||||||
widget->draw(window, offset);
|
widget->draw(window, offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mgl_window_set_scissor(window.internal_window(), &prev_scissor);
|
||||||
}
|
}
|
||||||
|
|
||||||
float ScrollablePage::get_border_size(mgl::Window &window) const {
|
float ScrollablePage::get_border_size(mgl::Window &window) const {
|
||||||
|
|||||||
@@ -1,6 +1,10 @@
|
|||||||
#include "../../include/gui/StaticPage.hpp"
|
#include "../../include/gui/StaticPage.hpp"
|
||||||
|
|
||||||
|
#include <mglpp/window/Window.hpp>
|
||||||
|
|
||||||
namespace gsr {
|
namespace gsr {
|
||||||
|
StaticPage::StaticPage(mgl::vec2f size) : size(size) {}
|
||||||
|
|
||||||
bool StaticPage::on_event(mgl::Event &event, mgl::Window &window, mgl::vec2f offset) {
|
bool StaticPage::on_event(mgl::Event &event, mgl::Window &window, mgl::vec2f offset) {
|
||||||
const mgl::vec2f draw_pos = position + offset;
|
const mgl::vec2f draw_pos = position + offset;
|
||||||
offset = draw_pos;
|
offset = draw_pos;
|
||||||
@@ -18,16 +22,26 @@ namespace gsr {
|
|||||||
const mgl::vec2f draw_pos = position + offset;
|
const mgl::vec2f draw_pos = position + offset;
|
||||||
offset = draw_pos;
|
offset = draw_pos;
|
||||||
|
|
||||||
|
mgl_scissor prev_scissor;
|
||||||
|
mgl_window_get_scissor(window.internal_window(), &prev_scissor);
|
||||||
|
|
||||||
|
mgl_scissor new_scissor = {
|
||||||
|
mgl_vec2i{(int)draw_pos.x, (int)draw_pos.y},
|
||||||
|
mgl_vec2i{(int)size.x, (int)size.y}
|
||||||
|
};
|
||||||
|
mgl_window_set_scissor(window.internal_window(), &new_scissor);
|
||||||
|
|
||||||
for(auto &widget : widgets) {
|
for(auto &widget : widgets) {
|
||||||
if(widget->move_to_top) {
|
if(widget->move_to_top) {
|
||||||
widget->move_to_top = false;
|
widget->move_to_top = false;
|
||||||
std::swap(widget, widgets.back());
|
std::swap(widget, widgets.back());
|
||||||
}
|
}
|
||||||
widget->draw(window, offset);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for(auto &widget : widgets) {
|
for(auto &widget : widgets) {
|
||||||
widget->draw(window, offset);
|
widget->draw(window, offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mgl_window_set_scissor(window.internal_window(), &prev_scissor);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
13
src/main.cpp
13
src/main.cpp
@@ -44,7 +44,7 @@ extern "C" {
|
|||||||
#include <mgl/mgl.h>
|
#include <mgl/mgl.h>
|
||||||
}
|
}
|
||||||
|
|
||||||
const mgl::Color bg_color(0, 0, 0, 180);
|
const mgl::Color bg_color(0, 0, 0, 160);
|
||||||
|
|
||||||
static void usage() {
|
static void usage() {
|
||||||
fprintf(stderr, "usage: window-overlay\n");
|
fprintf(stderr, "usage: window-overlay\n");
|
||||||
@@ -237,7 +237,7 @@ int main(int argc, char **argv) {
|
|||||||
mgl::Rectangle bg_screenshot_overlay(window.get_size().to_vec2f());
|
mgl::Rectangle bg_screenshot_overlay(window.get_size().to_vec2f());
|
||||||
bg_screenshot_overlay.set_color(bg_color);
|
bg_screenshot_overlay.set_color(bg_color);
|
||||||
|
|
||||||
gsr::StaticPage front_page;
|
gsr::StaticPage front_page(window_size.to_vec2f());
|
||||||
|
|
||||||
const mgl::vec2f settings_page_size(window_size.x * 0.3333f, window_size.y * 0.7f);
|
const mgl::vec2f settings_page_size(window_size.x * 0.3333f, window_size.y * 0.7f);
|
||||||
const mgl::vec2f settings_page_position = (window_size.to_vec2f() * 0.5f - settings_page_size * 0.5f).floor();
|
const mgl::vec2f settings_page_position = (window_size.to_vec2f() * 0.5f - settings_page_size * 0.5f).floor();
|
||||||
@@ -254,13 +254,13 @@ int main(int argc, char **argv) {
|
|||||||
gsr::ScrollablePage *stream_settings_content_ptr = stream_settings_content.get();
|
gsr::ScrollablePage *stream_settings_content_ptr = stream_settings_content.get();
|
||||||
stream_settings_content->set_position(settings_page_position);
|
stream_settings_content->set_position(settings_page_position);
|
||||||
|
|
||||||
gsr::StaticPage replay_settings_page;
|
gsr::StaticPage replay_settings_page(window_size.to_vec2f());
|
||||||
replay_settings_page.add_widget(std::move(replay_settings_content));
|
replay_settings_page.add_widget(std::move(replay_settings_content));
|
||||||
|
|
||||||
gsr::StaticPage record_settings_page;
|
gsr::StaticPage record_settings_page(window_size.to_vec2f());
|
||||||
record_settings_page.add_widget(std::move(record_settings_content));
|
record_settings_page.add_widget(std::move(record_settings_content));
|
||||||
|
|
||||||
gsr::StaticPage stream_settings_page;
|
gsr::StaticPage stream_settings_page(window_size.to_vec2f());
|
||||||
stream_settings_page.add_widget(std::move(stream_settings_content));
|
stream_settings_page.add_widget(std::move(stream_settings_content));
|
||||||
|
|
||||||
gsr::Page *current_page = &front_page;
|
gsr::Page *current_page = &front_page;
|
||||||
@@ -453,7 +453,7 @@ int main(int argc, char **argv) {
|
|||||||
//XGrabServer(display);
|
//XGrabServer(display);
|
||||||
|
|
||||||
mgl::Rectangle top_bar_background(mgl::vec2f(window.get_size().x, window.get_size().y*0.06f).floor());
|
mgl::Rectangle top_bar_background(mgl::vec2f(window.get_size().x, window.get_size().y*0.06f).floor());
|
||||||
top_bar_background.set_color(mgl::Color(0, 0, 0, 200));
|
top_bar_background.set_color(mgl::Color(0, 0, 0, 180));
|
||||||
|
|
||||||
mgl::Text top_bar_text("GPU Screen Recorder", top_bar_font);
|
mgl::Text top_bar_text("GPU Screen Recorder", top_bar_font);
|
||||||
//top_bar_text.set_color(gsr::get_theme().tint_color);
|
//top_bar_text.set_color(gsr::get_theme().tint_color);
|
||||||
@@ -482,7 +482,6 @@ int main(int argc, char **argv) {
|
|||||||
gsr::Page *settings_content_page = settings_content_pages[i];
|
gsr::Page *settings_content_page = settings_content_pages[i];
|
||||||
|
|
||||||
auto record_area_box = std::make_unique<gsr::ComboBox>(&title_font);
|
auto record_area_box = std::make_unique<gsr::ComboBox>(&title_font);
|
||||||
record_area_box->set_position(mgl::vec2f(300.0f, 300.0f));
|
|
||||||
if(gsr_info.supported_capture_options.window)
|
if(gsr_info.supported_capture_options.window)
|
||||||
record_area_box->add_item("Window", "window");
|
record_area_box->add_item("Window", "window");
|
||||||
if(gsr_info.supported_capture_options.focused)
|
if(gsr_info.supported_capture_options.focused)
|
||||||
|
|||||||
Reference in New Issue
Block a user