Merge CV, ver=5.1; ops/methods from HV, and interface from CV where possible
[goodguy/history.git] / cinelerra-5.1 / cinelerra / new.C
diff --git a/cinelerra-5.1/cinelerra/new.C b/cinelerra-5.1/cinelerra/new.C
new file mode 100644 (file)
index 0000000..6c37e34
--- /dev/null
@@ -0,0 +1,957 @@
+
+/*
+ * CINELERRA
+ * Copyright (C) 2008 Adam Williams <broadcast at earthling dot net>
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
+ *
+ */
+
+#include "clip.h"
+#include "cplayback.h"
+#include "cwindow.h"
+#include "bchash.h"
+#include "edl.h"
+#include "edlsession.h"
+#include "filexml.h"
+#include "interlacemodes.h"
+#include "language.h"
+#include "levelwindow.h"
+#include "mainundo.h"
+#include "mainmenu.h"
+#include "mutex.h"
+#include "mwindow.h"
+#include "mwindowgui.h"
+#include "new.h"
+#include "newpresets.h"
+#include "mainsession.h"
+#include "patchbay.h"
+#include "preferences.h"
+#include "theme.h"
+#include "transportque.h"
+#include "videowindow.h"
+#include "vplayback.h"
+#include "vwindow.h"
+
+
+#include <string.h>
+
+
+#define WIDTH 600
+#define HEIGHT 400
+
+
+New::New(MWindow *mwindow)
+ : BC_MenuItem(_("New"), "n", 'n')
+{
+       this->mwindow = mwindow;
+       script = 0;
+       new_edl = 0;
+       thread = 0;
+}
+
+New::~New()
+{
+       delete thread;
+}
+
+void New::create_objects()
+{
+       thread = new NewThread(mwindow, this);
+}
+
+int New::handle_event()
+{
+       mwindow->gui->unlock_window();
+       mwindow->edl->save_defaults(mwindow->defaults);
+       create_new_edl();
+       create_new_project();
+//     thread->start();
+       mwindow->gui->lock_window("New::handle_event");
+
+       return 1;
+}
+
+void New::create_new_edl()
+{
+       if(!new_edl)
+       {
+               new_edl = new EDL;
+               new_edl->create_objects();
+               new_edl->load_defaults(mwindow->defaults);
+       }
+}
+
+
+int New::create_new_project()
+{
+       mwindow->cwindow->playback_engine->que->send_command(STOP,
+               CHANGE_NONE,
+               0,
+               0);
+
+       for(int i = 0; i < mwindow->vwindows.size(); i++)
+       {
+               mwindow->vwindows.get(i)->playback_engine->que->send_command(STOP,
+                       CHANGE_NONE,
+                       0,
+                       0);
+               mwindow->vwindows.get(i)->playback_engine->interrupt_playback(0);
+       }
+
+       mwindow->cwindow->playback_engine->interrupt_playback(0);
+
+       mwindow->gui->lock_window();
+       mwindow->reset_caches();
+
+
+
+       memcpy(new_edl->session->achannel_positions,
+               &mwindow->preferences->channel_positions[
+                       MAXCHANNELS * (new_edl->session->audio_channels - 1)],
+               sizeof(int) * MAXCHANNELS);
+       new_edl->session->boundaries();
+       new_edl->create_default_tracks();
+
+       mwindow->undo->update_undo_before();
+       mwindow->set_filename("");
+
+       mwindow->hide_plugins();
+       mwindow->edl->Garbage::remove_user();
+       mwindow->edl = new_edl;
+       new_edl = 0;
+       mwindow->save_defaults();
+
+// Load file sequence
+       mwindow->update_project(LOADMODE_REPLACE);
+       mwindow->session->changes_made = 0;
+       mwindow->undo->update_undo_after(_("New"), LOAD_ALL);
+       mwindow->gui->unlock_window();
+       return 0;
+}
+
+NewThread::NewThread(MWindow *mwindow, New *new_project)
+ : BC_DialogThread()
+{
+       this->mwindow = mwindow;
+       this->new_project = new_project;
+       nwindow = 0;
+}
+
+NewThread::~NewThread()
+{
+       close_window();
+}
+
+
+
+BC_Window* NewThread::new_gui()
+{
+       mwindow->edl->save_defaults(mwindow->defaults);
+       new_project->create_new_edl();
+       load_defaults();
+
+       mwindow->gui->lock_window("NewThread::new_gui");
+       int x = mwindow->gui->get_abs_cursor_x(0) - WIDTH / 2;
+       int y = mwindow->gui->get_abs_cursor_y(0) - HEIGHT / 2;
+
+       nwindow = new NewWindow(mwindow, this, x, y);
+       nwindow->create_objects();
+       mwindow->gui->unlock_window();
+       return nwindow;
+}
+
+
+
+void NewThread::handle_close_event(int result)
+{
+
+       new_project->new_edl->save_defaults(mwindow->defaults);
+       mwindow->defaults->save();
+
+       if(result)
+       {
+// Aborted
+               if( !new_project->new_edl->Garbage::remove_user() )
+                       new_project->new_edl = 0;
+       }
+       else
+       {
+               new_project->create_new_project();
+       }
+}
+
+
+
+int NewThread::load_defaults()
+{
+       auto_aspect = mwindow->defaults->get("AUTOASPECT", 0);
+       return 0;
+}
+
+int NewThread::save_defaults()
+{
+       mwindow->defaults->update("AUTOASPECT", auto_aspect);
+       return 0;
+}
+
+int NewThread::update_aspect()
+{
+       if(auto_aspect)
+       {
+               char string[BCTEXTLEN];
+               mwindow->create_aspect_ratio(new_project->new_edl->session->aspect_w,
+                       new_project->new_edl->session->aspect_h,
+                       new_project->new_edl->session->output_w,
+                       new_project->new_edl->session->output_h);
+               sprintf(string, "%.02f", new_project->new_edl->session->aspect_w);
+               nwindow->aspect_w_text->update(string);
+               sprintf(string, "%.02f", new_project->new_edl->session->aspect_h);
+               nwindow->aspect_h_text->update(string);
+       }
+       return 0;
+}
+
+
+
+
+#if 0
+N_("Cinelerra: New Project");
+#endif
+
+NewWindow::NewWindow(MWindow *mwindow, NewThread *new_thread, int x, int y)
+ : BC_Window(_(_(PROGRAM_NAME ": New Project")),
+               x,
+               y,
+               WIDTH,
+               HEIGHT,
+               -1,
+               -1,
+               0,
+               0,
+               1)
+{
+       this->mwindow = mwindow;
+       this->new_thread = new_thread;
+       this->new_edl = new_thread->new_project->new_edl;
+       format_presets = 0;
+}
+
+NewWindow::~NewWindow()
+{
+       lock_window("NewWindow::~NewWindow");
+       if(format_presets) delete format_presets;
+       unlock_window();
+}
+
+void NewWindow::create_objects()
+{
+       int x = 10, y = 10, x1, y1;
+       BC_TextBox *textbox;
+
+       lock_window("NewWindow::create_objects");
+       mwindow->theme->draw_new_bg(this);
+
+       add_subwindow(new BC_Title(x, y, _("Parameters for the new project:")));
+       y += 20;
+
+       format_presets = new NewPresets(mwindow,
+               this,
+               x,
+               y);
+       format_presets->create_objects();
+       x = format_presets->x;
+       y = format_presets->y;
+
+
+
+       y += 40;
+       y1 = y;
+       add_subwindow(new BC_Title(x, y, _("Audio"), LARGEFONT));
+       y += 30;
+
+       x1 = x;
+       add_subwindow(new BC_Title(x1, y, _("Tracks:")));
+       x1 += 100;
+       add_subwindow(atracks = new NewATracks(this, "", x1, y));
+       x1 += atracks->get_w();
+       add_subwindow(new NewATracksTumbler(this, x1, y));
+       y += atracks->get_h() + 5;
+
+       x1 = x;
+       add_subwindow(new BC_Title(x1, y, _("Channels:")));
+       x1 += 100;
+       add_subwindow(achannels = new NewAChannels(this, "", x1, y));
+       x1 += achannels->get_w();
+       add_subwindow(new NewAChannelsTumbler(this, x1, y));
+       y += achannels->get_h() + 5;
+
+       x1 = x;
+       add_subwindow(new BC_Title(x1, y, _("Samplerate:")));
+       x1 += 100;
+       add_subwindow(sample_rate = new NewSampleRate(this, "", x1, y));
+       x1 += sample_rate->get_w();
+       add_subwindow(new SampleRatePulldown(mwindow, sample_rate, x1, y));
+
+       x += 250;
+       y = y1;
+       add_subwindow(new BC_Title(x, y, _("Video"), LARGEFONT));
+       y += 30;
+       x1 = x;
+       add_subwindow(new BC_Title(x1, y, _("Tracks:")));
+       x1 += 100;
+       add_subwindow(vtracks = new NewVTracks(this, "", x1, y));
+       x1 += vtracks->get_w();
+       add_subwindow(new NewVTracksTumbler(this, x1, y));
+       y += vtracks->get_h() + 5;
+
+//     x1 = x;
+//     add_subwindow(new BC_Title(x1, y, _("Channels:")));
+//     x1 += 100;
+//     add_subwindow(vchannels = new NewVChannels(this, "", x1, y));
+//     x1 += vchannels->get_w();
+//     add_subwindow(new NewVChannelsTumbler(this, x1, y));
+//     y += vchannels->get_h() + 5;
+       x1 = x;
+       add_subwindow(new BC_Title(x1, y, _("Framerate:")));
+       x1 += 100;
+       add_subwindow(frame_rate = new NewFrameRate(this, "", x1, y));
+       x1 += frame_rate->get_w();
+       add_subwindow(new FrameRatePulldown(mwindow, frame_rate, x1, y));
+       y += frame_rate->get_h() + 5;
+
+//     x1 = x;
+//     add_subwindow(new BC_Title(x1, y, _("Canvas size:")));
+//     x1 += 100;
+//     add_subwindow(canvas_w_text = new NewTrackW(this, x1, y));
+//     x1 += canvas_w_text->get_w() + 2;
+//     add_subwindow(new BC_Title(x1, y, "x"));
+//     x1 += 10;
+//     add_subwindow(canvas_h_text = new NewTrackH(this, x1, y));
+//     x1 += canvas_h_text->get_w();
+//     add_subwindow(new FrameSizePulldown(mwindow,
+//             canvas_w_text,
+//             canvas_h_text,
+//             x1,
+//             y));
+//     x1 += 100;
+//     add_subwindow(new NewCloneToggle(mwindow, this, x1, y));
+//     y += canvas_h_text->get_h() + 5;
+
+       x1 = x;
+       add_subwindow(new BC_Title(x1, y, _("Canvas size:")));
+       x1 += 100;
+       add_subwindow(output_w_text = new NewOutputW(this, x1, y));
+       x1 += output_w_text->get_w() + 2;
+       add_subwindow(new BC_Title(x1, y, "x"));
+       x1 += 10;
+       add_subwindow(output_h_text = new NewOutputH(this, x1, y));
+       x1 += output_h_text->get_w();
+       FrameSizePulldown *pulldown;
+       add_subwindow(pulldown = new FrameSizePulldown(mwindow->theme,
+               output_w_text,
+               output_h_text,
+               x1,
+               y));
+       x1 += pulldown->get_w() + 5;
+       add_subwindow(new NewSwapExtents(mwindow, this, x1, y));
+       y += output_h_text->get_h() + 5;
+
+       x1 = x;
+       add_subwindow(new BC_Title(x1, y, _("Aspect ratio:")));
+       x1 += 100;
+       add_subwindow(aspect_w_text = new NewAspectW(this, "", x1, y));
+       x1 += aspect_w_text->get_w() + 2;
+       add_subwindow(new BC_Title(x1, y, ":"));
+       x1 += 10;
+       add_subwindow(aspect_h_text = new NewAspectH(this, "", x1, y));
+       x1 += aspect_h_text->get_w();
+       add_subwindow(new AspectPulldown(mwindow,
+               aspect_w_text,
+               aspect_h_text,
+               x1,
+               y));
+
+       x1 = aspect_w_text->get_x();
+       y += aspect_w_text->get_h() + 5;
+       add_subwindow(new NewAspectAuto(this, x1, y));
+       y += 40;
+       add_subwindow(new BC_Title(x, y, _("Color model:")));
+       add_subwindow(textbox = new BC_TextBox(x + 100, y, 200, 1, ""));
+       add_subwindow(color_model = new ColormodelPulldown(mwindow,
+               textbox,
+               &new_edl->session->color_model,
+               x + 100 + textbox->get_w(),
+               y));
+       y += textbox->get_h() + 5;
+
+       // --------------------
+       add_subwindow(new BC_Title(x, y, _("Interlace mode:")));
+       add_subwindow(textbox = new BC_TextBox(x + 100, y, 140, 1, ""));
+       add_subwindow(interlace_pulldown = new InterlacemodePulldown(mwindow,
+               textbox,
+               &new_edl->session->interlace_mode,
+               (ArrayList<BC_ListBoxItem*>*)&mwindow->interlace_project_modes,
+               x + 100 + textbox->get_w(),
+               y));
+       y += textbox->get_h() + 5;
+
+       add_subwindow(new BC_OKButton(this,
+               mwindow->theme->get_image_set("new_ok_images")));
+       add_subwindow(new BC_CancelButton(this,
+               mwindow->theme->get_image_set("new_cancel_images")));
+       flash();
+       update();
+       show_window();
+       unlock_window();
+}
+
+int NewWindow::update()
+{
+       atracks->update((int64_t)new_edl->session->audio_tracks);
+       achannels->update((int64_t)new_edl->session->audio_channels);
+       sample_rate->update((int64_t)new_edl->session->sample_rate);
+       vtracks->update((int64_t)new_edl->session->video_tracks);
+       frame_rate->update((float)new_edl->session->frame_rate);
+       output_w_text->update((int64_t)new_edl->session->output_w);
+       output_h_text->update((int64_t)new_edl->session->output_h);
+       aspect_w_text->update((float)new_edl->session->aspect_w);
+       aspect_h_text->update((float)new_edl->session->aspect_h);
+       interlace_pulldown->update(new_edl->session->interlace_mode);
+       color_model->update_value(new_edl->session->color_model);
+       return 0;
+}
+
+
+
+
+
+
+
+NewPresets::NewPresets(MWindow *mwindow, NewWindow *gui, int x, int y)
+ : FormatPresets(mwindow, gui, 0, x, y)
+{
+}
+
+NewPresets::~NewPresets()
+{
+}
+
+int NewPresets::handle_event()
+{
+       new_gui->update();
+       return 1;
+}
+
+EDL* NewPresets::get_edl()
+{
+       return new_gui->new_edl;
+}
+
+
+
+NewATracks::NewATracks(NewWindow *nwindow, const char *text, int x, int y)
+ : BC_TextBox(x, y, 90, 1, text)
+{
+       this->nwindow = nwindow;
+}
+
+int NewATracks::handle_event()
+{
+       nwindow->new_edl->session->audio_tracks = atol(get_text());
+       return 1;
+}
+
+NewATracksTumbler::NewATracksTumbler(NewWindow *nwindow, int x, int y)
+ : BC_Tumbler(x, y)
+{
+       this->nwindow = nwindow;
+}
+int NewATracksTumbler::handle_up_event()
+{
+       nwindow->new_edl->session->audio_tracks++;
+       nwindow->new_edl->boundaries();
+       nwindow->update();
+       return 1;
+}
+int NewATracksTumbler::handle_down_event()
+{
+       nwindow->new_edl->session->audio_tracks--;
+       nwindow->new_edl->boundaries();
+       nwindow->update();
+       return 1;
+}
+
+NewAChannels::NewAChannels(NewWindow *nwindow, const char *text, int x, int y)
+ : BC_TextBox(x, y, 90, 1, text)
+{
+       this->nwindow = nwindow;
+}
+
+int NewAChannels::handle_event()
+{
+       nwindow->new_edl->session->audio_channels = atol(get_text());
+       return 1;
+}
+
+NewAChannelsTumbler::NewAChannelsTumbler(NewWindow *nwindow, int x, int y)
+ : BC_Tumbler(x, y)
+{
+       this->nwindow = nwindow;
+}
+int NewAChannelsTumbler::handle_up_event()
+{
+       nwindow->new_edl->session->audio_channels++;
+       nwindow->new_edl->boundaries();
+       nwindow->update();
+       return 1;
+}
+int NewAChannelsTumbler::handle_down_event()
+{
+       nwindow->new_edl->session->audio_channels--;
+       nwindow->new_edl->boundaries();
+       nwindow->update();
+       return 1;
+}
+
+
+NewSampleRate::NewSampleRate(NewWindow *nwindow, const char *text, int x, int y)
+ : BC_TextBox(x, y, 90, 1, text)
+{
+       this->nwindow = nwindow;
+}
+
+int NewSampleRate::handle_event()
+{
+       nwindow->new_edl->session->sample_rate = atol(get_text());
+       return 1;
+}
+
+SampleRatePulldown::SampleRatePulldown(MWindow *mwindow, BC_TextBox *output, int x, int y)
+ : BC_ListBox(x,
+       y,
+       100,
+       200,
+       LISTBOX_TEXT,
+       &mwindow->theme->sample_rates,
+       0,
+       0,
+       1,
+       0,
+       1)
+{
+       this->mwindow = mwindow;
+       this->output = output;
+}
+int SampleRatePulldown::handle_event()
+{
+       char *text = get_selection(0, 0)->get_text();
+       output->update(text);
+       output->handle_event();
+       return 1;
+}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+NewVTracks::NewVTracks(NewWindow *nwindow, const char *text, int x, int y)
+ : BC_TextBox(x, y, 90, 1, text)
+{
+       this->nwindow = nwindow;
+}
+
+int NewVTracks::handle_event()
+{
+       nwindow->new_edl->session->video_tracks = atol(get_text());
+       return 1;
+}
+
+NewVTracksTumbler::NewVTracksTumbler(NewWindow *nwindow, int x, int y)
+ : BC_Tumbler(x, y)
+{
+       this->nwindow = nwindow;
+}
+int NewVTracksTumbler::handle_up_event()
+{
+       nwindow->new_edl->session->video_tracks++;
+       nwindow->new_edl->boundaries();
+       nwindow->update();
+       return 1;
+}
+int NewVTracksTumbler::handle_down_event()
+{
+       nwindow->new_edl->session->video_tracks--;
+       nwindow->new_edl->boundaries();
+       nwindow->update();
+       return 1;
+}
+
+NewVChannels::NewVChannels(NewWindow *nwindow, const char *text, int x, int y)
+ : BC_TextBox(x, y, 90, 1, text)
+{
+       this->nwindow = nwindow;
+}
+
+int NewVChannels::handle_event()
+{
+       nwindow->new_edl->session->video_channels = atol(get_text());
+       return 1;
+}
+
+NewVChannelsTumbler::NewVChannelsTumbler(NewWindow *nwindow, int x, int y)
+ : BC_Tumbler(x, y)
+{
+       this->nwindow = nwindow;
+}
+int NewVChannelsTumbler::handle_up_event()
+{
+       nwindow->new_edl->session->video_channels++;
+       nwindow->new_edl->boundaries();
+       nwindow->update();
+       return 1;
+}
+int NewVChannelsTumbler::handle_down_event()
+{
+       nwindow->new_edl->session->video_channels--;
+       nwindow->new_edl->boundaries();
+       nwindow->update();
+       return 1;
+}
+
+NewFrameRate::NewFrameRate(NewWindow *nwindow, const char *text, int x, int y)
+ : BC_TextBox(x, y, 90, 1, text)
+{
+       this->nwindow = nwindow;
+}
+
+int NewFrameRate::handle_event()
+{
+       nwindow->new_edl->session->frame_rate = Units::atoframerate(get_text());
+       return 1;
+}
+
+FrameRatePulldown::FrameRatePulldown(MWindow *mwindow,
+       BC_TextBox *output,
+       int x,
+       int y)
+ : BC_ListBox(x,
+       y,
+       100,
+       200,
+       LISTBOX_TEXT,
+       &mwindow->theme->frame_rates,
+       0,
+       0,
+       1,
+       0,
+       1)
+{
+       this->mwindow = mwindow;
+       this->output = output;
+}
+int FrameRatePulldown::handle_event()
+{
+       char *text = get_selection(0, 0)->get_text();
+       output->update(text);
+       output->handle_event();
+       return 1;
+}
+
+FrameSizePulldown::FrameSizePulldown(Theme *theme,
+               BC_TextBox *output_w,
+               BC_TextBox *output_h,
+               int x,
+               int y)
+ : BC_ListBox(x,
+       y,
+       100,
+       250,
+       LISTBOX_TEXT,
+       &theme->frame_sizes,
+       0,
+       0,
+       1,
+       0,
+       1)
+{
+       this->theme = theme;
+       this->output_w = output_w;
+       this->output_h = output_h;
+}
+int FrameSizePulldown::handle_event()
+{
+       char *text = get_selection(0, 0)->get_text();
+       char string[BCTEXTLEN];
+       int64_t w, h;
+       char *ptr;
+
+       strcpy(string, text);
+       ptr = strrchr(string, 'x');
+       if(ptr)
+       {
+               ptr++;
+               h = atol(ptr);
+
+               *--ptr = 0;
+               w = atol(string);
+               output_w->update(w);
+               output_h->update(h);
+               output_w->handle_event();
+               output_h->handle_event();
+       }
+       return 1;
+}
+
+NewOutputW::NewOutputW(NewWindow *nwindow, int x, int y)
+ : BC_TextBox(x, y, 70, 1, nwindow->new_edl->session->output_w)
+{
+       this->nwindow = nwindow;
+}
+int NewOutputW::handle_event()
+{
+       nwindow->new_edl->session->output_w = MAX(1,atol(get_text()));
+       nwindow->new_thread->update_aspect();
+       return 1;
+}
+
+NewOutputH::NewOutputH(NewWindow *nwindow, int x, int y)
+ : BC_TextBox(x, y, 70, 1, nwindow->new_edl->session->output_h)
+{
+       this->nwindow = nwindow;
+}
+int NewOutputH::handle_event()
+{
+       nwindow->new_edl->session->output_h = MAX(1, atol(get_text()));
+       nwindow->new_thread->update_aspect();
+       return 1;
+}
+
+NewAspectW::NewAspectW(NewWindow *nwindow, const char *text, int x, int y)
+ : BC_TextBox(x, y, 70, 1, text)
+{
+       this->nwindow = nwindow;
+}
+
+int NewAspectW::handle_event()
+{
+       nwindow->new_edl->session->aspect_w = atof(get_text());
+       return 1;
+}
+
+NewAspectH::NewAspectH(NewWindow *nwindow, const char *text, int x, int y)
+ : BC_TextBox(x, y, 70, 1, text)
+{
+       this->nwindow = nwindow;
+}
+
+int NewAspectH::handle_event()
+{
+       nwindow->new_edl->session->aspect_h = atof(get_text());
+       return 1;
+}
+
+AspectPulldown::AspectPulldown(MWindow *mwindow,
+               BC_TextBox *output_w,
+               BC_TextBox *output_h,
+               int x,
+               int y)
+ : BC_ListBox(x,
+       y,
+       100,
+       200,
+       LISTBOX_TEXT,
+       &mwindow->theme->aspect_ratios,
+       0,
+       0,
+       1,
+       0,
+       1)
+{
+       this->mwindow = mwindow;
+       this->output_w = output_w;
+       this->output_h = output_h;
+}
+int AspectPulldown::handle_event()
+{
+       char *text = get_selection(0, 0)->get_text();
+       char string[BCTEXTLEN];
+       float w, h;
+       char *ptr;
+
+       strcpy(string, text);
+       ptr = strrchr(string, ':');
+       if(ptr)
+       {
+               ptr++;
+               h = atof(ptr);
+
+               *--ptr = 0;
+               w = atof(string);
+               output_w->update(w);
+               output_h->update(h);
+               output_w->handle_event();
+               output_h->handle_event();
+       }
+       return 1;
+}
+
+ColormodelItem::ColormodelItem(const char *text, int value)
+ : BC_ListBoxItem(text)
+{
+       this->value = value;
+}
+
+ColormodelPulldown::ColormodelPulldown(MWindow *mwindow,
+               BC_TextBox *output_text,
+               int *output_value,
+               int x,
+               int y)
+ : BC_ListBox(x,
+       y,
+       200,
+       150,
+       LISTBOX_TEXT,
+       (ArrayList<BC_ListBoxItem*>*)&mwindow->colormodels,
+       0,
+       0,
+       1,
+       0,
+       1)
+{
+       this->mwindow = mwindow;
+       this->output_text = output_text;
+       this->output_value = output_value;
+       output_text->update(colormodel_to_text());
+}
+
+int ColormodelPulldown::handle_event()
+{
+       output_text->update(get_selection(0, 0)->get_text());
+       *output_value = ((ColormodelItem*)get_selection(0, 0))->value;
+       return 1;
+}
+
+const char* ColormodelPulldown::colormodel_to_text()
+{
+       for(int i = 0; i < mwindow->colormodels.total; i++)
+               if(mwindow->colormodels.values[i]->value == *output_value)
+                       return mwindow->colormodels.values[i]->get_text();
+       return _("Unknown");
+}
+
+void ColormodelPulldown::update_value(int value)
+{
+       *output_value = value;
+       output_text->update(colormodel_to_text());
+}
+
+
+InterlacemodeItem::InterlacemodeItem(const char *text, int value)
+ : BC_ListBoxItem(text)
+{
+       this->value = value;
+}
+
+InterlacemodePulldown::InterlacemodePulldown(MWindow *mwindow,
+               BC_TextBox *output_text,
+               int *output_value,
+               ArrayList<BC_ListBoxItem*> *data,
+               int x,
+               int y)
+ : BC_ListBox(x, y, 200, 150, LISTBOX_TEXT, data, 0, 0, 1, 0, 1)
+{
+       this->mwindow = mwindow;
+       this->output_text = output_text;
+       this->output_value = output_value;
+       output_text->update(interlacemode_to_text());
+}
+
+int InterlacemodePulldown::handle_event()
+{
+       output_text->update(get_selection(0, 0)->get_text());
+       *output_value = ((InterlacemodeItem*)get_selection(0, 0))->value;
+       return 1;
+}
+
+const char* InterlacemodePulldown::interlacemode_to_text()
+{
+       ilacemode_to_text(this->string,*output_value);
+       return (this->string);
+}
+
+int InterlacemodePulldown::update(int interlace_mode)
+{
+       *output_value = interlace_mode;
+       output_text->update(interlacemode_to_text());
+       return 1;
+}
+
+
+NewAspectAuto::NewAspectAuto(NewWindow *nwindow, int x, int y)
+ : BC_CheckBox(x, y, nwindow->new_thread->auto_aspect, _("Auto aspect ratio"))
+{
+       this->nwindow = nwindow;
+}
+NewAspectAuto::~NewAspectAuto()
+{
+}
+int NewAspectAuto::handle_event()
+{
+       nwindow->new_thread->auto_aspect = get_value();
+       nwindow->new_thread->update_aspect();
+       return 1;
+}
+
+
+
+
+
+
+
+
+NewSwapExtents::NewSwapExtents(MWindow *mwindow, NewWindow *gui, int x, int y)
+ : BC_Button(x, y, mwindow->theme->get_image_set("swap_extents"))
+{
+       this->mwindow = mwindow;
+       this->gui = gui;
+       set_tooltip(_("Swap dimensions"));
+}
+
+int NewSwapExtents::handle_event()
+{
+       int w = gui->new_edl->session->output_w;
+       int h = gui->new_edl->session->output_h;
+       gui->new_edl->session->output_w = h;
+       gui->new_edl->session->output_h = w;
+       gui->output_w_text->update((int64_t)h);
+       gui->output_h_text->update((int64_t)w);
+       gui->new_thread->update_aspect();
+       return 1;
+}
+
+
+
+