|
Carlos Lopez |
a09598 |
/* === S Y N F I G ========================================================= */
|
|
Carlos Lopez |
a09598 |
/*! \file widget_defaults.cpp
|
|
Carlos Lopez |
a09598 |
** \brief Template File
|
|
Carlos Lopez |
a09598 |
**
|
|
Carlos Lopez |
a09598 |
** $Id$
|
|
Carlos Lopez |
a09598 |
**
|
|
Carlos Lopez |
a09598 |
** \legal
|
|
Carlos Lopez |
a09598 |
** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
|
|
Carlos Lopez |
a09598 |
** Copyright (c) 2008 Chris Moore
|
|
Carlos Lopez |
a63df6 |
** Copyright (c) 2008, 2011, 2012 Carlos Lรณpez
|
|
Carlos Lopez |
a09598 |
**
|
|
Carlos Lopez |
a09598 |
** This package is free software; you can redistribute it and/or
|
|
Carlos Lopez |
a09598 |
** modify it under the terms of the GNU General Public License as
|
|
Carlos Lopez |
a09598 |
** published by the Free Software Foundation; either version 2 of
|
|
Carlos Lopez |
a09598 |
** the License, or (at your option) any later version.
|
|
Carlos Lopez |
a09598 |
**
|
|
Carlos Lopez |
a09598 |
** This package is distributed in the hope that it will be useful,
|
|
Carlos Lopez |
a09598 |
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
Carlos Lopez |
a09598 |
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Carlos Lopez |
a09598 |
** General Public License for more details.
|
|
Carlos Lopez |
a09598 |
** \endlegal
|
|
Carlos Lopez |
a09598 |
*/
|
|
Carlos Lopez |
a09598 |
/* ========================================================================= */
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
/* === H E A D E R S ======================================================= */
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
#ifdef USING_PCH
|
|
Carlos Lopez |
a09598 |
# include "pch.h"
|
|
Carlos Lopez |
a09598 |
#else
|
|
Carlos Lopez |
a09598 |
#ifdef HAVE_CONFIG_H
|
|
Carlos Lopez |
a09598 |
# include <config.h></config.h>
|
|
Carlos Lopez |
a09598 |
#endif
|
|
Carlos Lopez |
a09598 |
|
|
bw |
94d8a6 |
#include <synfig general.h=""></synfig>
|
|
bw |
94d8a6 |
|
|
Nikita Kitaev |
3c2324 |
#include "widgets/widget_defaults.h"
|
|
Nikita Kitaev |
3c2324 |
#include "widgets/widget_color.h"
|
|
Nikita Kitaev |
3c2324 |
#include "widgets/widget_gradient.h"
|
|
Nikita Kitaev |
76ba27 |
#include "dialogs/dialog_color.h"
|
|
Nikita Kitaev |
76ba27 |
#include "dialogs/dialog_gradient.h"
|
|
Carlos Lopez |
a09598 |
#include "app.h"
|
|
Carlos Lopez |
a09598 |
#include <gtkmm menu.h=""></gtkmm>
|
|
Carlos Lopez |
a09598 |
#include <gtkmm scale.h=""></gtkmm>
|
|
|
def4c6 |
#include <gtkmm toolitem.h=""></gtkmm>
|
|
|
def4c6 |
#include <gtkmm toolitemgroup.h=""></gtkmm>
|
|
|
def4c6 |
#include <gtkmm toolpalette.h=""></gtkmm>
|
|
Carlos Lopez |
a09598 |
#include <synfig exception.h=""></synfig>
|
|
Carlos Lopez |
a09598 |
#include <synfigapp main.h=""></synfigapp>
|
|
Carlos Lopez |
a09598 |
#include "canvasview.h"
|
|
Nikita Kitaev |
3c2324 |
#include "widgets/widget_enum.h"
|
|
Carlos Lopez |
3794aa |
#include "widgets/widget_distance.h"
|
|
Carlos Lopez |
a09598 |
|
|
|
abdbf2 |
#include <gui localization.h=""></gui>
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
#endif
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
/* === U S I N G =========================================================== */
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
using namespace std;
|
|
Carlos Lopez |
a09598 |
using namespace etl;
|
|
Carlos Lopez |
a09598 |
using namespace synfig;
|
|
Carlos Lopez |
a09598 |
using namespace studio;
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
/* === M A C R O S ========================================================= */
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
#define DEFAULT_INCREMENT (0.25)
|
|
Carlos Lopez |
a09598 |
#define DEFAULT_WIDTH (synfig::Distance(3,synfig::Distance::SYSTEM_POINTS))
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
/* === G L O B A L S ======================================================= */
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
class studio::Widget_Brush : public Gtk::DrawingArea
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
public:
|
|
Carlos Lopez |
a09598 |
Widget_Brush()
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
add_events(Gdk::BUTTON_PRESS_MASK | Gdk::BUTTON_RELEASE_MASK);
|
|
Carlos Lopez |
a09598 |
add_events(Gdk::BUTTON1_MOTION_MASK);
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
synfigapp::Main::signal_outline_color_changed().connect(sigc::mem_fun(*this,&studio::Widget_Brush::queue_draw));
|
|
Carlos Lopez |
a09598 |
synfigapp::Main::signal_fill_color_changed().connect(sigc::mem_fun(*this,&studio::Widget_Brush::queue_draw));
|
|
Carlos Lopez |
a09598 |
synfigapp::Main::signal_bline_width_changed().connect(sigc::mem_fun(*this,&studio::Widget_Brush::queue_draw));
|
|
Carlos Lopez |
a09598 |
studio::App::signal_instance_selected().connect(sigc::hide(sigc::mem_fun(*this,&studio::Widget_Brush::queue_draw)));
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
bool
|
|
|
cf03b5 |
on_draw(const Cairo::RefPtr<cairo::context> &cr)</cairo::context>
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
const int h(get_height());
|
|
Carlos Lopez |
a09598 |
const int w(get_width());
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
float pixelsize(0);
|
|
Carlos Lopez |
a09598 |
if(App::get_selected_canvas_view())
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
const RendDesc& rend_desc(App::get_selected_canvas_view()->get_canvas()->rend_desc());
|
|
Carlos Lopez |
a09598 |
pixelsize=synfigapp::Main::get_bline_width().get(Distance::SYSTEM_PIXELS,rend_desc);
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
else
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
RendDesc rend_desc;
|
|
Carlos Lopez |
a09598 |
pixelsize=synfigapp::Main::get_bline_width().get(Distance::SYSTEM_PIXELS,rend_desc);
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
// Fill in the fill color
|
|
|
cf03b5 |
render_color_to_window(cr,Gdk::Rectangle(0,0,w,h),synfigapp::Main::get_fill_color());
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
// Draw in the circle
|
|
|
a4bbdd |
|
|
|
a4bbdd |
Color brush = App::get_selected_canvas_gamma().get_inverted().apply(
|
|
|
a4bbdd |
synfigapp::Main::get_outline_color() );
|
|
|
706048 |
cr->set_source_rgba(brush.get_r(), brush.get_g(), brush.get_b(), brush.get_a());
|
|
|
cf03b5 |
cr->arc(w/2.0, h/2.0, pixelsize, 0.0, 360*M_PI/180.0);
|
|
|
cf03b5 |
cr->fill();
|
|
Carlos Lopez |
a09598 |
return true;
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
bool
|
|
Carlos Lopez |
a09598 |
on_event(GdkEvent *event)
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
const int y(static_cast<int>(event->button.y));</int>
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
const int h(get_height());
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
switch(event->type)
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
case GDK_MOTION_NOTIFY:
|
|
Carlos Lopez |
a09598 |
break;
|
|
Carlos Lopez |
a09598 |
case GDK_BUTTON_RELEASE:
|
|
Carlos Lopez |
a09598 |
if(event->button.button==1) // Left click
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
Distance dist(synfigapp::Main::get_bline_width());
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
if(y
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
dist+=DEFAULT_INCREMENT;
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
else // Decrease BLine size
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
dist-=DEFAULT_INCREMENT;
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
synfigapp::Main::set_bline_width(dist);
|
|
Carlos Lopez |
a09598 |
return true;
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
if(event->button.button==3)
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
// right click on bline width
|
|
Carlos Lopez |
a09598 |
synfigapp::Main::set_bline_width(DEFAULT_WIDTH);
|
|
Carlos Lopez |
a09598 |
return true;
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
break;
|
|
Carlos Lopez |
a09598 |
case GDK_SCROLL:
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
Distance dist(synfigapp::Main::get_bline_width());
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
switch(event->scroll.direction){
|
|
Carlos Lopez |
a09598 |
case GDK_SCROLL_UP:
|
|
Carlos Lopez |
a09598 |
case GDK_SCROLL_RIGHT:
|
|
Carlos Lopez |
a09598 |
dist+=DEFAULT_INCREMENT;
|
|
|
300bf8 |
break;
|
|
Carlos Lopez |
a09598 |
case GDK_SCROLL_DOWN:
|
|
Carlos Lopez |
a09598 |
case GDK_SCROLL_LEFT:
|
|
Carlos Lopez |
a09598 |
dist-=DEFAULT_INCREMENT;
|
|
|
300bf8 |
break;
|
|
|
300bf8 |
default:
|
|
|
300bf8 |
break;
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
synfigapp::Main::set_bline_width(dist);
|
|
Carlos Lopez |
a09598 |
return true;
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
default:
|
|
Carlos Lopez |
a09598 |
break;
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
return false;
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
};
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
/* === P R O C E D U R E S ================================================= */
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
/* === M E T H O D S ======================================================= */
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
Widget_Defaults::Widget_Defaults()
|
|
Carlos Lopez |
a09598 |
{
|
|
Yu Chen |
17e3f0 |
Gtk::IconSize iconsize = Gtk::IconSize::from_name("synfig-tiny_icon");
|
|
Carlos Lopez |
a09598 |
|
|
Yu Chen |
278353 |
// widget colors: outline color and fill color.
|
|
Yu Chen |
278353 |
|
|
Yu Chen |
3904ae |
_widget_colors = manage(new Gtk::Table());
|
|
Carlos Lopez |
a09598 |
{
|
|
Yu Chen |
3904ae |
// widget outline color
|
|
Yu Chen |
3904ae |
_widget_otln_color = manage(new Widget_Color());
|
|
|
6330b7 |
_widget_otln_color->set_size_request(30, 26);
|
|
Yu Chen |
3904ae |
_widget_otln_color->signal_clicked().connect(sigc::mem_fun(*this,&Widget_Defaults::on_otln_color_clicked));
|
|
Yu Chen |
3904ae |
_widget_otln_color->set_tooltip_text(_("Outline Color"));
|
|
Yu Chen |
3904ae |
|
|
Yu Chen |
3904ae |
// fixed outline color widget size
|
|
|
8fbd17 |
Gtk::Alignment *widget_otln_color(manage(new Gtk::Alignment(Gtk::ALIGN_END, Gtk::ALIGN_END, 0.0, 0.0)));
|
|
Yu Chen |
3904ae |
widget_otln_color->add(*_widget_otln_color);
|
|
Yu Chen |
3904ae |
|
|
Yu Chen |
3904ae |
|
|
Yu Chen |
3904ae |
// widget fill color
|
|
Yu Chen |
3904ae |
_widget_fill_color = manage(new Widget_Color());
|
|
|
6330b7 |
_widget_fill_color->set_size_request(30, 26);
|
|
Yu Chen |
3904ae |
_widget_fill_color->signal_clicked().connect(sigc::mem_fun(*this,&Widget_Defaults::on_fill_color_clicked));
|
|
Yu Chen |
3904ae |
_widget_fill_color->set_tooltip_text(_("Fill Color"));
|
|
Yu Chen |
3904ae |
|
|
Yu Chen |
3904ae |
// fixed fill color wiget size
|
|
|
8fbd17 |
widget_fill_color = manage(new Gtk::Alignment(Gtk::ALIGN_END, Gtk::ALIGN_END, 0.0, 0.0));
|
|
Yu Chen |
3904ae |
widget_fill_color->add(*_widget_fill_color);
|
|
Yu Chen |
3904ae |
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
Gtk::Image* icon;
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
// Swap button
|
|
Yu Chen |
17e3f0 |
Gtk::Button* _button_swap(manage(new Gtk::Button()));
|
|
Yu Chen |
17e3f0 |
_button_swap->set_relief(Gtk::RELIEF_NONE);
|
|
Yu Chen |
17e3f0 |
_button_swap->set_border_width(0);
|
|
Yu Chen |
3904ae |
icon = manage(new Gtk::Image(Gtk::StockID("synfig-swap_colors"), iconsize));
|
|
Yu Chen |
17e3f0 |
_button_swap->add(*icon);
|
|
Yu Chen |
17e3f0 |
dynamic_cast<gtk::misc*>(_button_swap->get_child())->set_padding(0, 0);</gtk::misc*>
|
|
Yu Chen |
17e3f0 |
_button_swap->signal_clicked().connect(sigc::mem_fun(*this,&Widget_Defaults::on_swap_color_clicked));
|
|
Yu Chen |
17e3f0 |
_button_swap->set_tooltip_text(_("Swap Fill and\nOutline Colors"));
|
|
Yu Chen |
17e3f0 |
|
|
Yu Chen |
17e3f0 |
Gtk::Alignment *button_swap(manage(new Gtk::Alignment(Gtk::ALIGN_CENTER, Gtk::ALIGN_CENTER, 0, 0)));
|
|
Yu Chen |
17e3f0 |
button_swap->add(*_button_swap);
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
// Reset button
|
|
Yu Chen |
17e3f0 |
Gtk::Button* _button_reset(manage(new Gtk::Button()));
|
|
Yu Chen |
17e3f0 |
_button_reset->set_relief(Gtk::RELIEF_NONE);
|
|
Yu Chen |
17e3f0 |
_button_reset->set_border_width(0);
|
|
Yu Chen |
3904ae |
icon = manage(new Gtk::Image(Gtk::StockID("synfig-reset_colors"), iconsize));
|
|
Yu Chen |
17e3f0 |
_button_reset->add(*icon);
|
|
Yu Chen |
17e3f0 |
dynamic_cast<gtk::misc*>(_button_reset->get_child())->set_padding(0, 0);</gtk::misc*>
|
|
Yu Chen |
17e3f0 |
_button_reset->signal_clicked().connect(sigc::mem_fun(*this,&Widget_Defaults::on_reset_color_clicked));
|
|
Yu Chen |
17e3f0 |
_button_reset->set_tooltip_text(_("Reset Colors to Black and White"));
|
|
Carlos Lopez |
a09598 |
|
|
Yu Chen |
17e3f0 |
Gtk::Alignment *button_reset (manage (new Gtk::Alignment(Gtk::ALIGN_CENTER, Gtk::ALIGN_CENTER, 0 ,0)));
|
|
Yu Chen |
17e3f0 |
button_reset->add(*_button_reset);
|
|
Yu Chen |
abaaae |
|
|
Yu Chen |
3904ae |
// ship child widgets together
|
|
Yu Chen |
17e3f0 |
_widget_colors->attach(*widget_otln_color, 0, 8, 0, 7, Gtk::FILL, Gtk::FILL|Gtk::SHRINK, 0, 0);
|
|
Yu Chen |
17e3f0 |
_widget_colors->attach(*widget_fill_color, 3, 11, 3, 10, Gtk::FILL, Gtk::FILL|Gtk::SHRINK, 0, 0);
|
|
Yu Chen |
17e3f0 |
_widget_colors->attach(*button_swap, 9, 10, 0, 1, Gtk::FILL, Gtk::FILL|Gtk::SHRINK, 0, 0);
|
|
Yu Chen |
17e3f0 |
_widget_colors->attach(*button_reset, 0, 1, 9, 10, Gtk::FILL, Gtk::FILL|Gtk::SHRINK, 0, 0);
|
|
Yu Chen |
3904ae |
|
|
Yu Chen |
3904ae |
// fixed colors widget size
|
|
Yu Chen |
3904ae |
widget_colors = manage(new Gtk::Alignment(Gtk::ALIGN_CENTER, Gtk::ALIGN_CENTER, 0.0, 0.0));
|
|
Yu Chen |
3904ae |
widget_colors->add(*_widget_colors);
|
|
Carlos Lopez |
a09598 |
}
|
|
Yu Chen |
020306 |
|
|
Yu Chen |
abaaae |
// widget brush
|
|
Yu Chen |
3904ae |
_widget_brush = manage(new Widget_Brush());
|
|
|
96159f |
_widget_brush->set_size_request(56, 48);
|
|
Yu Chen |
3904ae |
_widget_brush->set_tooltip_text(_("Brush Preview"));
|
|
[d.j.a.y] Jerome Blanchi |
128b0d |
|
|
|
6330b7 |
brush_increase = Gtk::manage(new class Gtk::Button("+"));
|
|
|
92e71e |
brush_increase->set_tooltip_text(_("Increase brush size"));
|
|
|
6330b7 |
brush_increase->set_relief(Gtk::RELIEF_NONE);
|
|
|
6330b7 |
brush_increase->set_border_width(0);
|
|
|
6330b7 |
brush_increase->signal_clicked().connect(sigc::mem_fun(*this,&studio::Widget_Defaults::on_brush_increase_clicked));
|
|
[d.j.a.y] Jerome Blanchi |
128b0d |
|
|
|
6330b7 |
brush_decrease = Gtk::manage(new class Gtk::Button("-"));
|
|
|
92e71e |
brush_decrease->set_tooltip_text(_("Decrease brush size"));
|
|
|
6330b7 |
brush_decrease->set_relief(Gtk::RELIEF_NONE);
|
|
|
6330b7 |
brush_decrease->set_border_width(0);
|
|
|
6330b7 |
brush_decrease->signal_clicked().connect(sigc::mem_fun(*this,&studio::Widget_Defaults::on_brush_decrease_clicked));
|
|
[d.j.a.y] Jerome Blanchi |
128b0d |
|
|
|
6330b7 |
brush_entry = Gtk::manage(new class Gtk::Entry());
|
|
|
6330b7 |
brush_entry->set_width_chars(4);
|
|
|
6330b7 |
brush_entry->set_has_frame(false);
|
|
|
6330b7 |
brush_entry->signal_changed().connect(sigc::mem_fun(*this,&studio::Widget_Defaults::on_brush_entry_changed));
|
|
|
6330b7 |
brush_entry->set_tooltip_text(_("Brush Size"));
|
|
[d.j.a.y] Jerome Blanchi |
128b0d |
|
|
|
6330b7 |
Gtk::Table* brush_layout = Gtk::manage(new class Gtk::Table(2, 3, false));
|
|
|
96159f |
brush_layout->attach(*_widget_brush, 0, 2, 0, 1, Gtk::SHRINK|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
|
|
|
96159f |
brush_layout->attach(*brush_decrease, 0, 1, 1, 2, Gtk::SHRINK|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
|
|
|
96159f |
brush_layout->attach(*brush_increase, 1, 2, 1, 2, Gtk::SHRINK|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 0);
|
|
|
6330b7 |
brush_layout->attach(*brush_entry, 0, 2, 2, 3, Gtk::EXPAND|Gtk::FILL, Gtk::SHRINK|Gtk::FILL, 0, 2);
|
|
|
6330b7 |
brush_layout->show_all();
|
|
Yu Chen |
3904ae |
|
|
Yu Chen |
3904ae |
// fixed brush widget size
|
|
|
452a21 |
widget_brush = manage(new Gtk::Alignment(Gtk::ALIGN_CENTER, Gtk::ALIGN_CENTER, 0.0, 0.0));
|
|
|
6330b7 |
widget_brush->add(*brush_layout);
|
|
Yu Chen |
3904ae |
|
|
Carlos Lopez |
a09598 |
|
|
Yu Chen |
abaaae |
// widget bline width
|
|
Yu Chen |
3904ae |
widget_bline_width = manage(new Widget_Distance());
|
|
Rodolfo Ribeiro Gomes |
9fa13d |
widget_bline_width->set_parent(*this);
|
|
Carlos Lopez |
a09598 |
bline_width_refresh();
|
|
Carlos Lopez |
a09598 |
widget_bline_width->set_digits(2);
|
|
Carlos Lopez |
a09598 |
widget_bline_width->set_range(0,10000000);
|
|
|
452a21 |
widget_bline_width->set_width_chars(4);
|
|
|
452a21 |
//widget_bline_width->set_size_request(48, -1); //mini width of bline width widget, this value also affects mini width of whole default_widgets.
|
|
Carlos Lopez |
a09598 |
widget_bline_width->signal_value_changed().connect(sigc::mem_fun(*this,&studio::Widget_Defaults::on_bline_width_changed));
|
|
Carlos Lopez |
8e6980 |
widget_bline_width->set_tooltip_text(_("Brush Size"));
|
|
Carlos Lopez |
a09598 |
|
|
Yu Chen |
3904ae |
|
|
Yu Chen |
abaaae |
// widget blend method
|
|
Yu Chen |
278353 |
|
|
Yu Chen |
278353 |
/*
|
|
|
bff965 |
* NOTE1: the blend method widget affects the width of whole default_widgets widget,
|
|
Yu Chen |
278353 |
* since it requires mini width by it lengest item, "By Layer Default". If it
|
|
Yu Chen |
278353 |
* was removed from toolbox as planned, then toolbutton in toolbox will have
|
|
Yu Chen |
278353 |
* proper column spacing by default. I will let it as it is, because the toolbox
|
|
Yu Chen |
278353 |
* still need more love.
|
|
[d.j.a.y] Jerome Blanchi |
128b0d |
*
|
|
|
bff965 |
* NOTE2: Commented out as of 2014-06-24 -- KD.
|
|
Yu Chen |
278353 |
*/
|
|
Yu Chen |
278353 |
|
|
|
bff965 |
//widget_blend_method = manage(new Widget_Enum());
|
|
|
bff965 |
//widget_blend_method->signal_changed().connect(sigc::mem_fun(*this,&studio::Widget_Defaults::on_blend_method_changed));
|
|
|
bff965 |
//widget_blend_method->set_param_desc(
|
|
|
bff965 |
// ParamDesc((int)Color::BLEND_COMPOSITE,"blend_method")
|
|
|
bff965 |
// .add_enum_value(Color::BLEND_BY_LAYER,"bylayer", _("By Layer Default"))
|
|
|
bff965 |
//);
|
|
|
bff965 |
//widget_blend_method->set_tooltip_text(_("Default Blend Method"));
|
|
Carlos Lopez |
a09598 |
|
|
Yu Chen |
abaaae |
// widget opacity
|
|
|
d435fa |
//widget_opacity = manage(new Gtk::HScale(0.0f,1.01f,0.01f));
|
|
|
d435fa |
//widget_opacity->set_digits(2);
|
|
|
d435fa |
//widget_opacity->set_value_pos(Gtk::POS_LEFT);
|
|
|
d435fa |
//widget_opacity->signal_value_changed().connect(sigc::mem_fun(*this,&studio::Widget_Defaults::on_opacity_changed));
|
|
|
d435fa |
//widget_opacity->set_tooltip_text(_("Default Opacity"));
|
|
|
d435fa |
//widget_opacity->set_value_pos(Gtk::POS_LEFT);
|
|
Carlos Lopez |
a09598 |
|
|
Yu Chen |
abaaae |
// widget gradient
|
|
Yu Chen |
3904ae |
_widget_gradient = manage(new Widget_Gradient());
|
|
Yu Chen |
3904ae |
_widget_gradient->signal_clicked().connect(sigc::mem_fun(*this,&studio::Widget_Defaults::on_gradient_clicked));
|
|
|
6330b7 |
_widget_gradient->set_size_request(56, 24);
|
|
Yu Chen |
3904ae |
_widget_gradient->set_tooltip_text(_("Default Gradient"));
|
|
Yu Chen |
3904ae |
|
|
Yu Chen |
3904ae |
// fixed gradient widget size
|
|
Yu Chen |
3904ae |
widget_gradient = manage(new Gtk::Alignment(Gtk::ALIGN_CENTER, Gtk::ALIGN_CENTER, 0.0, 0.0));
|
|
Yu Chen |
3904ae |
widget_gradient->add(*_widget_gradient);
|
|
Yu Chen |
3904ae |
|
|
Yu Chen |
3904ae |
|
|
Yu Chen |
3904ae |
// pack all widgets
|
|
Yu Chen |
3904ae |
{
|
|
Yu Chen |
3904ae |
// pack colors and gradient widgets
|
|
Yu Chen |
3904ae |
{
|
|
|
452a21 |
widget_colors_gradient = manage(new Gtk::VBox(false, 0));
|
|
Yu Chen |
3904ae |
widget_colors_gradient->pack_start(*widget_colors);
|
|
Yu Chen |
3904ae |
widget_colors_gradient->pack_start(*widget_gradient);
|
|
Yu Chen |
3904ae |
}
|
|
Yu Chen |
3904ae |
|
|
|
def4c6 |
//pack_start(*widget_colors_gradient, Gtk::PACK_EXPAND_PADDING, 4);
|
|
|
bff965 |
//pack_start(*widget_blend_method, Gtk::PACK_EXPAND_PADDING, 4);
|
|
|
d435fa |
//pack_start(*widget_opacity, Gtk::PACK_EXPAND_PADDING, 4);
|
|
|
def4c6 |
//pack_start(*widget_brush, Gtk::PACK_EXPAND_PADDING, 6);
|
|
Yu Chen |
abaaae |
|
|
Yu Chen |
0461f9 |
// show all widgets
|
|
Yu Chen |
3904ae |
widget_colors_gradient->show_all();
|
|
|
bff965 |
//widget_blend_method->show();
|
|
|
d435fa |
//widget_opacity->show();
|
|
|
def4c6 |
//widget_brush_bline_width->show_all();
|
|
[d.j.a.y] Jerome Blanchi |
128b0d |
|
|
|
def4c6 |
Gtk::ToolItemGroup *tool_item_group = manage(new class Gtk::ToolItemGroup());
|
|
|
def4c6 |
gtk_tool_item_group_set_label(tool_item_group->gobj(), NULL);
|
|
|
def4c6 |
|
|
|
def4c6 |
Gtk::ToolPalette *palette = manage(new Gtk::ToolPalette());
|
|
|
def4c6 |
palette->add(*tool_item_group);
|
|
|
def4c6 |
palette->set_expand(*tool_item_group);
|
|
|
def4c6 |
palette->set_exclusive(*tool_item_group, true);
|
|
|
def4c6 |
palette->set_icon_size(Gtk::IconSize::from_name("synfig-small_icon_16x16"));
|
|
|
def4c6 |
palette->set_size_request(100,100);
|
|
|
def4c6 |
palette->show();
|
|
[d.j.a.y] Jerome Blanchi |
128b0d |
|
|
|
def4c6 |
Gtk::ToolItem *tool_item1 = manage(new class Gtk::ToolItem());
|
|
|
def4c6 |
tool_item1->add(*widget_colors_gradient);
|
|
|
def4c6 |
tool_item_group->insert(*tool_item1);
|
|
|
def4c6 |
tool_item1->show();
|
|
|
def4c6 |
Gtk::ToolItem *tool_item2 = manage(new class Gtk::ToolItem());
|
|
|
def4c6 |
tool_item2->add(*widget_brush);
|
|
|
def4c6 |
tool_item_group->insert(*tool_item2);
|
|
|
def4c6 |
tool_item2->show();
|
|
[d.j.a.y] Jerome Blanchi |
128b0d |
|
|
|
def4c6 |
tool_item_group->show_all();
|
|
[d.j.a.y] Jerome Blanchi |
128b0d |
|
|
|
def4c6 |
//Gtk::ScrolledWindow *scrolled_window = manage(new Gtk::ScrolledWindow());
|
|
|
def4c6 |
//scrolled_window->add(*palette);
|
|
|
def4c6 |
//scrolled_window->show();
|
|
[d.j.a.y] Jerome Blanchi |
128b0d |
|
|
|
def4c6 |
//pack_start(*scrolled_window, Gtk::PACK_EXPAND_PADDING, 4);
|
|
|
def4c6 |
pack_start(*palette, Gtk::PACK_EXPAND_WIDGET|Gtk::PACK_SHRINK, 4);
|
|
[d.j.a.y] Jerome Blanchi |
128b0d |
|
|
Yu Chen |
3904ae |
}
|
|
Yu Chen |
3904ae |
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
// Signals
|
|
|
d435fa |
//synfigapp::Main::signal_opacity_changed().connect(sigc::mem_fun(*this,&studio::Widget_Defaults::opacity_refresh));
|
|
Carlos Lopez |
a09598 |
synfigapp::Main::signal_bline_width_changed().connect(sigc::mem_fun(*this,&studio::Widget_Defaults::bline_width_refresh));
|
|
Carlos Lopez |
a09598 |
synfigapp::Main::signal_outline_color_changed().connect(sigc::mem_fun(*this,&studio::Widget_Defaults::otln_color_refresh));
|
|
Carlos Lopez |
a09598 |
synfigapp::Main::signal_fill_color_changed().connect(sigc::mem_fun(*this,&studio::Widget_Defaults::fill_color_refresh));
|
|
Carlos Lopez |
a09598 |
synfigapp::Main::signal_gradient_changed().connect(sigc::mem_fun(*this,&studio::Widget_Defaults::gradient_refresh));
|
|
|
bff965 |
//synfigapp::Main::signal_blend_method_changed().connect(sigc::mem_fun(*this,&studio::Widget_Defaults::blend_method_refresh));
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
otln_color_refresh();
|
|
Carlos Lopez |
a09598 |
fill_color_refresh();
|
|
Carlos Lopez |
a09598 |
gradient_refresh();
|
|
|
bff965 |
//blend_method_refresh();
|
|
|
d435fa |
//opacity_refresh();
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
Widget_Defaults::~Widget_Defaults()
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
void
|
|
Carlos Lopez |
a09598 |
Widget_Defaults::otln_color_refresh()
|
|
Carlos Lopez |
a09598 |
{
|
|
Yu Chen |
3904ae |
_widget_otln_color->set_value(synfigapp::Main::get_outline_color());
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
void
|
|
Carlos Lopez |
a09598 |
Widget_Defaults::fill_color_refresh()
|
|
Carlos Lopez |
a09598 |
{
|
|
Yu Chen |
3904ae |
_widget_fill_color->set_value(synfigapp::Main::get_fill_color());
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
void
|
|
Carlos Lopez |
a09598 |
Widget_Defaults::gradient_refresh()
|
|
Carlos Lopez |
a09598 |
{
|
|
Yu Chen |
3904ae |
_widget_gradient->set_value(synfigapp::Main::get_gradient());
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
void
|
|
Carlos Lopez |
a09598 |
Widget_Defaults::bline_width_refresh()
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
widget_bline_width->set_value(synfigapp::Main::get_bline_width());
|
|
|
6330b7 |
brush_entry->set_text(widget_bline_width->get_value().get_string(widget_bline_width->get_digits()));
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
|
|
|
bff965 |
/*
|
|
Carlos Lopez |
a09598 |
void
|
|
Carlos Lopez |
a09598 |
Widget_Defaults::blend_method_refresh()
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
widget_blend_method->set_value(synfigapp::Main::get_blend_method());
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
void
|
|
Carlos Lopez |
a09598 |
Widget_Defaults::opacity_refresh()
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
widget_opacity->set_value(synfigapp::Main::get_opacity());
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
void
|
|
Carlos Lopez |
a09598 |
Widget_Defaults::on_opacity_changed()
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
synfigapp::Main::set_opacity(widget_opacity->get_value());
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
void
|
|
Carlos Lopez |
a09598 |
Widget_Defaults::on_blend_method_changed()
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
synfigapp::Main::set_blend_method(Color::BlendMethod(widget_blend_method->get_value()));
|
|
Carlos Lopez |
a09598 |
}
|
|
|
bff965 |
*/
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
void
|
|
Carlos Lopez |
a09598 |
Widget_Defaults::on_bline_width_changed()
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
synfigapp::Main::set_bline_width(widget_bline_width->get_value());
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
void
|
|
|
6330b7 |
Widget_Defaults::on_brush_entry_changed()
|
|
|
6330b7 |
{
|
|
|
6330b7 |
synfig::Distance distance(synfigapp::Main::get_bline_width());
|
|
|
6330b7 |
distance = synfig::String(brush_entry->get_text());
|
|
|
6330b7 |
synfigapp::Main::set_bline_width(distance);
|
|
|
6330b7 |
}
|
|
|
6330b7 |
|
|
|
6330b7 |
void
|
|
|
6330b7 |
Widget_Defaults::on_brush_increase_clicked()
|
|
|
6330b7 |
{
|
|
|
6330b7 |
synfig::Distance distance(synfigapp::Main::get_bline_width());
|
|
|
6330b7 |
distance+=1;
|
|
|
6330b7 |
synfigapp::Main::set_bline_width(distance);
|
|
|
6330b7 |
}
|
|
|
6330b7 |
|
|
|
6330b7 |
void
|
|
|
6330b7 |
Widget_Defaults::on_brush_decrease_clicked()
|
|
|
6330b7 |
{
|
|
|
6330b7 |
synfig::Distance distance(synfigapp::Main::get_bline_width());
|
|
|
6330b7 |
distance-=1;
|
|
|
6330b7 |
synfigapp::Main::set_bline_width(distance);
|
|
|
6330b7 |
}
|
|
|
6330b7 |
|
|
|
6330b7 |
void
|
|
Carlos Lopez |
a09598 |
Widget_Defaults::on_otln_color_clicked()
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
// Left click on outline color
|
|
Carlos Lopez |
a09598 |
App::dialog_color->reset();
|
|
[d.j.a.y] Jerome Blanchi |
128b0d |
App::dialog_color->set_color(synfigapp::Main::get_outline_color());
|
|
Carlos Lopez |
a09598 |
App::dialog_color->signal_edited().connect(sigc::ptr_fun(synfigapp::Main::set_outline_color));
|
|
Carlos Lopez |
a09598 |
App::dialog_color->present();
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
void
|
|
Carlos Lopez |
a09598 |
Widget_Defaults::on_fill_color_clicked()
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
// Left click on fill color
|
|
Carlos Lopez |
a09598 |
App::dialog_color->reset();
|
|
[d.j.a.y] Jerome Blanchi |
128b0d |
App::dialog_color->set_color(synfigapp::Main::get_fill_color());
|
|
Carlos Lopez |
a09598 |
App::dialog_color->signal_edited().connect(sigc::ptr_fun(synfigapp::Main::set_fill_color));
|
|
Carlos Lopez |
a09598 |
App::dialog_color->present();
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
void
|
|
Carlos Lopez |
a09598 |
Widget_Defaults::on_swap_color_clicked()
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
synfigapp::Main::color_swap();
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
void
|
|
Carlos Lopez |
a09598 |
Widget_Defaults::on_reset_color_clicked()
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
synfigapp::Main::set_fill_color(Color::white());
|
|
Carlos Lopez |
a09598 |
synfigapp::Main::set_outline_color(Color::black());
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
|
|
Carlos Lopez |
a09598 |
void
|
|
Carlos Lopez |
a09598 |
Widget_Defaults::on_gradient_clicked()
|
|
Carlos Lopez |
a09598 |
{
|
|
Carlos Lopez |
a09598 |
App::dialog_gradient->set_gradient(synfigapp::Main::get_gradient());
|
|
Carlos Lopez |
a09598 |
App::dialog_gradient->reset();
|
|
Carlos Lopez |
a09598 |
App::dialog_gradient->signal_edited().connect(sigc::ptr_fun(synfigapp::Main::set_gradient));
|
|
Nikita Kitaev |
6ac9d5 |
App::dialog_gradient->set_default_button_set_sensitive(false);
|
|
Carlos Lopez |
a09598 |
App::dialog_gradient->present();
|
|
Carlos Lopez |
a09598 |
}
|
|
Carlos Lopez |
a09598 |
|