X-Git-Url: https://git.cinelerra-gg.org/git/?a=blobdiff_plain;f=cinelerra-5.1%2Fplugins%2Fyuv411%2Fyuv411win.C;h=e80f1439fa6ecc4f5c3b755b9c7032d019c503dc;hb=0fd1b583cf9d14672c35f7369ba88388413be4f7;hp=605f1aaf2d741e4172d34362f9d10e6cd71877f9;hpb=7fd85fb66168f6b518c5f2d73e04036e87faa0e1;p=goodguy%2Fcinelerra.git diff --git a/cinelerra-5.1/plugins/yuv411/yuv411win.C b/cinelerra-5.1/plugins/yuv411/yuv411win.C index 605f1aaf..e80f1439 100644 --- a/cinelerra-5.1/plugins/yuv411/yuv411win.C +++ b/cinelerra-5.1/plugins/yuv411/yuv411win.C @@ -1,11 +1,14 @@ #include "bcdisplayinfo.h" +#include "edl.h" +#include "edlsession.h" #include "yuv411win.h" #include "language.h" yuv411Window::yuv411Window(yuv411Main *client) - : PluginClientWindow(client, 250, 220, 250, 220, 0) + : PluginClientWindow(client, xS(260), yS(250), xS(260), yS(250), 0) { this->client = client; + colormodel = -1; } yuv411Window::~yuv411Window() @@ -14,40 +17,61 @@ yuv411Window::~yuv411Window() void yuv411Window::create_objects() { - int x = 10, y = 10, x1=90; + int xs10 = xS(10), xs90 = xS(90); + int ys10 = yS(10), ys30 = yS(30); + int x = xs10, y = ys10, x1=xs90; add_tool(avg_vertical = new yuv411Toggle(client, &(client->config.avg_vertical), _("Vertical average"), x, y)); - y += 30; + y += ys30; add_tool(int_horizontal = new yuv411Toggle(client, &(client->config.int_horizontal), _("Horizontal interpolate"), x, y)); - y += 30; + y += ys30; add_tool(inpainting = new yuv411Toggle(client, &(client->config.inpainting), _("Inpainting method"), x, y)); - y += 30; + y += ys30; add_subwindow(new BC_Title(x, y, _("Offset:"))); add_subwindow(offset=new yuv411Offset(client,x1,y)); - y += 30; + y += ys30; add_subwindow(new BC_Title(x, y, _("Threshold:"))); add_subwindow(thresh=new yuv411Thresh(client,x1,y)); - y += 30; + y += ys30; add_subwindow(new BC_Title(x, y, _("Bias:"))); add_subwindow(bias=new yuv411Bias(client,x1,y)); - y += 30; + y += ys30; + int y1 = get_h() - yuv411Reset::calculate_h() - yS(20); + add_subwindow(reset = new yuv411Reset(client, this, x, y1+ys10)); show_window(); flush(); yuv_warning = new BC_Title(x, y, _("Warning: colormodel not YUV"),MEDIUMFONT,RED); add_subwindow(yuv_warning); - yuv_warning->hide_window(); + EDL *edl = client->get_edl(); + colormodel = edl->session->color_model; + switch( colormodel ) { + case BC_YUV888: + case BC_YUVA8888: + yuv_warning->hide_window(); + break; + } +} + +void yuv411Window::update() +{ + avg_vertical->update(client->config.avg_vertical); + int_horizontal->update(client->config.int_horizontal); + inpainting->update(client->config.inpainting); + offset->update(client->config.offset); + thresh->update(client->config.thresh); + bias->update(client->config.bias); } int yuv411Window::close_event() @@ -74,7 +98,7 @@ int yuv411Toggle::handle_event() } yuv411Offset::yuv411Offset(yuv411Main *client, int x, int y) - : BC_FSlider(x, y, 0, 100, 100, (float)0, (float)2, + : BC_FSlider(x+xS(60), y, 0, xS(100), yS(100), (float)0, (float)2, (float)client->config.offset) { this->client = client; @@ -88,7 +112,7 @@ int yuv411Offset::handle_event() } yuv411Thresh::yuv411Thresh(yuv411Main *client, int x, int y) - : BC_FSlider(x, y, 0, 100, 100, (float)1, (float)100, + : BC_FSlider(x+xS(60), y, 0, xS(100), yS(100), (float)1, (float)100, (float)client->config.thresh) { this->client = client; @@ -102,7 +126,7 @@ int yuv411Thresh::handle_event() } yuv411Bias::yuv411Bias(yuv411Main *client, int x, int y) - : BC_FSlider(x, y, 0, 100, 100, (float)0, (float)25, + : BC_FSlider(x+xS(60), y, 0, xS(100), yS(100), (float)0, (float)25, (float)client->config.bias) { this->client = client; @@ -116,6 +140,25 @@ int yuv411Bias::handle_event() return 1; } +yuv411Reset::yuv411Reset(yuv411Main *client, yuv411Window *window, int x, int y) + : BC_GenericButton(x, y, _("Reset")) +{ + this->client = client; + this->window = window; +} +yuv411Reset::~yuv411Reset() +{ +} +int yuv411Reset::handle_event() +{ + client->config.reset(); + window->update(); + window->update_enables(); + client->send_configure_change(); + return 1; +} + + void yuv411Window::update_enables() { yuv411Config &config = client->config; @@ -149,4 +192,3 @@ void yuv411Window::show_warning(int warn) yuv_warning->hide_window(); } -