Credit Andrew R for finding the direct copy mods for exr and ppm sequences
[goodguy/cinelerra.git] / cinelerra-5.1 / plugins / yuvshift / yuvshift.C
index 3f68a6c8bcc07e4025f451f408a7b2d0bcf5af8f..bf6ab68c9f75c86ab0c9e12dc9850f6cacd52173 100644 (file)
@@ -32,14 +32,31 @@ REGISTER_PLUGIN(YUVShiftEffect)
 
 YUVShiftConfig::YUVShiftConfig()
 {
-       reset();
+       reset(RESET_ALL);
 }
 
-void YUVShiftConfig::reset()
+void YUVShiftConfig::reset(int clear)
 {
-       y_dx = y_dy = 0;
-       u_dx = u_dy = 0;
-       v_dx = v_dy = 0;
+       switch(clear) {
+               case RESET_Y_DX : y_dx = 0;
+                       break;
+               case RESET_Y_DY : y_dy = 0;
+                       break;
+               case RESET_U_DX : u_dx = 0;
+                       break;
+               case RESET_U_DY : u_dy = 0;
+                       break;
+               case RESET_V_DX : v_dx = 0;
+                       break;
+               case RESET_V_DY : v_dy = 0;
+                       break;
+               case RESET_ALL :
+               default:
+                       y_dx = y_dy = 0;
+                       u_dx = u_dy = 0;
+                       v_dx = v_dy = 0;
+                       break;
+       }
 }
 
 void YUVShiftConfig::copy_from(YUVShiftConfig &src)
@@ -77,18 +94,50 @@ void YUVShiftConfig::interpolate(YUVShiftConfig &prev,
 
 
 
-#define MAXVALUE 100
 
-YUVShiftLevel::YUVShiftLevel(YUVShiftEffect *plugin, int *output, int x, int y)
- : BC_ISlider(x, y, 0, 200, 200, -MAXVALUE, MAXVALUE, *output)
+
+
+YUVShiftIText::YUVShiftIText(YUVShiftWindow *window, YUVShiftEffect *plugin,
+       YUVShiftISlider *slider, int *output, int x, int y, int min, int max)
+ : BC_TumbleTextBox(window, *output,
+       min, max, x, y, xS(60), 0)
 {
+       this->window = window;
        this->plugin = plugin;
        this->output = output;
+       this->slider = slider;
+       this->min = min;
+       this->max = max;
+       set_increment(1);
+}
+
+YUVShiftIText::~YUVShiftIText()
+{
 }
 
-int YUVShiftLevel::handle_event()
+int YUVShiftIText::handle_event()
+{
+       *output = atoi(get_text());
+       if(*output > max) *output = max;
+       if(*output < min) *output = min;
+       slider->update(*output);
+       plugin->send_configure_change();
+       return 1;
+}
+
+YUVShiftISlider::YUVShiftISlider(YUVShiftEffect *plugin, YUVShiftIText *text, int *output, int x, int y)
+ : BC_ISlider(x, y, 0, xS(200), xS(200), -MAXVALUE, MAXVALUE, *output)
+{
+       this->plugin = plugin;
+       this->output = output;
+       this->text = text;
+       enable_show_value(0); // Hide caption
+}
+
+int YUVShiftISlider::handle_event()
 {
        *output = get_value();
+       text->update((int64_t)*output);
        plugin->send_configure_change();
        return 1;
 }
@@ -105,41 +154,122 @@ YUVShiftReset::~YUVShiftReset()
 }
 int YUVShiftReset::handle_event()
 {
-       plugin->config.reset();
-       window->update();
+       plugin->config.reset(RESET_ALL);
+       window->update_gui(RESET_ALL);
+       plugin->send_configure_change();
+       return 1;
+}
+
+
+YUVShiftClr::YUVShiftClr(YUVShiftEffect *plugin, YUVShiftWindow *window, int x, int y, int clear)
+ : BC_Button(x, y, plugin->get_theme()->get_image_set("reset_button"))
+{
+       this->plugin = plugin;
+       this->window = window;
+       this->clear = clear;
+}
+YUVShiftClr::~YUVShiftClr()
+{
+}
+int YUVShiftClr::handle_event()
+{
+       // clear==1 ==> y_dx slider --- clear==2 ==> y_dy slider
+       // clear==3 ==> u_dx slider --- clear==4 ==> u_dy slider
+       // clear==5 ==> v_dx slider --- clear==6 ==> v_dy slider
+       plugin->config.reset(clear);
+       window->update_gui(clear);
        plugin->send_configure_change();
        return 1;
 }
 
 
 YUVShiftWindow::YUVShiftWindow(YUVShiftEffect *plugin)
