|
@@ -1,5 +1,6 @@
|
|
/*
|
|
/*
|
|
* Copyright (c) 2020, Idan Horowitz <idan.horowitz@gmail.com>
|
|
* Copyright (c) 2020, Idan Horowitz <idan.horowitz@gmail.com>
|
|
|
|
+ * Copyright (c) 2021, the SerenityOS developers
|
|
* All rights reserved.
|
|
* All rights reserved.
|
|
*
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* Redistribution and use in source and binary forms, with or without
|
|
@@ -24,21 +25,13 @@
|
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
*/
|
|
*/
|
|
|
|
|
|
|
|
+#include "MouseSettingsWindow.h"
|
|
#include <LibGUI/Action.h>
|
|
#include <LibGUI/Action.h>
|
|
#include <LibGUI/Application.h>
|
|
#include <LibGUI/Application.h>
|
|
-#include <LibGUI/BoxLayout.h>
|
|
|
|
-#include <LibGUI/Button.h>
|
|
|
|
-#include <LibGUI/GroupBox.h>
|
|
|
|
#include <LibGUI/Icon.h>
|
|
#include <LibGUI/Icon.h>
|
|
#include <LibGUI/Menu.h>
|
|
#include <LibGUI/Menu.h>
|
|
#include <LibGUI/MenuBar.h>
|
|
#include <LibGUI/MenuBar.h>
|
|
-#include <LibGUI/Slider.h>
|
|
|
|
-#include <LibGUI/SpinBox.h>
|
|
|
|
-#include <LibGUI/Widget.h>
|
|
|
|
-#include <LibGUI/Window.h>
|
|
|
|
-#include <LibGUI/WindowServerConnection.h>
|
|
|
|
-#include <LibGfx/SystemTheme.h>
|
|
|
|
-#include <WindowServer/Screen.h>
|
|
|
|
|
|
+#include <unistd.h>
|
|
|
|
|
|
int main(int argc, char** argv)
|
|
int main(int argc, char** argv)
|
|
{
|
|
{
|
|
@@ -55,75 +48,20 @@ int main(int argc, char** argv)
|
|
}
|
|
}
|
|
|
|
|
|
auto app_icon = GUI::Icon::default_icon("app-mouse");
|
|
auto app_icon = GUI::Icon::default_icon("app-mouse");
|
|
- auto window = GUI::Window::construct();
|
|
|
|
|
|
+
|
|
|
|
+ auto window = MouseSettingsWindow::construct();
|
|
window->set_title("Mouse Settings");
|
|
window->set_title("Mouse Settings");
|
|
- window->resize(200, 130);
|
|
|
|
|
|
+ window->resize(300, 220);
|
|
window->set_resizable(false);
|
|
window->set_resizable(false);
|
|
|
|
+ window->set_minimizable(false);
|
|
window->set_icon(app_icon.bitmap_for_size(16));
|
|
window->set_icon(app_icon.bitmap_for_size(16));
|
|
|
|
|
|
- auto& settings = window->set_main_widget<GUI::Widget>();
|
|
|
|
- settings.set_fill_with_background_color(true);
|
|
|
|
- settings.set_background_role(ColorRole::Button);
|
|
|
|
- settings.set_layout<GUI::VerticalBoxLayout>();
|
|
|
|
- settings.layout()->set_margins({ 4, 4, 4, 4 });
|
|
|
|
-
|
|
|
|
- auto& speed_container = settings.add<GUI::GroupBox>("Mouse speed");
|
|
|
|
- speed_container.set_layout<GUI::VerticalBoxLayout>();
|
|
|
|
- speed_container.layout()->set_margins({ 6, 16, 6, 6 });
|
|
|
|
- speed_container.set_fixed_height(50);
|
|
|
|
-
|
|
|
|
- auto& speed_slider = speed_container.add<GUI::HorizontalSlider>();
|
|
|
|
- const auto scalar = 1000.0;
|
|
|
|
- speed_slider.set_range(WindowServer::mouse_accel_min * scalar, WindowServer::mouse_accel_max * scalar); // These values are scaled down (by a factor of 1000) to get fractional values
|
|
|
|
- int current_value = GUI::WindowServerConnection::the().send_sync<Messages::WindowServer::GetMouseAcceleration>()->factor() * scalar;
|
|
|
|
- speed_slider.set_value(current_value);
|
|
|
|
-
|
|
|
|
- auto& scroll_container = settings.add<GUI::GroupBox>("Scroll length");
|
|
|
|
- scroll_container.set_layout<GUI::VerticalBoxLayout>();
|
|
|
|
- scroll_container.layout()->set_margins({ 6, 16, 6, 6 });
|
|
|
|
- scroll_container.set_fixed_height(46);
|
|
|
|
-
|
|
|
|
- auto& scroll_spinbox = scroll_container.add<GUI::SpinBox>();
|
|
|
|
- scroll_spinbox.set_min(WindowServer::scroll_step_size_min);
|
|
|
|
- scroll_spinbox.set_value(GUI::WindowServerConnection::the().send_sync<Messages::WindowServer::GetScrollStepSize>()->step_size());
|
|
|
|
-
|
|
|
|
- auto update_window_server = [&]() {
|
|
|
|
- float factor = speed_slider.value() / scalar;
|
|
|
|
- GUI::WindowServerConnection::the().send_sync<Messages::WindowServer::SetMouseAcceleration>(factor);
|
|
|
|
- GUI::WindowServerConnection::the().send_sync<Messages::WindowServer::SetScrollStepSize>(scroll_spinbox.value());
|
|
|
|
- };
|
|
|
|
-
|
|
|
|
- auto& prompt_buttons = settings.add<GUI::Widget>();
|
|
|
|
- prompt_buttons.set_layout<GUI::HorizontalBoxLayout>();
|
|
|
|
- prompt_buttons.set_fixed_height(22);
|
|
|
|
-
|
|
|
|
- auto& ok_button = prompt_buttons.add<GUI::Button>();
|
|
|
|
- ok_button.set_text("OK");
|
|
|
|
- prompt_buttons.set_fixed_height(22);
|
|
|
|
- ok_button.on_click = [&](auto) {
|
|
|
|
- update_window_server();
|
|
|
|
- app->quit();
|
|
|
|
- };
|
|
|
|
- auto& apply_button = prompt_buttons.add<GUI::Button>();
|
|
|
|
- apply_button.set_text("Apply");
|
|
|
|
- prompt_buttons.set_fixed_height(22);
|
|
|
|
- apply_button.on_click = [&](auto) {
|
|
|
|
- update_window_server();
|
|
|
|
- };
|
|
|
|
- auto& reset_button = prompt_buttons.add<GUI::Button>();
|
|
|
|
- reset_button.set_text("Reset");
|
|
|
|
- prompt_buttons.set_fixed_height(22);
|
|
|
|
- reset_button.on_click = [&](auto) {
|
|
|
|
- speed_slider.set_value(scalar);
|
|
|
|
- scroll_spinbox.set_value(4);
|
|
|
|
- update_window_server();
|
|
|
|
- };
|
|
|
|
-
|
|
|
|
auto menubar = GUI::MenuBar::construct();
|
|
auto menubar = GUI::MenuBar::construct();
|
|
auto& app_menu = menubar->add_menu("File");
|
|
auto& app_menu = menubar->add_menu("File");
|
|
app_menu.add_action(GUI::CommonActions::make_quit_action([&](auto&) {
|
|
app_menu.add_action(GUI::CommonActions::make_quit_action([&](auto&) {
|
|
app->quit();
|
|
app->quit();
|
|
}));
|
|
}));
|
|
|
|
+
|
|
auto& help_menu = menubar->add_menu("Help");
|
|
auto& help_menu = menubar->add_menu("Help");
|
|
help_menu.add_action(GUI::CommonActions::make_about_action("Mouse Settings", app_icon, window));
|
|
help_menu.add_action(GUI::CommonActions::make_about_action("Mouse Settings", app_icon, window));
|
|
window->set_menubar(move(menubar));
|
|
window->set_menubar(move(menubar));
|