X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=src%2Flive_effects%2Fparameter%2Fpoint.cpp;h=5284bc7975ea9244257de670ae2e1c2989456357;hb=844b3f1ccd684cf1979db02b46a89c3c00fef3ec;hp=caa81692fdeb6e57e5cff3be2052a7c649c5aac2;hpb=f07bfd5a05d43a6d11f7cd442f085149092dea88;p=inkscape.git diff --git a/src/live_effects/parameter/point.cpp b/src/live_effects/parameter/point.cpp index caa81692f..5284bc797 100644 --- a/src/live_effects/parameter/point.cpp +++ b/src/live_effects/parameter/point.cpp @@ -80,8 +80,10 @@ PointParam::param_writeSVGValue() const } Gtk::Widget * -PointParam::param_getWidget() +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"); if (!_widget) { pointwdg = new Inkscape::UI::Widget::RegisteredPoint(); pointwdg->init(param_label, param_tooltip, param_key, *param_wr, param_effect->getRepr(), param_effect->getSPDoc()); @@ -104,8 +106,7 @@ PointParam::param_getWidget() static_cast(_widget)->pack_start(*(pointwdg->getPoint()), true, true); static_cast(_widget)->show_all_children(); - _tooltips = new Gtk::Tooltips(); - _tooltips->set_tip(*pButton, _("Edit on-canvas")); + tooltips->set_tip(*pButton, _("Edit on-canvas")); } return dynamic_cast (_widget); } @@ -118,6 +119,22 @@ PointParam::param_setValue(Geom::Point newpoint) pointwdg->setValue(newpoint[0], newpoint[1]); } +void +PointParam::param_set_and_write_new_value (Geom::Point newpoint) +{ + Inkscape::SVGOStringStream os; + os << newpoint[0] << "," << newpoint[1]; + gchar * str = g_strdup(os.str().c_str()); + param_write_to_repr(str); + g_free(str); +} + +void +PointParam::param_transform_multiply(Geom::Matrix const& postmul, bool /*set*/) +{ + param_set_and_write_new_value( (*this) * postmul ); +} + // CALLBACKS: @@ -135,7 +152,7 @@ PointParam::on_button_click() sp_knot_update_ctrl(knot); // move knot to the given point - sp_knot_set_position (knot, &NR::Point((*this)[0], (*this)[1]), SP_KNOT_STATE_NORMAL); + sp_knot_set_position (knot, &NR::Point(*static_cast(this)), SP_KNOT_STATE_NORMAL); sp_knot_show (knot); /* // connect knot's signals