- : PluginClientWindow(plugin, 300, 230, 300, 230, 0)
+ : PluginClientWindow(plugin, xS(420), yS(250), xS(420), yS(250), 0)
 {
        this->plugin = plugin;
 }
 
 void YUVShiftWindow::create_objects()
 {
-       int x = 10, y = 10, x1 = 50;
+       int xs10 = xS(10);
+       int ys10 = yS(10), ys30 = yS(30), ys40 = yS(40);
+       int x = xs10, y = ys10;
+       int x2 = xS(80), x3 = xS(180);
+       int clr_x = get_w()-x - xS(22); // note: clrBtn_w = 22
+
+       BC_Bar *bar;
+
+       y += ys10;
        add_subwindow(new BC_Title(x, y, _("Y_dx:")));
-       add_subwindow(y_dx = new YUVShiftLevel(plugin, &plugin->config.y_dx, x1, y));
-       y += 30;
+       y_dx_text = new YUVShiftIText(this, plugin,
+               0, &plugin->config.y_dx, (x + x2), y, -MAXVALUE, MAXVALUE);
+       y_dx_text->create_objects();
+       y_dx_slider = new YUVShiftISlider(plugin,
+               y_dx_text, &plugin->config.y_dx, x3, y);
+       add_subwindow(y_dx_slider);
+       y_dx_text->slider = y_dx_slider;
+       clr_x = x3 + y_dx_slider->get_w() + x;
+       add_subwindow(y_dx_Clr = new YUVShiftClr(plugin, this, clr_x, y, RESET_Y_DX));
+       y += ys30;
+
        add_subwindow(new BC_Title(x, y, _("Y_dy:")));
-       add_subwindow(y_dy = new YUVShiftLevel(plugin, &plugin->config.y_dy, x1, y));
-       y += 30;
+       y_dy_text = new YUVShiftIText(this, plugin,
+               0, &plugin->config.y_dy, (x + x2), y, -MAXVALUE, MAXVALUE);
+       y_dy_text->create_objects();
+       y_dy_slider = new YUVShiftISlider(plugin,
+               y_dy_text, &plugin->config.y_dy, x3, y);
+       add_subwindow(y_dy_slider);
+       y_dy_text->slider = y_dy_slider;
+       add_subwindow(y_dy_Clr = new YUVShiftClr(plugin, this, clr_x, y, RESET_Y_DY));
+       y += ys30;
+
        add_subwindow(new BC_Title(x, y, _("U_dx:")));
-       add_subwindow(u_dx = new YUVShiftLevel(plugin, &plugin->config.u_dx, x1, y));
-       y += 30;
+       u_dx_text = new YUVShiftIText(this, plugin,
+               0, &plugin->config.u_dx, (x + x2), y, -MAXVALUE, MAXVALUE);
+       u_dx_text->create_objects();
+       u_dx_slider = new YUVShiftISlider(plugin,
+               u_dx_text, &plugin->config.u_dx, x3, y);
+       add_subwindow(u_dx_slider);
+       u_dx_text->slider = u_dx_slider;
+       add_subwindow(u_dx_Clr = new YUVShiftClr(plugin, this, clr_x, y, RESET_U_DX));
+       y += ys30;
+
        add_subwindow(new BC_Title(x, y, _("U_dy:")));
-       add_subwindow(u_dy = new YUVShiftLevel(plugin, &plugin->config.u_dy, x1, y));
-       y += 30;
+       u_dy_text = new YUVShiftIText(this, plugin,
+               0, &plugin->config.u_dy, (x + x2), y, -MAXVALUE, MAXVALUE);
+       u_dy_text->create_objects();
+       u_dy_slider = new YUVShiftISlider(plugin,
+               u_dy_text, &plugin->config.u_dy, x3, y);
+       add_subwindow(u_dy_slider);
+       u_dy_text->slider = u_dy_slider;
+       add_subwindow(u_dy_Clr = new YUVShiftClr(plugin, this, clr_x, y, RESET_U_DY));
+       y += ys30;
+
        add_subwindow(new BC_Title(x, y, _("V_dx:")));
-       add_subwindow(v_dx = new YUVShiftLevel(plugin, &plugin->config.v_dx, x1, y));
-       y += 30;
-       add_subwindow(new BC_Title(x, y, _("V_dy:")));
-       add_subwindow(v_dy = new YUVShiftLevel(plugin, &plugin->config.v_dy, x1, y));
+       v_dx_text = new YUVShiftIText(this, plugin,
+               0, &plugin->config.v_dx, (x + x2), y, -MAXVALUE, MAXVALUE);
+       v_dx_text->create_objects();
+       v_dx_slider = new YUVShiftISlider(plugin,
+               v_dx_text, &plugin->config.v_dx, x3, y);
+       add_subwindow(v_dx_slider);
+       v_dx_text->slider = v_dx_slider;
+       add_subwindow(v_dx_Clr = new YUVShiftClr(plugin, this, clr_x, y, RESET_V_DX));
+       y += ys30;
 
-       y += 40;
+       add_subwindow(new BC_Title(x, y, _("V_dy:")));
+       v_dy_text = new YUVShiftIText(this, plugin,
+               0, &plugin->config.v_dy, (x + x2), y, -MAXVALUE, MAXVALUE);
+       v_dy_text->create_objects();
+       v_dy_slider = new YUVShiftISlider(plugin,
+               v_dy_text, &plugin->config.v_dy, x3, y);
+       add_subwindow(v_dy_slider);
+       v_dy_text->slider = v_dy_slider;
+       add_subwindow(v_dy_Clr = new YUVShiftClr(plugin, this, clr_x, y, RESET_V_DY));
+       y += ys40;
+
+// Reset section
+       add_subwindow(bar = new BC_Bar(x, y, get_w()-2*x));
+       y += ys10;
        add_subwindow(reset = new YUVShiftReset(plugin, this, x, y));
 
        show_window();
@@ -148,14 +278,49 @@ void YUVShiftWindow::create_objects()
 
 
 // for Reset button
-void YUVShiftWindow::update()
+void YUVShiftWindow::update_gui(int clear)
 {
-       y_dx->update(plugin->config.y_dx);
-       y_dy->update(plugin->config.y_dy);
-       u_dx->update(plugin->config.u_dx);
-       u_dy->update(plugin->config.u_dy);
-       v_dx->update(plugin->config.v_dx);
-       v_dy->update(plugin->config.v_dy);
+       switch(clear) {
+               case RESET_Y_DX :
+                       y_dx_text->update((int64_t)plugin->config.y_dx);
+                       y_dx_slider->update(plugin->config.y_dx);
+                       break;
+               case RESET_Y_DY :
+                       y_dy_text->update((int64_t)plugin->config.y_dy);
+                       y_dy_slider->update(plugin->config.y_dy);
+                       break;
+               case RESET_U_DX :
+                       u_dx_text->update((int64_t)plugin->config.u_dx);
+                       u_dx_slider->update(plugin->config.u_dx);
+                       break;
+               case RESET_U_DY :
+                       u_dy_text->update((int64_t)plugin->config.u_dy);
+                       u_dy_slider->update(plugin->config.u_dy);
+                       break;
+               case RESET_V_DX :
+                       v_dx_text->update((int64_t)plugin->config.v_dx);
+                       v_dx_slider->update(plugin->config.v_dx);
+                       break;
+               case RESET_V_DY :
+                       v_dy_text->update((int64_t)plugin->config.v_dy);
+                       v_dy_slider->update(plugin->config.v_dy);
+                       break;
+               case RESET_ALL :
+               default:
+                       y_dx_text->update((int64_t)plugin->config.y_dx);
+                       y_dx_slider->update(plugin->config.y_dx);
+                       y_dy_text->update((int64_t)plugin->config.y_dy);
+                       y_dy_slider->update(plugin->config.y_dy);
+                       u_dx_text->update((int64_t)plugin->config.u_dx);
+                       u_dx_slider->update(plugin->config.u_dx);
+                       u_dy_text->update((int64_t)plugin->config.u_dy);
+                       u_dy_slider->update(plugin->config.u_dy);
+                       v_dx_text->update((int64_t)plugin->config.v_dx);
+                       v_dx_slider->update(plugin->config.v_dx);
+                       v_dy_text->update((int64_t)plugin->config.v_dy);
+                       v_dy_slider->update(plugin->config.v_dy);
+                       break;
+       }
 }
 
 
@@ -187,12 +352,18 @@ void YUVShiftEffect::update_gui()
                YUVShiftWindow *yuv_wdw = (YUVShiftWindow*)thread->window;
                yuv_wdw->lock_window("YUVShiftEffect::update_gui");
                load_configuration();
-               yuv_wdw->y_dx->update(config.y_dx);
-               yuv_wdw->y_dy->update(config.y_dy);
-               yuv_wdw->u_dx->update(config.u_dx);
-               yuv_wdw->u_dy->update(config.u_dy);
-               yuv_wdw->v_dx->update(config.v_dx);
-               yuv_wdw->v_dy->update(config.v_dy);
+               yuv_wdw->y_dx_text->update((int64_t)config.y_dx);
+               yuv_wdw->y_dx_slider->update(config.y_dx);
+               yuv_wdw->y_dy_text->update((int64_t)config.y_dy);
+               yuv_wdw->y_dy_slider->update(config.y_dy);
+               yuv_wdw->u_dx_text->update((int64_t)config.u_dx);
+               yuv_wdw->u_dx_slider->update(config.u_dx);
+               yuv_wdw->u_dy_text->update((int64_t)config.u_dy);
+               yuv_wdw->u_dy_slider->update(config.u_dy);
+               yuv_wdw->v_dx_text->update((int64_t)config.v_dx);
+               yuv_wdw->v_dx_slider->update(config.v_dx);
+               yuv_wdw->v_dy_text->update((int64_t)config.v_dy);
+               yuv_wdw->v_dy_slider->update(config.v_dy);
                yuv_wdw->unlock_window();
        }
 }