#include "bcdisplayinfo.h"
#include "language.h"
+#include "theme.h"
#include "unsharp.h"
#include "unsharpwindow.h"
-
-
-
-
-
-
-
-
UnsharpWindow::UnsharpWindow(UnsharpMain *plugin)
- : PluginClientWindow(plugin, 285, 160, 285, 160, 0)
+ : PluginClientWindow(plugin, xS(285), yS(170), xS(285), yS(170), 0)
{
this->plugin = plugin;
}
void UnsharpWindow::create_objects()
{
- int x = 10, y = 10;
+ int xs10 = xS(10), xs50 = xS(50), xs90 = xS(90), xs100 = xS(100);
+ int ys10 = yS(10), ys40 = yS(40), ys50 = yS(50);
+ int x = xs10, y = ys10, x1 = xs90;
+ int x2 = 0; int clrBtn_w = xs50;
+ int defaultBtn_w = xs100;
BC_Title *title;
- add_subwindow(title = new BC_Title(x, y + 10, _("Radius:")));
- add_subwindow(radius = new UnsharpRadius(plugin,
- x + title->get_w() + 10,
- y));
+ add_subwindow(title = new BC_Title(x, y + ys10, _("Radius:")));
+ add_subwindow(radius = new UnsharpRadius(plugin, x + x1, y));
+ x2 = xS(285) - xs10 - clrBtn_w;
+ add_subwindow(radiusClr = new UnsharpSliderClr(plugin, this, x2, y + ys10, clrBtn_w, RESET_RADIUS));
- y += 40;
- add_subwindow(title = new BC_Title(x, y + 10, _("Amount:")));
- add_subwindow(amount = new UnsharpAmount(plugin,
- x + title->get_w() + 10,
- y));
+ y += ys40;
+ add_subwindow(title = new BC_Title(x, y + ys10, _("Amount:")));
+ add_subwindow(amount = new UnsharpAmount(plugin, x + x1, y));
+ add_subwindow(amountClr = new UnsharpSliderClr(plugin, this, x2, y + ys10, clrBtn_w, RESET_AMOUNT));
- y += 40;
- add_subwindow(title = new BC_Title(x, y + 10, _("Threshold:")));
- add_subwindow(threshold = new UnsharpThreshold(plugin,
- x + title->get_w() + 10,
- y));
+ y += ys40;
+ add_subwindow(title = new BC_Title(x, y + ys10, _("Threshold:")));
+ add_subwindow(threshold = new UnsharpThreshold(plugin, x + x1, y));
+ add_subwindow(thresholdClr = new UnsharpSliderClr(plugin, this, x2, y + ys10, clrBtn_w, RESET_THRESHOLD));
+
+ y += ys50;
+ add_subwindow(reset = new UnsharpReset(plugin, this, x, y));
+ add_subwindow(default_settings = new UnsharpDefaultSettings(plugin, this,
+ (xS(285) - xs10 - defaultBtn_w), y, defaultBtn_w));
show_window();
flush();
}
-void UnsharpWindow::update()
+void UnsharpWindow::update_gui(int clear)
{
- radius->update(plugin->config.radius);
- amount->update(plugin->config.amount);
- threshold->update(plugin->config.threshold);
+ switch(clear) {
+ case RESET_RADIUS : radius->update(plugin->config.radius);
+ break;
+ case RESET_AMOUNT : amount->update(plugin->config.amount);
+ break;
+ case RESET_THRESHOLD : threshold->update(plugin->config.threshold);
+ break;
+ case RESET_ALL :
+ case RESET_DEFAULT_SETTINGS :
+ default:
+ radius->update(plugin->config.radius);
+ amount->update(plugin->config.amount);
+ threshold->update(plugin->config.threshold);
+ break;
+ }
}
return 1;
}
+UnsharpReset::UnsharpReset(UnsharpMain *plugin, UnsharpWindow *window, int x, int y)
+ : BC_GenericButton(x, y, _("Reset"))
+{
+ this->plugin = plugin;
+ this->window = window;
+}
+UnsharpReset::~UnsharpReset()
+{
+}
+int UnsharpReset::handle_event()
+{
+ plugin->config.reset(RESET_ALL);
+ window->update_gui(RESET_ALL);
+ plugin->send_configure_change();
+ return 1;
+}
+UnsharpDefaultSettings::UnsharpDefaultSettings(UnsharpMain *plugin, UnsharpWindow *window, int x, int y, int w)
+ : BC_GenericButton(x, y, w, _("Default"))
+{
+ this->plugin = plugin;
+ this->window = window;
+}
+UnsharpDefaultSettings::~UnsharpDefaultSettings()
+{
+}
+int UnsharpDefaultSettings::handle_event()
+{
+ plugin->config.reset(RESET_DEFAULT_SETTINGS);
+ window->update_gui(RESET_DEFAULT_SETTINGS);
+ plugin->send_configure_change();
+ return 1;
+}
-
+UnsharpSliderClr::UnsharpSliderClr(UnsharpMain *plugin, UnsharpWindow *window, int x, int y, int w, int clear)
+ : BC_Button(x, y, w, plugin->get_theme()->get_image_set("reset_button"))
+{
+ this->plugin = plugin;
+ this->window = window;
+ this->clear = clear;
+}
+UnsharpSliderClr::~UnsharpSliderClr()
+{
+}
+int UnsharpSliderClr::handle_event()
+{
+ // clear==1 ==> Radius slider
+ // clear==2 ==> Amount slider
+ // clear==3 ==> Threshold slider
+ plugin->config.reset(clear);
+ window->update_gui(clear);
+ plugin->send_configure_change();
+ return 1;
+}