summaryrefslogtreecommitdiffstats
path: root/src/widgets/tweak-toolbar.cpp
diff options
context:
space:
mode:
authorTavmjong Bah <tavmjong@free.fr>2018-01-31 15:35:06 +0000
committerTavmjong Bah <tavmjong@free.fr>2018-01-31 15:35:06 +0000
commitfb98487a4e39627824ab6e5e3501eb072ad1b4f4 (patch)
tree89abc61bad7bd1ad99a9c3907f8d918d8392dcf2 /src/widgets/tweak-toolbar.cpp
parentConvert bucket toolbar to use ink-select-one-action. (diff)
downloadinkscape-fb98487a4e39627824ab6e5e3501eb072ad1b4f4.tar.gz
inkscape-fb98487a4e39627824ab6e5e3501eb072ad1b4f4.zip
Convert tweak tool to use ink-select-one-action.
Diffstat (limited to 'src/widgets/tweak-toolbar.cpp')
-rw-r--r--src/widgets/tweak-toolbar.cpp238
1 files changed, 116 insertions, 122 deletions
diff --git a/src/widgets/tweak-toolbar.cpp b/src/widgets/tweak-toolbar.cpp
index 6a2847c68..173e99479 100644
--- a/src/widgets/tweak-toolbar.cpp
+++ b/src/widgets/tweak-toolbar.cpp
@@ -28,19 +28,23 @@
#include "config.h"
#endif
-#include "ui/widget/spinbutton.h"
#include <glibmm/i18n.h>
+
#include "tweak-toolbar.h"
+
#include "desktop.h"
#include "document-undo.h"
-#include "widgets/ege-adjustment-action.h"
-#include "widgets/ege-output-action.h"
-#include "widgets/ege-select-one-action.h"
-#include "ink-radio-action.h"
-#include "ink-toggle-action.h"
-#include "toolbox.h"
+
#include "ui/icon-names.h"
#include "ui/tools/tweak-tool.h"
+#include "ui/widget/ink-select-one-action.h"
+#include "ui/widget/spinbutton.h"
+
+#include "widgets/ege-adjustment-action.h"
+#include "widgets/ege-output-action.h"
+#include "widgets/ink-radio-action.h"
+#include "widgets/ink-toggle-action.h"
+#include "widgets/toolbox.h"
using Inkscape::DocumentUndo;
using Inkscape::UI::ToolboxFactory;
@@ -71,14 +75,14 @@ static void sp_tweak_pressure_state_changed( GtkToggleAction *act, gpointer /*da
prefs->setBool("/tools/tweak/usepressure", gtk_toggle_action_get_active(act));
}
-static void sp_tweak_mode_changed( EgeSelectOneAction *act, GObject *tbl )
+static void sp_tweak_mode_changed( GObject *tbl, int mode )
{
- int mode = ege_select_one_action_get_active( act );
Inkscape::Preferences *prefs = Inkscape::Preferences::get();
prefs->setInt("/tools/tweak/mode", mode);
static gchar const* names[] = {"tweak_doh", "tweak_dos", "tweak_dol", "tweak_doo", "tweak_channels_label"};
- bool flag = ((mode == Inkscape::UI::Tools::TWEAK_MODE_COLORPAINT) || (mode == Inkscape::UI::Tools::TWEAK_MODE_COLORJITTER));
+ bool flag = ((mode == Inkscape::UI::Tools::TWEAK_MODE_COLORPAINT) ||
+ (mode == Inkscape::UI::Tools::TWEAK_MODE_COLORJITTER));
for (size_t i = 0; i < G_N_ELEMENTS(names); ++i) {
GtkAction *act = GTK_ACTION(g_object_get_data( tbl, names[i] ));
if (act) {
@@ -155,118 +159,108 @@ void sp_tweak_toolbox_prep(SPDesktop *desktop, GtkActionGroup* mainActions, GObj
/* Mode */
{
- GtkListStore* model = gtk_list_store_new( 3, G_TYPE_STRING, G_TYPE_STRING, G_TYPE_STRING );
-
- GtkTreeIter iter;
- gtk_list_store_append( model, &iter );
- gtk_list_store_set( model, &iter,
- 0, _("Move mode"),
- 1, _("Move objects in any direction"),
- 2, INKSCAPE_ICON("object-tweak-push"),
- -1 );
-
- gtk_list_store_append( model, &iter );
- gtk_list_store_set( model, &iter,
- 0, _("Move in/out mode"),
- 1, _("Move objects towards cursor; with Shift from cursor"),
- 2, INKSCAPE_ICON("object-tweak-attract"),
- -1 );
-
- gtk_list_store_append( model, &iter );
- gtk_list_store_set( model, &iter,
- 0, _("Move jitter mode"),
- 1, _("Move objects in random directions"),
- 2, INKSCAPE_ICON("object-tweak-randomize"),
- -1 );
-
- gtk_list_store_append( model, &iter );
- gtk_list_store_set( model, &iter,
- 0, _("Scale mode"),
- 1, _("Shrink objects, with Shift enlarge"),
- 2, INKSCAPE_ICON("object-tweak-shrink"),
- -1 );
-
- gtk_list_store_append( model, &iter );
- gtk_list_store_set( model, &iter,
- 0, _("Rotate mode"),
- 1, _("Rotate objects, with Shift counterclockwise"),
- 2, INKSCAPE_ICON("object-tweak-rotate"),
- -1 );
-
- gtk_list_store_append( model, &iter );
- gtk_list_store_set( model, &iter,
- 0, _("Duplicate/delete mode"),
- 1, _("Duplicate objects, with Shift delete"),
- 2, INKSCAPE_ICON("object-tweak-duplicate"),
- -1 );
-
- gtk_list_store_append( model, &iter );
- gtk_list_store_set( model, &iter,
- 0, _("Push mode"),
- 1, _("Push parts of paths in any direction"),
- 2, INKSCAPE_ICON("path-tweak-push"),
- -1 );
-
- gtk_list_store_append( model, &iter );
- gtk_list_store_set( model, &iter,
- 0, _("Shrink/grow mode"),
- 1, _("Shrink (inset) parts of paths; with Shift grow (outset)"),
- 2, INKSCAPE_ICON("path-tweak-shrink"),
- -1 );
-
- gtk_list_store_append( model, &iter );
- gtk_list_store_set( model, &iter,
- 0, _("Attract/repel mode"),
- 1, _("Attract parts of paths towards cursor; with Shift from cursor"),
- 2, INKSCAPE_ICON("path-tweak-attract"),
- -1 );
-
- gtk_list_store_append( model, &iter );
- gtk_list_store_set( model, &iter,
- 0, _("Roughen mode"),
- 1, _("Roughen parts of paths"),
- 2, INKSCAPE_ICON("path-tweak-roughen"),
- -1 );
-
- gtk_list_store_append( model, &iter );
- gtk_list_store_set( model, &iter,
- 0, _("Color paint mode"),
- 1, _("Paint the tool's color upon selected objects"),
- 2, INKSCAPE_ICON("object-tweak-paint"),
- -1 );
-
- gtk_list_store_append( model, &iter );
- gtk_list_store_set( model, &iter,
- 0, _("Color jitter mode"),
- 1, _("Jitter the colors of selected objects"),
- 2, INKSCAPE_ICON("object-tweak-jitter-color"),
- -1 );
-
- gtk_list_store_append( model, &iter );
- gtk_list_store_set( model, &iter,
- 0, _("Blur mode"),
- 1, _("Blur selected objects more; with Shift, blur less"),
- 2, INKSCAPE_ICON("object-tweak-blur"),
- -1 );
-
-
- EgeSelectOneAction* act = ege_select_one_action_new( "TweakModeAction", _("Mode"), (""), NULL, GTK_TREE_MODEL(model) );
- g_object_set( act, "short_label", _("Mode:"), NULL );
- gtk_action_group_add_action( mainActions, GTK_ACTION(act) );
- g_object_set_data( holder, "mode_action", act );
-
- ege_select_one_action_set_appearance( act, "full" );
- ege_select_one_action_set_radio_action_type( act, INK_RADIO_ACTION_TYPE );
- g_object_set( G_OBJECT(act), "icon-property", "iconId", NULL );
- ege_select_one_action_set_icon_column( act, 2 );
- ege_select_one_action_set_icon_size( act, secondarySize );
- ege_select_one_action_set_tooltip_column( act, 1 );
-
- gint mode = prefs->getInt("/tools/tweak/mode", 0);
- ege_select_one_action_set_active( act, mode );
- g_signal_connect_after( G_OBJECT(act), "changed", G_CALLBACK(sp_tweak_mode_changed), holder );
-
- g_object_set_data( G_OBJECT(holder), "tweak_tool_mode", act);
+ InkSelectOneActionColumns columns;
+
+ Glib::RefPtr<Gtk::ListStore> store = Gtk::ListStore::create(columns);
+
+ Gtk::TreeModel::Row row;
+
+ row = *(store->append());
+ row[columns.col_label ] = _("Move mode");
+ row[columns.col_tooltip ] = _("Move objects in any direction");
+ row[columns.col_icon ] = INKSCAPE_ICON("object-tweak-push");
+ row[columns.col_sensitive] = true;
+
+ row = *(store->append());
+ row[columns.col_label ] = _("Move in/out mode");
+ row[columns.col_tooltip ] = _("Move objects towards cursor; with Shift from cursor");
+ row[columns.col_icon ] = INKSCAPE_ICON("object-tweak-attract");
+ row[columns.col_sensitive] = true;
+
+ row = *(store->append());
+ row[columns.col_label ] = _("Move jitter mode");
+ row[columns.col_tooltip ] = _("Move objects in random directions");
+ row[columns.col_icon ] = INKSCAPE_ICON("object-tweak-randomize");
+ row[columns.col_sensitive] = true;
+
+ row = *(store->append());
+ row[columns.col_label ] = _("Scale mode");
+ row[columns.col_tooltip ] = _("Shrink objects, with Shift enlarge");
+ row[columns.col_icon ] = INKSCAPE_ICON("object-tweak-shrink");
+ row[columns.col_sensitive] = true;
+
+ row = *(store->append());
+ row[columns.col_label ] = _("Rotate mode");
+ row[columns.col_tooltip ] = _("Rotate objects, with Shift counterclockwise");
+ row[columns.col_icon ] = INKSCAPE_ICON("object-tweak-rotate");
+ row[columns.col_sensitive] = true;
+
+ row = *(store->append());
+ row[columns.col_label ] = _("Duplicate/delete mode");
+ row[columns.col_tooltip ] = _("Duplicate objects, with Shift delete");
+ row[columns.col_icon ] = INKSCAPE_ICON("object-tweak-duplicate");
+ row[columns.col_sensitive] = true;
+
+ row = *(store->append());
+ row[columns.col_label ] = _("Push mode");
+ row[columns.col_tooltip ] = _("Push parts of paths in any direction");
+ row[columns.col_icon ] = INKSCAPE_ICON("path-tweak-push");
+ row[columns.col_sensitive] = true;
+
+ row = *(store->append());
+ row[columns.col_label ] = _("Shrink/grow mode");
+ row[columns.col_tooltip ] = _("Shrink (inset) parts of paths; with Shift grow (outset)");
+ row[columns.col_icon ] = INKSCAPE_ICON("path-tweak-shrink");
+ row[columns.col_sensitive] = true;
+
+ row = *(store->append());
+ row[columns.col_label ] = _("Attract/repel mode");
+ row[columns.col_tooltip ] = _("Attract parts of paths towards cursor; with Shift from cursor");
+ row[columns.col_icon ] = INKSCAPE_ICON("path-tweak-attract");
+ row[columns.col_sensitive] = true;
+
+ row = *(store->append());
+ row[columns.col_label ] = _("Roughen mode");
+ row[columns.col_tooltip ] = _("Roughen parts of paths");
+ row[columns.col_icon ] = INKSCAPE_ICON("path-tweak-roughen");
+ row[columns.col_sensitive] = true;
+
+ row = *(store->append());
+ row[columns.col_label ] = _("Color paint mode");
+ row[columns.col_tooltip ] = _("Paint the tool's color upon selected objects");
+ row[columns.col_icon ] = INKSCAPE_ICON("object-tweak-paint");
+ row[columns.col_sensitive] = true;
+
+ row = *(store->append());
+ row[columns.col_label ] = _("Color jitter mode");
+ row[columns.col_tooltip ] = _("Jitter the colors of selected objects");
+ row[columns.col_icon ] = INKSCAPE_ICON("object-tweak-jitter-color");
+ row[columns.col_sensitive] = true;
+
+ row = *(store->append());
+ row[columns.col_label ] = _("Blur mode");
+ row[columns.col_tooltip ] = _("Blur selected objects more; with Shift, blur less");
+ row[columns.col_icon ] = INKSCAPE_ICON("object-tweak-blur");
+ row[columns.col_sensitive] = true;
+
+ InkSelectOneAction* act =
+ InkSelectOneAction::create( "TweakModeAction", // Name
+ _("Mode"), // Label
+ (""), // Tooltip
+ "Not Used", // Icon
+ store ); // Tree store
+
+ act->use_radio( true );
+ act->use_icon( true );
+ act->use_label( false );
+ act->use_group_label( true );
+ int mode = prefs->getInt("/tools/tweak/mode", 0);
+ act->set_active( mode );
+
+ gtk_action_group_add_action( mainActions, GTK_ACTION( act->gobj() ));
+ g_object_set_data( holder, "tweak_tool_mode", act );
+
+ act->signal_changed().connect(sigc::bind<0>(sigc::ptr_fun(&sp_tweak_mode_changed), holder));
}
guint mode = prefs->getInt("/tools/tweak/mode", 0);