+++ /dev/null
-/* === S Y N F I G ========================================================= */
-/*! \file canvasoptions.cpp
-** \brief Template File
-**
-** $Id$
-**
-** \legal
-** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
-**
-** 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.
-**
-** 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
-*/
-/* ========================================================================= */
-
-/* === H E A D E R S ======================================================= */
-
-#ifdef USING_PCH
-# include "pch.h"
-#else
-#ifdef HAVE_CONFIG_H
-# include <config.h>
-#endif
-
-#include "canvasoptions.h"
-#include <gtkmm/frame.h>
-#include <gtkmm/table.h>
-#include <gtkmm/label.h>
-#include <gtkmm/notebook.h>
-#include <gtkmm/alignment.h>
-#include "canvasview.h"
-#include "workarea.h"
-
-#include "general.h"
-
-#endif
-
-/* === U S I N G =========================================================== */
-
-using namespace std;
-using namespace etl;
-using namespace synfig;
-using namespace studio;
-
-/* === M A C R O S ========================================================= */
-
-/* === G L O B A L S ======================================================= */
-
-/* === P R O C E D U R E S ================================================= */
-
-/* === M E T H O D S ======================================================= */
-
-CanvasOptions::CanvasOptions(etl::loose_handle<CanvasView> canvas_view):
- Gtk::Dialog(_("Canvas Options"),*canvas_view,false,true),
- canvas_view_(canvas_view),
- toggle_grid_snap(_("_Snap to grid"), true),
- toggle_grid_show(_("S_how grid"), true),
- toggle_time_snap(_("Snap to _frame"), true)
-{
- vector_grid_size.set_canvas(canvas_view->get_canvas());
-
- Gtk::Alignment *dialogPadding = manage(new Gtk::Alignment(0, 0, 1, 1));
- dialogPadding->set_padding(12, 12, 12, 12);
-
- Gtk::Notebook *notebook=manage(new class Gtk::Notebook());
- dialogPadding->add(*notebook);
-
- toggle_grid_snap.signal_toggled().connect(sigc::mem_fun(*this, &studio::CanvasOptions::on_grid_snap_toggle));
- toggle_grid_show.signal_toggled().connect(sigc::mem_fun(*this, &studio::CanvasOptions::on_grid_show_toggle));
-
- Gtk::Alignment *gridPadding = manage(new Gtk::Alignment(0, 0, 1, 1));
- gridPadding->set_padding(12, 12, 12, 12);
- notebook->append_page(*gridPadding, _("Grid"));
-
- Gtk::VBox *gridBox = manage(new Gtk::VBox(false, 12));
- gridPadding->add(*gridBox);
-
- Gtk::Table *gridTable = manage(new Gtk::Table(3, 2, false));
- gridTable->set_row_spacings(6);
- gridTable->set_col_spacings(12);
- gridBox->pack_start(*gridTable, false, false, 0);
-
- Gtk::Label *gridSizeLabel = manage(new Gtk::Label(_("_Grid size"), true));
- gridSizeLabel->set_alignment(0, 0.5);
- gridSizeLabel->set_mnemonic_widget(vector_grid_size);
-
- toggle_grid_show.set_alignment(0, 0.5);
- toggle_grid_snap.set_alignment(0, 0.5);
-
- gridTable->attach(*gridSizeLabel, 0, 1, 0, 1, Gtk::SHRINK | Gtk::FILL, Gtk::EXPAND | Gtk::FILL, 0, 0);
- gridTable->attach(vector_grid_size, 1, 2, 0, 1, Gtk::EXPAND | Gtk::FILL, Gtk::EXPAND | Gtk::FILL, 0, 0);
- gridTable->attach(toggle_grid_show, 0, 2, 1, 2, Gtk::EXPAND | Gtk::FILL, Gtk::EXPAND | Gtk::FILL, 0, 0);
- gridTable->attach(toggle_grid_snap, 0, 2, 2, 3, Gtk::EXPAND | Gtk::FILL, Gtk::EXPAND | Gtk::FILL, 0, 0);
-
- Gtk::Alignment *timePadding = manage(new Gtk::Alignment(0, 0, 1, 1));
- timePadding->set_padding(12, 12, 12, 12);
- notebook->append_page(*timePadding, _("Time"));
-
- Gtk::VBox *timeBox = manage(new Gtk::VBox(false, 12));
- timePadding->add(*timeBox);
-
- timeBox->pack_start(toggle_time_snap, false, false, 0);
-
- Gtk::Alignment *unitPadding = manage(new Gtk::Alignment(0, 0, 1, 1));
- unitPadding->set_padding(12, 12, 12, 12);
- notebook->append_page(*unitPadding, _("Units"));
- unitPadding->add(*manage(new Gtk::Label(_("Not yet implemented!"))));
-
- Gtk::Button *ok_button(manage(new class Gtk::Button(Gtk::StockID("gtk-ok"))));
- ok_button->show();
- add_action_widget(*ok_button,2);
- ok_button->signal_clicked().connect(sigc::mem_fun(*this, &studio::CanvasOptions::on_ok_pressed));
-
- Gtk::Button *apply_button(manage(new class Gtk::Button(Gtk::StockID("gtk-apply"))));
- apply_button->show();
- add_action_widget(*apply_button,1);
- apply_button->signal_clicked().connect(sigc::mem_fun(*this, &studio::CanvasOptions::on_apply_pressed));
-
- Gtk::Button *cancel_button(manage(new class Gtk::Button(Gtk::StockID("gtk-close"))));
- cancel_button->show();
- add_action_widget(*cancel_button,0);
- cancel_button->signal_clicked().connect(sigc::mem_fun(*this, &studio::CanvasOptions::on_cancel_pressed));
-
- //set_default_response(1);
-
-
- get_vbox()->pack_start(*dialogPadding);
- get_vbox()->show_all();
-
- signal_show().connect(sigc::mem_fun(*this, &studio::CanvasOptions::refresh));
-
- vector_grid_size.set_digits(5);
-
- update_title();
-}
-
-CanvasOptions::~CanvasOptions()
-{
-}
-
-void
-CanvasOptions::update_title()
-{
- set_title(_("Options")+String(" - ")+canvas_view_->get_canvas()->get_name());
-}
-
-void
-CanvasOptions::refresh()
-{
- if(canvas_view_->work_area->grid_status())
- toggle_grid_show.set_active(true);
- else
- toggle_grid_show.set_active(false);
-
- if(canvas_view_->work_area->get_grid_snap())
- toggle_grid_snap.set_active(true);
- else
- toggle_grid_snap.set_active(false);
-
- vector_grid_size.set_value(canvas_view_->work_area->get_grid_size());
-
- tooltips.set_tip(toggle_time_snap,_("Not yet implemented"));
- toggle_time_snap.set_sensitive(false);
-
- update_title();
-}
-
-void
-CanvasOptions::on_grid_snap_toggle()
-{
-}
-
-void
-CanvasOptions::on_grid_show_toggle()
-{
-}
-
-void
-CanvasOptions::on_apply_pressed()
-{
- canvas_view_->set_grid_snap_toggle(toggle_grid_snap.get_active());
- if(toggle_grid_snap.get_active())
- canvas_view_->work_area->enable_grid_snap();
- else
- canvas_view_->work_area->disable_grid_snap();
-
- canvas_view_->set_grid_show_toggle(toggle_grid_show.get_active());
- if(toggle_grid_show.get_active())
- canvas_view_->work_area->enable_grid();
- else
- canvas_view_->work_area->disable_grid();
-
- canvas_view_->work_area->set_grid_size(vector_grid_size.get_value());
-}
-
-void
-CanvasOptions::on_ok_pressed()
-{
- on_apply_pressed();
- hide();
-}
-
-void
-CanvasOptions::on_cancel_pressed()
-{
- refresh();
- hide();
-}