SharpenWindow::SharpenWindow(SharpenMain *client)
- : PluginClientWindow(client, 230, 150, 230, 150, 0)
+ : PluginClientWindow(client, xS(280), yS(190), xS(280), yS(190), 0) //195 was 150
{
this->client = client;
}
void SharpenWindow::create_objects()
{
- int x = 10, y = 10;
+ int xs10 = xS(10), xs50 = xS(50), xs100 = xS(100);
+ int ys10 = yS(10), ys20 = yS(20), ys30 = yS(30), ys40 = yS(40);
+ int x = xs10, y = ys10;
+ int x1 = 0; int clrBtn_w = xs50;
+ int defaultBtn_w = xs100;
+
add_tool(new BC_Title(x, y, _("Sharpness")));
- y += 20;
+ y += ys20;
add_tool(sharpen_slider = new SharpenSlider(client, &(client->config.sharpness), x, y));
- y += 30;
+ x1 = x + sharpen_slider->get_w() + xs10;
+ add_subwindow(sharpen_sliderClr = new SharpenSliderClr(client, this, x1, y, clrBtn_w));
+
+ y += ys30;
add_tool(sharpen_interlace = new SharpenInterlace(client, x, y));
- y += 30;
+ y += ys30;
add_tool(sharpen_horizontal = new SharpenHorizontal(client, x, y));
- y += 30;
+ y += ys30;
add_tool(sharpen_luminance = new SharpenLuminance(client, x, y));
+ y += ys40;
+ add_tool(reset = new SharpenReset(client, this, x, y));
+ add_subwindow(default_settings = new SharpenDefaultSettings(client, this,
+ (xS(280) - xs10 - defaultBtn_w), y, defaultBtn_w));
+
show_window();
flush();
}
-
-
-
-
+void SharpenWindow::update_gui(int clear)
+{
+ switch(clear) {
+ case RESET_SHARPEN_SLIDER :
+ sharpen_slider->update(client->config.sharpness);
+ break;
+ case RESET_ALL :
+ case RESET_DEFAULT_SETTINGS :
+ default:
+ sharpen_slider->update(client->config.sharpness);
+ sharpen_interlace->update(client->config.interlace);
+ sharpen_horizontal->update(client->config.horizontal);
+ sharpen_luminance->update(client->config.luminance);
+ break;
+ }
+}
SharpenSlider::SharpenSlider(SharpenMain *client, float *output, int x, int y)
: BC_ISlider(x,
y,
0,
- 200,
- 200,
+ xS(200),
+ yS(200),
0,
MAXSHARPNESS,
(int)*output,
}
-
-
SharpenInterlace::SharpenInterlace(SharpenMain *client, int x, int y)
: BC_CheckBox(x, y, client->config.interlace, _("Interlace"))
{
}
-
-
SharpenHorizontal::SharpenHorizontal(SharpenMain *client, int x, int y)
: BC_CheckBox(x, y, client->config.horizontal, _("Horizontal only"))
{
}
-
SharpenLuminance::SharpenLuminance(SharpenMain *client, int x, int y)
: BC_CheckBox(x, y, client->config.luminance, _("Luminance only"))
{
return 1;
}
+
+SharpenReset::SharpenReset(SharpenMain *client, SharpenWindow *gui, int x, int y)
+ : BC_GenericButton(x, y, _("Reset"))
+{
+ this->client = client;
+ this->gui = gui;
+}
+SharpenReset::~SharpenReset()
+{
+}
+int SharpenReset::handle_event()
+{
+ client->config.reset(RESET_ALL);
+ gui->update_gui(RESET_ALL);
+ client->send_configure_change();
+ return 1;
+}
+
+
+SharpenDefaultSettings::SharpenDefaultSettings(SharpenMain *client, SharpenWindow *gui, int x, int y, int w)
+ : BC_GenericButton(x, y, w, _("Default"))
+{
+ this->client = client;
+ this->gui = gui;
+}
+SharpenDefaultSettings::~SharpenDefaultSettings()
+{
+}
+int SharpenDefaultSettings::handle_event()
+{
+ client->config.reset(RESET_DEFAULT_SETTINGS);
+ gui->update_gui(RESET_DEFAULT_SETTINGS);
+ client->send_configure_change();
+ return 1;
+}
+
+
+SharpenSliderClr::SharpenSliderClr(SharpenMain *client, SharpenWindow *gui, int x, int y, int w)
+ : BC_Button(x, y, w, client->get_theme()->get_image_set("reset_button"))
+{
+ this->client = client;
+ this->gui = gui;
+}
+SharpenSliderClr::~SharpenSliderClr()
+{
+}
+int SharpenSliderClr::handle_event()
+{
+ client->config.reset(RESET_SHARPEN_SLIDER);
+ gui->update_gui(RESET_SHARPEN_SLIDER);
+ client->send_configure_change();
+ return 1;
+}
+