Add actions (add to group, ,remove from group, export, un-export, set layer descripti...
[synfig.git] / synfig-studio / src / gtkmm / widget_enum.cpp
1 /* === S Y N F I G ========================================================= */
2 /*!     \file widget_enum.cpp
3 **      \brief Template File
4 **
5 **      $Id$
6 **
7 **      \legal
8 **      Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley
9 **
10 **      This package is free software; you can redistribute it and/or
11 **      modify it under the terms of the GNU General Public License as
12 **      published by the Free Software Foundation; either version 2 of
13 **      the License, or (at your option) any later version.
14 **
15 **      This package is distributed in the hope that it will be useful,
16 **      but WITHOUT ANY WARRANTY; without even the implied warranty of
17 **      MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18 **      General Public License for more details.
19 **      \endlegal
20 */
21 /* ========================================================================= */
22
23 /* === H E A D E R S ======================================================= */
24
25 #ifdef USING_PCH
26 #       include "pch.h"
27 #else
28 #ifdef HAVE_CONFIG_H
29 #       include <config.h>
30 #endif
31
32 #include <gtkmm/menu.h>
33 #include "widget_enum.h"
34 #include <ETL/stringf>
35 #include <synfig/valuenode.h>
36
37 #include "general.h"
38
39 #endif
40
41 /* === U S I N G =========================================================== */
42
43 using namespace std;
44 using namespace etl;
45 using namespace synfig;
46 using namespace studio;
47
48 /* === M A C R O S ========================================================= */
49
50 /* === G L O B A L S ======================================================= */
51
52 /* === P R O C E D U R E S ================================================= */
53
54 /* === M E T H O D S ======================================================= */
55
56 Widget_Enum::Widget_Enum()
57 {
58 }
59
60 Widget_Enum::~Widget_Enum()
61 {
62 }
63
64 void
65 Widget_Enum::set_param_desc(const synfig::ParamDesc &x)
66 {
67         param_desc=x;
68         //refresh();
69 }
70
71 void
72 Widget_Enum::set_value_(int data)
73 {
74         set_value(data);
75         activate();
76 }
77
78 void
79 Widget_Enum::refresh()
80 {
81         enum_menu = manage(new class Gtk::Menu());
82
83         std::list<synfig::ParamDesc::EnumData> enum_list=param_desc.get_enum_list();
84         std::list<synfig::ParamDesc::EnumData>::iterator iter;
85
86         String name=strprintf("(%d)",value);
87
88         for(iter=enum_list.begin();iter!=enum_list.end();iter++)
89                 if(iter->value!=value)
90                         enum_menu->items().push_back(Gtk::Menu_Helpers::MenuElem(iter->local_name,
91                                 sigc::bind(sigc::mem_fun(*this,&Widget_Enum::set_value_),iter->value)
92                         ));
93                 else
94                         name=iter->local_name;
95
96         enum_menu->items().push_front(Gtk::Menu_Helpers::MenuElem(name));
97
98         set_menu(*enum_menu);
99 }
100
101 void
102 Widget_Enum::set_value(int data)
103 {
104         value=data;
105
106         refresh();
107
108         set_history(0);
109 }
110
111 int
112 Widget_Enum::get_value() const
113 {
114         return value;
115 }