/*! \file dialog_setup.cpp
** \brief Template File
**
-** $Id: dialog_setup.cpp,v 1.1.1.1 2005/01/07 03:34:36 darco Exp $
+** $Id$
**
** \legal
-** Copyright (c) 2002 Robert B. Quattlebaum Jr.
+** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
+** Copyright (c) 2007 Chris Moore
**
-** This software and associated documentation
-** are CONFIDENTIAL and PROPRIETARY property of
-** the above-mentioned copyright holder.
+** This package 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.
**
-** You may not copy, print, publish, or in any
-** other way distribute this software without
-** a prior written agreement with
-** the copyright holder.
+** This package 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.
** \endlegal
*/
/* ========================================================================= */
#include <gtkmm/notebook.h>
#include <gtkmm/spinbutton.h>
#include "widget_enum.h"
+#include "autorecover.h"
#include <ETL/stringf>
#include <ETL/misc>
+#include "general.h"
+
#endif
/* === U S I N G =========================================================== */
/* === M E T H O D S ======================================================= */
Dialog_Setup::Dialog_Setup():
- Dialog(_("SYNFIG Studio Setup"),false,true),
+ Dialog(_("Synfig Studio Setup"),false,true),
adj_gamma_r(2.2,0.1,3.0,0.025,0.025,0.025),
adj_gamma_g(2.2,0.1,3.0,0.025,0.025,0.025),
adj_gamma_b(2.2,0.1,3.0,0.025,0.025,0.025),
adj_recent_files(15,1,50,1,1,1),
adj_undo_depth(100,10,5000,1,1,1),
- toggle_use_colorspace_gamma(_("Visually Linear Color Selection"))
+ toggle_use_colorspace_gamma(_("Visually Linear Color Selection")),
+ toggle_single_threaded(_("Use Only a Single Thread")),
+ toggle_restrict_radius_ducks(_("Restrict Real-Valued Ducks to Top Right Quadrant"))
{
// Setup the buttons
Gtk::Table *gamma_table=manage(new Gtk::Table(2,2,false));
notebook->append_page(*gamma_table,_("Gamma"));
//gamma_frame->add(*gamma_table);
-
- gamma_table->attach(gamma_pattern, 0, 2, 0, 1, Gtk::EXPAND, Gtk::SHRINK|Gtk::FILL, 0, 0);
+
+ gamma_table->attach(gamma_pattern, 0, 2, 0, 1, Gtk::EXPAND, Gtk::SHRINK|Gtk::FILL, 0, 0);
Gtk::HScale* scale_gamma_r(manage(new Gtk::HScale(adj_gamma_r)));
- gamma_table->attach(*manage(new Gtk::Label(_("Red"))), 0, 1, 1, 2, Gtk::SHRINK|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
- gamma_table->attach(*scale_gamma_r, 1, 2, 1, 2, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
+ gamma_table->attach(*manage(new Gtk::Label(_("Red"))), 0, 1, 1, 2, Gtk::SHRINK|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
+ gamma_table->attach(*scale_gamma_r, 1, 2, 1, 2, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
adj_gamma_r.signal_value_changed().connect(sigc::mem_fun(*this,&studio::Dialog_Setup::on_gamma_r_change));
-
+
Gtk::HScale* scale_gamma_g(manage(new Gtk::HScale(adj_gamma_g)));
- gamma_table->attach(*manage(new Gtk::Label(_("Green"))), 0, 1, 2, 3, Gtk::SHRINK|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
- gamma_table->attach(*scale_gamma_g, 1, 2, 2, 3, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
+ gamma_table->attach(*manage(new Gtk::Label(_("Green"))), 0, 1, 2, 3, Gtk::SHRINK|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
+ gamma_table->attach(*scale_gamma_g, 1, 2, 2, 3, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
adj_gamma_g.signal_value_changed().connect(sigc::mem_fun(*this,&studio::Dialog_Setup::on_gamma_g_change));
Gtk::HScale* scale_gamma_b(manage(new Gtk::HScale(adj_gamma_b)));
- gamma_table->attach(*manage(new Gtk::Label(_("Blue"))), 0, 1, 3, 4, Gtk::SHRINK|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
- gamma_table->attach(*scale_gamma_b, 1, 2, 3, 4, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
+ gamma_table->attach(*manage(new Gtk::Label(_("Blue"))), 0, 1, 3, 4, Gtk::SHRINK|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
+ gamma_table->attach(*scale_gamma_b, 1, 2, 3, 4, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
adj_gamma_b.signal_value_changed().connect(sigc::mem_fun(*this,&studio::Dialog_Setup::on_gamma_b_change));
- gamma_table->attach(*manage(new Gtk::Label(_("Black Level"))), 0, 1, 4, 5, Gtk::SHRINK|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
- gamma_table->attach(black_level_selector, 1, 2, 4, 5, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
+ gamma_table->attach(*manage(new Gtk::Label(_("Black Level"))), 0, 1, 4, 5, Gtk::SHRINK|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
+ gamma_table->attach(black_level_selector, 1, 2, 4, 5, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
black_level_selector.signal_value_changed().connect(sigc::mem_fun(*this,&studio::Dialog_Setup::on_black_level_change));
- //gamma_table->attach(*manage(new Gtk::Label(_("Red-Blue Level"))), 0, 1, 5, 6, Gtk::SHRINK|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
- //gamma_table->attach(red_blue_level_selector, 1, 2, 5, 6, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
+ //gamma_table->attach(*manage(new Gtk::Label(_("Red-Blue Level"))), 0, 1, 5, 6, Gtk::SHRINK|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
+ //gamma_table->attach(red_blue_level_selector, 1, 2, 5, 6, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
//red_blue_level_selector.signal_value_changed().connect(sigc::mem_fun(*this,&studio::Dialog_Setup::on_red_blue_level_change));
// Misc
Gtk::Table *misc_table=manage(new Gtk::Table(2,2,false));
notebook->append_page(*misc_table,_("Misc."));
-
+
// Misc - Timestamp
timestamp_menu=manage(new class Gtk::Menu());
- misc_table->attach(*manage(new Gtk::Label(_("Timestamp"))), 0, 1, 0, 1, Gtk::SHRINK|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
- misc_table->attach(timestamp_optionmenu, 1, 2, 0, 1, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
+ misc_table->attach(*manage(new Gtk::Label(_("Timestamp"))), 0, 1, 0, 1, Gtk::SHRINK|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
+ misc_table->attach(timestamp_optionmenu, 1, 2, 0, 1, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
#define ADD_TIMESTAMP(desc,x) \
timestamp_menu->items().push_back( \
ADD_TIMESTAMP("HHhMMmSSsFFf",Time::FORMAT_NORMAL|Time::FORMAT_NOSPACES|Time::FORMAT_FULL);
timestamp_optionmenu.set_menu(*timestamp_menu);
-
+
#undef ADD_TIMESTAMP
{
widget_enum=manage(new Widget_Enum());
widget_enum->set_param_desc(param_desc);
- misc_table->attach(*manage(new Gtk::Label(_("Unit System"))), 0, 1, 3, 4, Gtk::SHRINK|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
- misc_table->attach(*widget_enum, 1, 2, 3, 4, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
+ misc_table->attach(*manage(new Gtk::Label(_("Unit System"))), 0, 1, 3, 4, Gtk::SHRINK|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
+ misc_table->attach(*widget_enum, 1, 2, 3, 4, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
}
// Misc - recent files
Gtk::SpinButton* recent_files_spinbutton(manage(new Gtk::SpinButton(adj_recent_files,1,0)));
- misc_table->attach(*manage(new Gtk::Label(_("Recent Files"))), 0, 1, 1, 2, Gtk::SHRINK|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
- misc_table->attach(*recent_files_spinbutton, 1, 2, 1, 2, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
+ misc_table->attach(*manage(new Gtk::Label(_("Recent Files"))), 0, 1, 1, 2, Gtk::SHRINK|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
+ misc_table->attach(*recent_files_spinbutton, 1, 2, 1, 2, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
// Misc - use_colorspace_gamma
- misc_table->attach(toggle_use_colorspace_gamma, 0, 2, 2, 3, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
-
+ misc_table->attach(toggle_use_colorspace_gamma, 0, 2, 2, 3, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
+
+ // Misc - single_threaded
+ misc_table->attach(toggle_single_threaded, 0, 2, 4, 5, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
+
+ // Misc - auto backup interval
+ misc_table->attach(*manage(new Gtk::Label(_("Auto Backup Interval (0 to disable)"))), 0, 1, 5, 6, Gtk::SHRINK|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
+ misc_table->attach(auto_backup_interval, 1, 2, 5, 6, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
+
+ // Misc - restrict_radius_ducks
+ misc_table->attach(toggle_restrict_radius_ducks, 0, 2, 6, 7, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
+
show_all_children();
}
{
App::gamma.set_all(1.0/adj_gamma_r.get_value(),1.0/adj_gamma_g.get_value(),1.0/adj_gamma_b.get_value(),black_level_selector.get_value(),red_blue_level_selector.get_value());
- App::set_max_recent_files((int)adj_recent_files.get_value());
-
+ App::set_max_recent_files((int)adj_recent_files.get_value());
+
// Set the time format
App::set_time_format(get_time_format());
-
+
// Set the use_colorspace_gamma flag
App::use_colorspace_gamma=toggle_use_colorspace_gamma.get_active();
+ // Set the single_threaded flag
+ App::single_threaded=toggle_single_threaded.get_active();
+
+ // Set the auto backup interval
+ App::auto_recover->set_timeout(auto_backup_interval.get_value() * 1000);
+
App::distance_system=Distance::System(widget_enum->get_value());
-
+
+ // Set the restrict_radius_ducks flag
+ App::restrict_radius_ducks=toggle_restrict_radius_ducks.get_active();
+
App::save_settings();
}
void
Dialog_Setup::refresh()
{
- adj_gamma_r.set_value(1.0/App::gamma.get_gamma_r());
- adj_gamma_g.set_value(1.0/App::gamma.get_gamma_g());
- adj_gamma_b.set_value(1.0/App::gamma.get_gamma_b());
+ // Refresh the temporary gamma; do this before adjusting the sliders,
+ // or variables will be used before their initialization.
+ gamma_pattern.set_gamma_r(App::gamma.get_gamma_r());
+ gamma_pattern.set_gamma_g(App::gamma.get_gamma_g());
+ gamma_pattern.set_gamma_b(App::gamma.get_gamma_b());
+ gamma_pattern.set_black_level(App::gamma.get_black_level());
+ gamma_pattern.set_red_blue_level(App::gamma.get_red_blue_level());
+
+ adj_gamma_r.set_value(1.0/App::gamma.get_gamma_r());
+ adj_gamma_g.set_value(1.0/App::gamma.get_gamma_g());
+ adj_gamma_b.set_value(1.0/App::gamma.get_gamma_b());
black_level_selector.set_value(App::gamma.get_black_level());
red_blue_level_selector.set_value(App::gamma.get_red_blue_level());
-
- // Refresh the temporary gamma
- gamma_pattern.set_gamma_r(1.0/adj_gamma_r.get_value());
- gamma_pattern.set_gamma_g(1.0/adj_gamma_g.get_value());
- gamma_pattern.set_gamma_b(1.0/adj_gamma_b.get_value());
- gamma_pattern.set_black_level(black_level_selector.get_value());
- gamma_pattern.set_red_blue_level(red_blue_level_selector.get_value());
+
gamma_pattern.refresh();
-
+
adj_recent_files.set_value(App::get_max_recent_files());
-
+
// Refresh the time format
set_time_format(App::get_time_format());
widget_enum->set_value(App::distance_system);
-
+
// Refresh the status of the use_colorspace_gamma flag
toggle_use_colorspace_gamma.set_active(App::use_colorspace_gamma);
+ // Refresh the status of the single_threaded flag
+ toggle_single_threaded.set_active(App::single_threaded);
+
+ // Refresh the value of the auto backup interval
+ auto_backup_interval.set_value(App::auto_recover->get_timeout() / 1000);
+
+ // Refresh the status of the restrict_radius_ducks flag
+ toggle_restrict_radius_ducks.set_active(App::restrict_radius_ducks);
}
GammaPattern::GammaPattern():
set_size_request(tile_w*4,tile_h*3);
signal_expose_event().connect(sigc::mem_fun(*this, &studio::GammaPattern::redraw));
}
-
+
GammaPattern::~GammaPattern()
{
}
GammaPattern::refresh()
{
black[0].set_rgb_p(
- r_F32_to_F32(0.0),
- g_F32_to_F32(0.0),
+ r_F32_to_F32(0.0),
+ g_F32_to_F32(0.0),
b_F32_to_F32(0.0)
);
white[0].set_rgb_p(
- r_F32_to_F32(1.0),
- g_F32_to_F32(1.0),
+ r_F32_to_F32(1.0),
+ g_F32_to_F32(1.0),
b_F32_to_F32(1.0)
);
gray50[0].set_rgb_p(
- r_F32_to_F32(0.5),
- g_F32_to_F32(0.5),
+ r_F32_to_F32(0.5),
+ g_F32_to_F32(0.5),
b_F32_to_F32(0.5)
);
gray25[0].set_rgb_p(
- r_F32_to_F32(0.25),
- g_F32_to_F32(0.25),
+ r_F32_to_F32(0.25),
+ g_F32_to_F32(0.25),
b_F32_to_F32(0.25)
);
}
bool
-GammaPattern::redraw(GdkEventExpose*bleh)
+GammaPattern::redraw(GdkEventExpose */*bleh*/)
{
static const char hlines[] = { 3, 0 };
Glib::RefPtr<Gdk::GC> gc(Gdk::GC::create(get_window()));
-
+
int i;
Gdk::Color trueblack("#000000");
-
+
// 50% Pattern
for(i=0;i<4;i++)
{
gc->set_rgb_fg_color(black[i]);
get_window()->draw_rectangle(gc, true, i*tile_w, 0, tile_w, tile_h);
-
+
gc->set_stipple(Gdk::Bitmap::create(hlines,2,2));
gc->set_fill(Gdk::STIPPLED);
gc->set_rgb_fg_color(white[i]);
get_window()->draw_rectangle(gc, true, i*tile_w, 0, tile_w, tile_h);
-
+
gc->set_fill(Gdk::SOLID);
gc->set_rgb_fg_color(gray50[i]);
-
+
get_window()->draw_rectangle(gc, true, i*tile_w+tile_w/4, tile_h/4, tile_w-tile_w/2, tile_h-tile_h/2);
}
{
gc->set_rgb_fg_color(black[i]);
get_window()->draw_rectangle(gc, true, i*tile_w, tile_h, tile_w, tile_h);
-
+
gc->set_stipple(Gdk::Bitmap::create(hlines,2,2));
gc->set_fill(Gdk::STIPPLED);
gc->set_rgb_fg_color(gray50[i]);
get_window()->draw_rectangle(gc, true, i*tile_w, tile_h, tile_w, tile_h);
-
+
gc->set_fill(Gdk::SOLID);
gc->set_rgb_fg_color(gray25[i]);
-
+
get_window()->draw_rectangle(gc, true, i*tile_w+tile_w/4, tile_h+tile_h/4, tile_w-tile_w/2, tile_h-tile_h/2);
}
for(i=0;i<4;i++)
{
gc->set_rgb_fg_color(black[i]);
-
+
get_window()->draw_rectangle(gc, true, i*tile_w+tile_w/4, tile_h*2+tile_h/4, tile_w-tile_w/2, tile_h-tile_h/2);
}
return true;
}
-
+
BlackLevelSelector::BlackLevelSelector()
{
- set_size_request(-1,24);
+ set_size_request(-1,24);
signal_expose_event().connect(sigc::mem_fun(*this, &studio::BlackLevelSelector::redraw));
-
+
add_events(Gdk::BUTTON_PRESS_MASK | Gdk::BUTTON_RELEASE_MASK);
add_events(Gdk::BUTTON1_MOTION_MASK);
add_events(Gdk::BUTTON1_MOTION_MASK);
}
bool
-BlackLevelSelector::redraw(GdkEventExpose*bleh)
+BlackLevelSelector::redraw(GdkEventExpose */*bleh*/)
{
const int w(get_width()),h(get_height());
Glib::RefPtr<Gdk::GC> gc(Gdk::GC::create(get_window()));
int i;
-
+
// Draw the gradient
for(i=0;i<w;i++)
{
color.set_rgb(i*65536/w,i*65536/w,i*65536/w);
-
+
gc->set_rgb_fg_color(color);
get_window()->draw_rectangle(gc, true, i, 0, 1, h);
}
-
+
// Draw a frame
gc->set_rgb_fg_color(Gdk::Color("#000000"));
get_window()->draw_rectangle(gc, false, 0, 0, w-1, h-1);
get_window()->draw_rectangle(gc, true, i, 1, 1, h-1);
// Print out the value
- Glib::RefPtr<Pango::Layout> layout(Pango::Layout::create(get_pango_context()));
+ Glib::RefPtr<Pango::Layout> layout(Pango::Layout::create(get_pango_context()));
layout->set_text(etl::strprintf("%0.01f%%",level*100.0f));
layout->set_alignment(Pango::ALIGN_CENTER);
gc->set_rgb_fg_color(Gdk::Color("#a00000"));
void
-Dialog_Setup::set_time_format(Time::Format x)
+Dialog_Setup::set_time_format(synfig::Time::Format x)
{
time_format=x;
if(x<=Time::FORMAT_VIDEO)
RedBlueLevelSelector::RedBlueLevelSelector()
{
- set_size_request(-1,24);
+ set_size_request(-1,24);
signal_expose_event().connect(sigc::mem_fun(*this, &studio::RedBlueLevelSelector::redraw));
-
+
add_events(Gdk::BUTTON_PRESS_MASK | Gdk::BUTTON_RELEASE_MASK);
add_events(Gdk::BUTTON1_MOTION_MASK);
add_events(Gdk::BUTTON1_MOTION_MASK);
}
bool
-RedBlueLevelSelector::redraw(GdkEventExpose*bleh)
+RedBlueLevelSelector::redraw(GdkEventExpose */*bleh*/)
{
const int w(get_width()),h(get_height());
Glib::RefPtr<Gdk::GC> gc(Gdk::GC::create(get_window()));
int i;
-
+
// Draw the gradient
for(i=0;i<w;i++)
{
float blue_red(2.0f-(red_blue));
if(red_blue>1.0f)red_blue=1.0f;
if(blue_red>1.0f)blue_red=1.0f;
-
+
color.set_rgb(
round_to_int(min(red_blue,1.0f)*65535),
round_to_int(sqrt(min(red_blue,blue_red))*65535),
round_to_int(min(blue_red,1.0f)*65535)
);
-
+
gc->set_rgb_fg_color(color);
get_window()->draw_rectangle(gc, true, i, 0, 1, h);
}
-
+
// Draw a frame
gc->set_rgb_fg_color(Gdk::Color("#000000"));
get_window()->draw_rectangle(gc, false, 0, 0, w-1, h-1);
get_window()->draw_rectangle(gc, true, i, 1, 1, h-1);
// Print out the value
- Glib::RefPtr<Pango::Layout> layout(Pango::Layout::create(get_pango_context()));
+ Glib::RefPtr<Pango::Layout> layout(Pango::Layout::create(get_pango_context()));
layout->set_text(etl::strprintf("%0.02f",level));
layout->set_alignment(Pango::ALIGN_CENTER);
gc->set_rgb_fg_color(Gdk::Color("#a00000"));