summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: a00d071)
raw | patch | inline | side by side (parent: a00d071)
author | johanengelen <johanengelen@users.sourceforge.net> | |
Wed, 27 Feb 2008 09:39:45 +0000 (09:39 +0000) | ||
committer | johanengelen <johanengelen@users.sourceforge.net> | |
Wed, 27 Feb 2008 09:39:45 +0000 (09:39 +0000) |
* put forward declarations in lpe parameters to decrease recompile times
index f800017b8dbecf003b10662f84c390eb89941742..5cbb7b1d5eb563787e54cfd7c01808287a0e42bb 100644 (file)
#include "live_effects/effect.h"
#include "svg/svg.h"
#include "libnr/nr-values.h"
-
+#include "xml/repr.h"
#include <gtkmm.h>
-#include "ui/widget/scalar.h"
+#include "ui/widget/registered-widget.h"
#include "svg/stringstream.h"
index 256ab343f4ca7cb14f29812969b9000d0a5f3088..23faffc308c7506f38eb85f686bfbacdcc4676c2 100644 (file)
#include <2geom/point.h>
#include <2geom/path.h>
-#include "ui/widget/registry.h"
-#include "ui/widget/registered-widget.h"
-
struct SPDesktop;
struct SPItem;
class Path ;
}
+namespace UI {
+namespace Widget {
+ class Registry;
+}
+}
+
namespace LivePathEffect {
class Effect;
index 09b0ff5d40cc4216c382cdad10d86bbc2f86d2ea..ded004eee7da9ba07709285b17675604b535a7fa 100644 (file)
#include "widgets/icon.h"
#include <gtk/gtkstock.h>
#include "selection-chemistry.h"
-
+#include "xml/repr.h"
#include "desktop.h"
#include "inkscape.h"
#include "message-stack.h"
}
ShapeEditor * shape_editor = SP_NODE_CONTEXT( dt->event_context )->shape_editor;
- shape_editor->set_item_livepatheffect_parameter(item, SP_OBJECT(param_effect->getLPEObj()), param_key.c_str());
+ shape_editor->set_item_lpe_path_parameter(item, SP_OBJECT(param_effect->getLPEObj()), param_key.c_str());
}
void
index 8ee7950a3a860ef94e3c1756f92794a151116778..0f125cbb511e3186f363c8dfd8d283691fbf8c40 100644 (file)
void param_set_and_write_default();
void param_set_and_write_new_value (Geom::Piecewise<Geom::D2<Geom::SBasis> > newpath);
- void param_editOncanvas(SPItem * item, SPDesktop * dt);
- void param_setup_nodepath(Inkscape::NodePath::Path *np);
+ virtual void param_editOncanvas(SPItem * item, SPDesktop * dt);
+ virtual void param_setup_nodepath(Inkscape::NodePath::Path *np);
virtual void param_transform_multiply(Geom::Matrix const& /*postmul*/, bool /*set*/);
index 31c4ae55bdd04574e46c9eb77da8cd5d35502da5..ca188da806a252f2627390bb4af7f5d7e43a043e 100644 (file)
#include "inkscape.h"
#include "verbs.h"
-#define noLPEPOINTPARAM_DEBUG
+// needed for on-canvas editting:
+#include "tools-switch.h"
+#include "shape-editor.h"
+#include "node-context.h"
+#include "desktop-handles.h"
+#include "selection.h"
+#include "desktop.h"
+
+#define LPEPOINTPARAM_DEBUG // undefine to disable all on-canvas editing code for PointParam
#define PRM_KNOT_COLOR_NORMAL 0xffffff00
#define PRM_KNOT_COLOR_SELECTED 0x0000ff00
: Geom::Point(default_value), Parameter(label, tip, key, wr, effect), defvalue(default_value)
{
knot = NULL;
+#ifdef LPEPOINTPARAM_DEBUG
+ oncanvas_editable = true;
+#endif
}
PointParam::~PointParam()
Gtk::Widget *
PointParam::param_newWidget(Gtk::Tooltips * tooltips)
{
- // WIDGET TODO: This implementation is incorrect, it should create a *new* widget for the caller, not just return an already created widget
- g_warning("PointParam::param_newWidget still needs recoding to work with multiple document views");
Inkscape::UI::Widget::RegisteredPoint * pointwdg = Gtk::manage(
new Inkscape::UI::Widget::RegisteredPoint( param_label,
param_tooltip,
g_free(str);
}
+void
+PointParam::param_editOncanvas(SPItem * item, SPDesktop * dt)
+{
+ // If not already in nodecontext, goto it!
+ if (!tools_isactive(dt, TOOLS_NODES)) {
+ tools_switch_current(TOOLS_NODES);
+ }
+
+ ShapeEditor * shape_editor = SP_NODE_CONTEXT( dt->event_context )->shape_editor;
+ shape_editor->set_item_lpe_point_parameter(item, SP_OBJECT(param_effect->getLPEObj()), param_key.c_str());
+}
+
+
+
void
PointParam::param_transform_multiply(Geom::Matrix const& postmul, bool /*set*/)
{
@@ -135,36 +158,9 @@ PointParam::param_transform_multiply(Geom::Matrix const& postmul, bool /*set*/)
void
PointParam::on_button_click()
{
- g_message("add knot to canvas on correct location :S");
-
- if (!knot) {
- // create the knot
- knot = sp_knot_new (SP_ACTIVE_DESKTOP, NULL);
- knot->setMode(SP_KNOT_MODE_XOR);
- knot->setFill(PRM_KNOT_COLOR_NORMAL, PRM_KNOT_COLOR_NORMAL, PRM_KNOT_COLOR_NORMAL);
- knot->setStroke(0x000000ff, 0x000000ff, 0x000000ff);
- sp_knot_update_ctrl(knot);
-
- // move knot to the given point
- sp_knot_set_position (knot, &NR::Point(*static_cast<Geom::Point*>(this)), SP_KNOT_STATE_NORMAL);
- sp_knot_show (knot);
-/*
- // connect knot's signals
- if ( (draggable) // it can be NULL if a node in unsnapped (eg. focus point unsnapped from center)
- // luckily, midstops never snap to other nodes so are never unsnapped...
- && ( (draggable->point_type == POINT_LG_MID)
- || (draggable->point_type == POINT_RG_MID1)
- || (draggable->point_type == POINT_RG_MID2) ) )
- {
- this->handler_id = g_signal_connect (G_OBJECT (this->knot), "moved", G_CALLBACK (gr_knot_moved_midpoint_handler), this);
- } else {
- this->handler_id = g_signal_connect (G_OBJECT (this->knot), "moved", G_CALLBACK (gr_knot_moved_handler), this);
- }
- g_signal_connect (G_OBJECT (this->knot), "clicked", G_CALLBACK (gr_knot_clicked_handler), this);
- g_signal_connect (G_OBJECT (this->knot), "doubleclicked", G_CALLBACK (gr_knot_doubleclicked_handler), this);
- g_signal_connect (G_OBJECT (this->knot), "grabbed", G_CALLBACK (gr_knot_grabbed_handler), this);
- g_signal_connect (G_OBJECT (this->knot), "ungrabbed", G_CALLBACK (gr_knot_ungrabbed_handler), this);
-*/
+ SPItem * item = sp_desktop_selection(SP_ACTIVE_DESKTOP)->singleItem();
+ if (item != NULL) {
+ param_editOncanvas(item, SP_ACTIVE_DESKTOP);
}
}
index a47fa77f53391e894fa73288113ea04f97bae53e..1137a8f1a725fa11677b0a67eb185b0acfd81d27 100644 (file)
void param_set_and_write_new_value(Geom::Point newpoint);
+ virtual void param_editOncanvas(SPItem * item, SPDesktop * dt);
+
virtual void param_transform_multiply(Geom::Matrix const& /*postmul*/, bool /*set*/);
private:
index d5efc7ce3852c31da10d134305e68304b7760335..9213a6a6bc926e3ed984589dad67277e31a6cb1a 100644 (file)
#include "live_effects/effect.h"
#include "svg/svg.h"
#include "libnr/nr-values.h"
-
+#include "ui/widget/registered-widget.h"
#include <gtkmm.h>
#include "ui/widget/random.h"
diff --git a/src/shape-editor.cpp b/src/shape-editor.cpp
index fbf42eaca1b8ebc71f1ce116c0db6036b134a5af..b8eaca7a7c0d9246f8e07c9ef57b072bb6402529 100644 (file)
--- a/src/shape-editor.cpp
+++ b/src/shape-editor.cpp
/** Please note that this function only works for path parameters.
* All other parameters probably will crash Inkscape!
-* Fortunately, there are no other on-canvas edittable objects at this moment :)
*/
-void ShapeEditor::set_item_livepatheffect_parameter(SPItem *item, SPObject *lpeobject, const char * key) {
+void ShapeEditor::set_item_lpe_path_parameter(SPItem *item, SPObject *lpeobject, const char * key) {
unset_item();
this->grab_node = -1;
if (lpeobject) {
+ // FIXME ? just setting knotholder to NULL... not necessary to delete it ?
this->knotholder = NULL; // it's a path, no special knotholder needed.
this->nodepath = sp_nodepath_new( desktop, lpeobject,
(prefs_get_int_attribute("tools.nodes", "show_handles", 1) != 0),
@@ -238,6 +238,14 @@ void ShapeEditor::set_item_livepatheffect_parameter(SPItem *item, SPObject *lpeo
}
}
+/** Please note that this function only works for point parameters.
+* All other parameters probably will crash Inkscape!
+*/
+void ShapeEditor::set_item_lpe_point_parameter(SPItem */*item*/, SPObject */*lpeobject*/, const char * /*key*/) {
+ g_message("ShapeEditor::set_item_lpe_point_parameter has not been implemented yet!");
+}
+
+
/** FIXME: think about this. Is this thing only called when the item needs to be updated?
Why not make a reload function in NodePath and in KnotHolder? */
void ShapeEditor::reset_item ()
SPItem * item = this->nodepath->item;
SPObject *obj = this->nodepath->object;
char * key = g_strdup(this->nodepath->repr_key);
- set_item_livepatheffect_parameter(item, obj, key);
+ set_item_lpe_path_parameter(item, obj, key); // the above checks for nodepath, so it is indeed a path that we are editing
g_free(key);
} else {
SPItem * item = get_item();
diff --git a/src/shape-editor.h b/src/shape-editor.h
index 8e563b433d0185afb658cb2f31d6fcc8f2db781b..c78fb0d4ac4bc79eaa9d54b05a0f58a305acfb58 100644 (file)
--- a/src/shape-editor.h
+++ b/src/shape-editor.h
~ShapeEditor();
void set_item (SPItem *item);
- void set_item_livepatheffect_parameter(SPItem *item, SPObject *lpeobject, const char * key);
+ void set_item_lpe_path_parameter(SPItem *item, SPObject *lpeobject, const char * key);
+ void set_item_lpe_point_parameter(SPItem *item, SPObject *lpeobject, const char * key);
void reset_item ();
void unset_item ();