summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorJabier Arraiza Cenoz <jabier.arraiza@marker.es>2015-03-08 14:31:15 +0000
committerJabiertxof <jtx@jtx.marker.es>2015-03-08 14:31:15 +0000
commit351660cb86c992fe7be5edd31250e2826714c9cb (patch)
treec4d56725c68dbda0a7838ce5bd55380e3bbb06fd /src
parentminor changes to helper paths (diff)
parentUpdate simplify and bspline to auto size some helper paths based on current zoom (diff)
downloadinkscape-351660cb86c992fe7be5edd31250e2826714c9cb.tar.gz
inkscape-351660cb86c992fe7be5edd31250e2826714c9cb.zip
update to trunk and fixed helper paths
(bzr r13645.1.38)
Diffstat (limited to 'src')
-rw-r--r--src/live_effects/effect.cpp4
-rw-r--r--src/live_effects/effect.h2
-rw-r--r--src/live_effects/lpe-bspline.cpp20
-rw-r--r--src/live_effects/lpe-fillet-chamfer.cpp73
-rw-r--r--src/live_effects/lpe-simplify.cpp130
-rw-r--r--src/live_effects/lpe-simplify.h6
-rw-r--r--src/ui/dialog/lpe-fillet-chamfer-properties.cpp12
-rw-r--r--src/ui/dialog/lpe-fillet-chamfer-properties.h6
8 files changed, 208 insertions, 45 deletions
diff --git a/src/live_effects/effect.cpp b/src/live_effects/effect.cpp
index 827f70749..aab64fe64 100644
--- a/src/live_effects/effect.cpp
+++ b/src/live_effects/effect.cpp
@@ -450,7 +450,7 @@ void Effect::doOnRemove (SPLPEItem const* /*lpeitem*/)
void Effect::doOnApply_impl(SPLPEItem const* lpeitem)
{
sp_lpe_item = const_cast<SPLPEItem *>(lpeitem);
- defaultUnit = &sp_lpe_item->document->getDisplayUnit()->abbr;
+ defaultUnit = sp_lpe_item->document->getDisplayUnit()->abbr;
/*sp_curve = SP_SHAPE(sp_lpe_item)->getCurve();
pathvector_before_effect = sp_curve->get_pathvector();*/
doOnApply(lpeitem);
@@ -459,7 +459,7 @@ void Effect::doOnApply_impl(SPLPEItem const* lpeitem)
void Effect::doBeforeEffect_impl(SPLPEItem const* lpeitem)
{
sp_lpe_item = const_cast<SPLPEItem *>(lpeitem);
- defaultUnit = &sp_lpe_item->document->getDisplayUnit()->abbr;
+ defaultUnit = sp_lpe_item->document->getDisplayUnit()->abbr;
//printf("(SPLPEITEM*) %p\n", sp_lpe_item);
sp_curve = SP_SHAPE(sp_lpe_item)->getCurve();
pathvector_before_effect = sp_curve->get_pathvector();
diff --git a/src/live_effects/effect.h b/src/live_effects/effect.h
index 7da76b267..ac1f0b8dc 100644
--- a/src/live_effects/effect.h
+++ b/src/live_effects/effect.h
@@ -159,7 +159,7 @@ protected:
bool concatenate_before_pwd2;
SPLPEItem * sp_lpe_item; // these get stored in doBeforeEffect_impl, and derived classes may do as they please with them.
- Glib::ustring const * defaultUnit; // these get stored in doBeforeEffect_impl, and derived classes may do as they please with them.
+ Glib::ustring defaultUnit; // these get stored in doBeforeEffect_impl, and derived classes may do as they please with them.
double current_zoom;
std::vector<Geom::Point> selectedNodesPoints;
SPCurve * sp_curve;
diff --git a/src/live_effects/lpe-bspline.cpp b/src/live_effects/lpe-bspline.cpp
index 045974147..02a7b3711 100644
--- a/src/live_effects/lpe-bspline.cpp
+++ b/src/live_effects/lpe-bspline.cpp
@@ -106,9 +106,23 @@ void LPEBSpline::doEffect(SPCurve *curve)
// Make copy of old path as it is changed during processing
Geom::PathVector const original_pathv = curve->get_pathvector();
curve->reset();
- double radiusHelperNodes = 6.0;
- radiusHelperNodes /= current_zoom;
- radiusHelperNodes = Inkscape::Util::Quantity::convert(radiusHelperNodes, "px", *defaultUnit);
+ double radiusHelperNodes = 12.0;
+ if(current_zoom != 0){
+ if(current_zoom < 0.5){
+ radiusHelperNodes *= current_zoom + 0.4;
+ } else if(current_zoom > 1) {
+ radiusHelperNodes *= 1/current_zoom;
+ }
+ Geom::Affine i2doc = i2anc_affine(SP_ITEM(sp_lpe_item), SP_OBJECT(SP_ITEM(sp_lpe_item)->document->getRoot()));
+ double expand = (i2doc.expansionX() + i2doc.expansionY())/2;
+ std::cout << expand << "expand\n";
+ if(expand != 0){
+ radiusHelperNodes /= expand;
+ }
+ radiusHelperNodes = Inkscape::Util::Quantity::convert(radiusHelperNodes, "px", defaultUnit);
+ } else {
+ radiusHelperNodes = 0;
+ }
for (Geom::PathVector::const_iterator path_it = original_pathv.begin();
path_it != original_pathv.end(); ++path_it) {
if (path_it->empty())
diff --git a/src/live_effects/lpe-fillet-chamfer.cpp b/src/live_effects/lpe-fillet-chamfer.cpp
index ca53bec63..0140f9be9 100644
--- a/src/live_effects/lpe-fillet-chamfer.cpp
+++ b/src/live_effects/lpe-fillet-chamfer.cpp
@@ -231,6 +231,60 @@ Gtk::Widget *LPEFilletChamfer::newWidget()
return vbox;
}
+void LPEFilletChamfer::toggleHide()
+{
+ std::vector<Point> filletChamferData = fillet_chamfer_values.data();
+ std::vector<Geom::Point> result;
+ for (std::vector<Point>::const_iterator point_it = filletChamferData.begin();
+ point_it != filletChamferData.end(); ++point_it) {
+ if (hide_knots) {
+ result.push_back(Point((*point_it)[X], std::abs((*point_it)[Y]) * -1));
+ } else {
+ result.push_back(Point((*point_it)[X], std::abs((*point_it)[Y])));
+ }
+ }
+ fillet_chamfer_values.param_set_and_write_new_value(result);
+ refreshKnots();
+}
+
+void LPEFilletChamfer::toggleFlexFixed()
+{
+ std::vector<Point> filletChamferData = fillet_chamfer_values.data();
+ std::vector<Geom::Point> result;
+ unsigned int i = 0;
+ for (std::vector<Point>::const_iterator point_it = filletChamferData.begin();
+ point_it != filletChamferData.end(); ++point_it) {
+ if (flexible) {
+ result.push_back(Point(fillet_chamfer_values.to_time(i, (*point_it)[X]),
+ (*point_it)[Y]));
+ } else {
+ result.push_back(Point(fillet_chamfer_values.to_len(i, (*point_it)[X]),
+ (*point_it)[Y]));
+ }
+ i++;
+ }
+ if (flexible) {
+ radius.param_set_range(0., 100);
+ radius.param_set_value(0);
+ } else {
+ radius.param_set_range(0., infinity());
+ radius.param_set_value(0);
+ }
+ fillet_chamfer_values.param_set_and_write_new_value(result);
+}
+
+void LPEFilletChamfer::updateFillet()
+{
+ double power = 0;
+ if (!flexible) {
+ power = Inkscape::Util::Quantity::convert(radius, unit.get_abbreviation(), defaultUnit) * -1;
+ } else {
+ power = radius;
+ }
+ Piecewise<D2<SBasis> > const &pwd2 = fillet_chamfer_values.get_pwd2();
+ doUpdateFillet(path_from_piecewise(pwd2, tolerance), power);
+}
+>>>>>>> MERGE-SOURCE
void LPEFilletChamfer::fillet()
{
@@ -265,7 +319,7 @@ void LPEFilletChamfer::updateAmount()
{
double power = 0;
if (!flexible) {
- power = Inkscape::Util::Quantity::convert(radius, unit.get_abbreviation(), *defaultUnit);
+ power = Inkscape::Util::Quantity::convert(radius, unit.get_abbreviation(), defaultUnit);
} else {
power = radius/100;
}
@@ -371,10 +425,21 @@ void LPEFilletChamfer::doBeforeEffect(SPLPEItem const *lpeItem)
if(hide_knots || !helper){
satellitepairarrayparam_values.set_helper_size(0);
} else {
- double radiusHelperNodes = 6.0;
+ double radiusHelperNodes = 12.0;
if(current_zoom != 0){
- radiusHelperNodes *= 1/current_zoom;
- radiusHelperNodes = Inkscape::Util::Quantity::convert(radiusHelperNodes, "px", *defaultUnit);
+ if(current_zoom < 0.5){
+ radiusHelperNodes *= current_zoom + 0.4;
+ } else if(current_zoom > 1) {
+ radiusHelperNodes *= 1/current_zoom;
+ }
+ Geom::Affine i2doc = i2anc_affine(SP_ITEM(lpeItem), SP_OBJECT(SP_ITEM(lpeItem)->document->getRoot()));
+ double expand = (i2doc.expansionX() + i2doc.expansionY())/2;
+ if(expand != 0){
+ radiusHelperNodes /= expand;
+ }
+ radiusHelperNodes = Inkscape::Util::Quantity::convert(radiusHelperNodes, "px", defaultUnit);
+ } else {
+ radiusHelperNodes = 0;
}
satellitepairarrayparam_values.set_helper_size(radiusHelperNodes);
}
diff --git a/src/live_effects/lpe-simplify.cpp b/src/live_effects/lpe-simplify.cpp
index 2b2efb1a9..12bd9dc60 100644
--- a/src/live_effects/lpe-simplify.cpp
+++ b/src/live_effects/lpe-simplify.cpp
@@ -20,6 +20,7 @@
#include <2geom/generic-rect.h>
#include <2geom/interval.h>
#include "ui/icon-names.h"
+#include "util/units.h"
namespace Inkscape {
namespace LivePathEffect {
@@ -28,7 +29,9 @@ LPESimplify::LPESimplify(LivePathEffectObject *lpeobject)
: Effect(lpeobject),
steps(_("Steps:"),_("Change number of simplify steps "), "steps", &wr, this,1),
threshold(_("Roughly threshold:"), _("Roughly threshold:"), "threshold", &wr, this, 0.003),
- helper_size(_("Helper size:"), _("Helper size"), "helper_size", &wr, this, 2.),
+ smooth_angles(_("Smooth angles:"), _("Max degree diference on handles to preform a smooth"), "smooth_angles", &wr, this, 20.),
+ helper(_("Helper"), _("Show helper"), "helper", &wr, this, false,
+ "", INKSCAPE_ICON("on"), INKSCAPE_ICON("off")),
nodes(_("Helper nodes"), _("Show helper nodes"), "nodes", &wr, this, false,
"", INKSCAPE_ICON("on"), INKSCAPE_ICON("off")),
handles(_("Helper handles"), _("Show helper handles"), "handles", &wr, this, false,
@@ -38,9 +41,11 @@ LPESimplify::LPESimplify(LivePathEffectObject *lpeobject)
simplifyJustCoalesce(_("Just coalesce"), _("Simplify just coalesce"), "simplifyJustCoalesce", &wr, this, false,
"", INKSCAPE_ICON("on"), INKSCAPE_ICON("off"))
{
+ radiusHelperNodes = 6.0;
registerParameter(dynamic_cast<Parameter *>(&steps));
registerParameter(dynamic_cast<Parameter *>(&threshold));
- registerParameter(dynamic_cast<Parameter *>(&helper_size));
+ registerParameter(dynamic_cast<Parameter *>(&smooth_angles));
+ registerParameter(dynamic_cast<Parameter *>(&helper));
registerParameter(dynamic_cast<Parameter *>(&nodes));
registerParameter(dynamic_cast<Parameter *>(&handles));
registerParameter(dynamic_cast<Parameter *>(&simplifyindividualpaths));
@@ -51,9 +56,9 @@ LPESimplify::LPESimplify(LivePathEffectObject *lpeobject)
steps.param_set_range(0, 100);
steps.param_set_increments(1, 1);
steps.param_set_digits(0);
- helper_size.param_set_range(0.1, 100);
- helper_size.param_set_increments(1, 1);
- helper_size.param_set_digits(1);
+ smooth_angles.param_set_range(0.0, 365.0);
+ smooth_angles.param_set_increments(10, 10);
+ smooth_angles.param_set_digits(2);
}
LPESimplify::~LPESimplify() {}
@@ -66,9 +71,24 @@ LPESimplify::doBeforeEffect (SPLPEItem const* lpeitem)
}
bbox = SP_ITEM(lpeitem)->visualBounds();
SPLPEItem * item = const_cast<SPLPEItem*>(lpeitem);
+ radiusHelperNodes = 12.0;
+ if(current_zoom != 0){
+ if(current_zoom < 0.5){
+ radiusHelperNodes *= current_zoom + 0.4;
+ } else if(current_zoom > 1) {
+ radiusHelperNodes *= 1/current_zoom;
+ }
+ Geom::Affine i2doc = i2anc_affine(SP_ITEM(lpeitem), SP_OBJECT(SP_ITEM(lpeitem)->document->getRoot()));
+ double expand = (i2doc.expansionX() + i2doc.expansionY())/2;
+ if(expand != 0){
+ radiusHelperNodes /= expand;
+ }
+ radiusHelperNodes = Inkscape::Util::Quantity::convert(radiusHelperNodes, "px", defaultUnit);
+ } else {
+ radiusHelperNodes = 0;
+ }
item->apply_to_clippath(item);
item->apply_to_mask(item);
-
}
Gtk::Widget *
@@ -80,18 +100,31 @@ LPESimplify::newWidget()
vbox->set_homogeneous(false);
vbox->set_spacing(2);
std::vector<Parameter *>::iterator it = param_vector.begin();
+ Gtk::HBox * buttonTop = Gtk::manage(new Gtk::HBox(true,0));
Gtk::HBox * buttons = Gtk::manage(new Gtk::HBox(true,0));
- Gtk::HBox * buttonsTwo = Gtk::manage(new Gtk::HBox(true,0));
+ Gtk::HBox * buttonsBottom = Gtk::manage(new Gtk::HBox(true,0));
while (it != param_vector.end()) {
if ((*it)->widget_is_visible) {
Parameter * param = *it;
Gtk::Widget * widg = dynamic_cast<Gtk::Widget *>(param->param_newWidget());
- if (param->param_key == "simplifyindividualpaths" ||
+ if (param->param_key == "helper")
+ {
+ Glib::ustring * tip = param->param_getTooltip();
+ if (widg) {
+ buttonTop->pack_start(*widg, true, true, 2);
+ if (tip) {
+ widg->set_tooltip_text(*tip);
+ } else {
+ widg->set_tooltip_text("");
+ widg->set_has_tooltip(false);
+ }
+ }
+ } else if (param->param_key == "simplifyindividualpaths" ||
param->param_key == "simplifyJustCoalesce")
{
Glib::ustring * tip = param->param_getTooltip();
if (widg) {
- buttonsTwo->pack_start(*widg, true, true, 2);
+ buttonsBottom->pack_start(*widg, true, true, 2);
if (tip) {
widg->set_tooltip_text(*tip);
} else {
@@ -132,8 +165,9 @@ LPESimplify::newWidget()
++it;
}
+ vbox->pack_start(*buttonTop,true, true, 2);
vbox->pack_start(*buttons,true, true, 2);
- vbox->pack_start(*buttonsTwo,true, true, 2);
+ vbox->pack_start(*buttonsBottom,true, true, 2);
return dynamic_cast<Gtk::Widget *>(vbox);
}
@@ -154,9 +188,9 @@ LPESimplify::doEffect(SPCurve *curve) {
pathliv->Simplify(threshold * size);
}
}
- Geom::PathVector outres = Geom::parse_svg_path(pathliv->svg_dump_path());
- generateHelperPath(outres);
- curve->set_pathvector(outres);
+ Geom::PathVector result = Geom::parse_svg_path(pathliv->svg_dump_path());
+ generateHelperPathAndSmooth(result);
+ curve->set_pathvector(result);
SPDesktop* desktop = SP_ACTIVE_DESKTOP;
if(desktop && INK_IS_NODE_TOOL(desktop->event_context)){
Inkscape::UI::Tools::NodeTool *nt = static_cast<Inkscape::UI::Tools::NodeTool*>(desktop->event_context);
@@ -165,16 +199,16 @@ LPESimplify::doEffect(SPCurve *curve) {
}
void
-LPESimplify::generateHelperPath(Geom::PathVector result)
+LPESimplify::generateHelperPathAndSmooth(Geom::PathVector &result)
{
- if(!handles && !nodes){
+ if(!handles && !nodes && smooth_angles == 0){
return;
}
if(steps < 1){
return;
}
-
+ Geom::PathVector tmpPath;
Geom::CubicBezier const *cubic = NULL;
for (Geom::PathVector::iterator path_it = result.begin(); path_it != result.end(); ++path_it) {
//Si está vacío...
@@ -183,11 +217,9 @@ LPESimplify::generateHelperPath(Geom::PathVector result)
}
//Itreadores
Geom::Path::const_iterator curve_it1 = path_it->begin(); // incoming curve
- Geom::Path::const_iterator curve_it2 =
- ++(path_it->begin()); // outgoing curve
- Geom::Path::const_iterator curve_endit =
- path_it->end_default(); // this determines when the loop has to stop
-
+ Geom::Path::const_iterator curve_it2 = ++(path_it->begin());// outgoing curve
+ Geom::Path::const_iterator curve_endit = path_it->end_default(); // this determines when the loop has to stop
+ SPCurve *nCurve = new SPCurve();
if (path_it->closed()) {
// if the path is closed, maybe we have to stop a bit earlier because the
// closing line segment has zerolength.
@@ -205,9 +237,46 @@ LPESimplify::generateHelperPath(Geom::PathVector result)
if(nodes){
drawNode(curve_it1->initialPoint());
}
+ nCurve->moveto(curve_it1->initialPoint());
+ Geom::Point start = Geom::Point(0,0);
while (curve_it1 != curve_endit) {
cubic = dynamic_cast<Geom::CubicBezier const *>(&*curve_it1);
+ Geom::Point pointAt1 = curve_it1->initialPoint();
+ Geom::Point pointAt2 = curve_it1->finalPoint();
+ Geom::Point pointAt3 = curve_it1->finalPoint();
+ Geom::Point pointAt4 = curve_it1->finalPoint();
+ if (cubic) {
+ pointAt1 = (*cubic)[1];
+ pointAt2 = (*cubic)[2];
+ }
+ if(start == Geom::Point(0,0)){
+ start = pointAt1;
+ }
+
+ if(path_it->closed() && curve_it2 == curve_endit){
+ pointAt4 = start;
+ }
+ if(curve_it2 != curve_endit){
+ cubic = dynamic_cast<Geom::CubicBezier const *>(&*curve_it2);
+ if (cubic) {
+ pointAt4 = (*cubic)[1];
+ }
+ }
+ Geom::Ray ray1(pointAt2, pointAt3);
+ Geom::Ray ray2(pointAt3, pointAt4);
+ double angle1 = Geom::rad_to_deg(ray1.angle());
+ double angle2 = Geom::rad_to_deg(ray2.angle());
+ if((smooth_angles >= angle2 - angle1) && !are_near(pointAt4,pointAt3) && !are_near(pointAt2,pointAt3)){
+ double dist = Geom::distance(pointAt2,pointAt3);
+ Geom::Angle angleFixed = ray2.angle();
+ angleFixed -= Geom::Angle::from_degrees(180.0);
+ pointAt2 = Geom::Point::polar(angleFixed,dist) + pointAt3;
+ }
+ nCurve->curveto(pointAt1, pointAt2, curve_it1->finalPoint());
+ cubic = dynamic_cast<Geom::CubicBezier const *>(nCurve->last_segment());
if (cubic) {
+ pointAt1 = (*cubic)[1];
+ pointAt2 = (*cubic)[2];
if(handles) {
if(!are_near((*cubic)[0],(*cubic)[1])){
drawHandle((*cubic)[1]);
@@ -223,17 +292,22 @@ LPESimplify::generateHelperPath(Geom::PathVector result)
drawNode(curve_it1->finalPoint());
}
++curve_it1;
- if(curve_it2 != curve_endit){
- ++curve_it2;
- }
+ ++curve_it2;
+ }
+ if (path_it->closed()) {
+ nCurve->closepath_current();
}
+ tmpPath.push_back(nCurve->get_pathvector()[0]);
+ nCurve->reset();
+ delete nCurve;
}
+ result = tmpPath;
}
void
LPESimplify::drawNode(Geom::Point p)
{
- double r = helper_size/0.67;
+ double r = radiusHelperNodes;
char const * svgd;
svgd = "M 0.55,0.5 A 0.05,0.05 0 0 1 0.5,0.55 0.05,0.05 0 0 1 0.45,0.5 0.05,0.05 0 0 1 0.5,0.45 0.05,0.05 0 0 1 0.55,0.5 Z M 0,0 1,0 1,1 0,1 Z";
Geom::PathVector pathv = sp_svg_read_pathv(svgd);
@@ -246,7 +320,7 @@ LPESimplify::drawNode(Geom::Point p)
void
LPESimplify::drawHandle(Geom::Point p)
{
- double r = helper_size/0.67;
+ double r = radiusHelperNodes;
char const * svgd;
svgd = "M 0.7,0.35 A 0.35,0.35 0 0 1 0.35,0.7 0.35,0.35 0 0 1 0,0.35 0.35,0.35 0 0 1 0.35,0 0.35,0.35 0 0 1 0.7,0.35 Z";
Geom::PathVector pathv = sp_svg_read_pathv(svgd);
@@ -261,8 +335,8 @@ LPESimplify::drawHandleLine(Geom::Point p,Geom::Point p2)
{
Geom::Path path;
path.start( p );
- double diameter = helper_size/0.67;
- if(helper_size > 0.0 && Geom::distance(p,p2) > (diameter * 0.35)){
+ double diameter = radiusHelperNodes;
+ if(helper && Geom::distance(p,p2) > (diameter * 0.35)){
Geom::Ray ray2(p, p2);
p2 = p2 - Geom::Point::polar(ray2.angle(),(diameter * 0.35));
}
diff --git a/src/live_effects/lpe-simplify.h b/src/live_effects/lpe-simplify.h
index 6acf2f2d4..9721d15c4 100644
--- a/src/live_effects/lpe-simplify.h
+++ b/src/live_effects/lpe-simplify.h
@@ -24,7 +24,7 @@ public:
virtual void doBeforeEffect (SPLPEItem const* lpeitem);
- virtual void generateHelperPath(Geom::PathVector result);
+ virtual void generateHelperPathAndSmooth(Geom::PathVector &result);
virtual Gtk::Widget * newWidget();
@@ -40,11 +40,13 @@ protected:
private:
ScalarParam steps;
ScalarParam threshold;
- ScalarParam helper_size;
+ ScalarParam smooth_angles;
+ ToggleButtonParam helper;
ToggleButtonParam nodes;
ToggleButtonParam handles;
ToggleButtonParam simplifyindividualpaths;
ToggleButtonParam simplifyJustCoalesce;
+ double radiusHelperNodes;
Geom::PathVector hp;
Geom::OptRect bbox;
diff --git a/src/ui/dialog/lpe-fillet-chamfer-properties.cpp b/src/ui/dialog/lpe-fillet-chamfer-properties.cpp
index 8a6cbadad..d0f52775a 100644
--- a/src/ui/dialog/lpe-fillet-chamfer-properties.cpp
+++ b/src/ui/dialog/lpe-fillet-chamfer-properties.cpp
@@ -129,8 +129,12 @@ void FilletChamferPropertiesDialog::showDialog(
const gchar *unit,
bool use_distance,
bool aprox_radius,
+<<<<<<< TREE
Glib::ustring const * documentUnit,
Geom::Satellite satellite)
+=======
+ Glib::ustring documentUnit)
+>>>>>>> MERGE-SOURCE
{
FilletChamferPropertiesDialog *dialog = new FilletChamferPropertiesDialog();
@@ -174,7 +178,7 @@ void FilletChamferPropertiesDialog::_apply()
}
d_pos = d_pos / 100;
} else {
- d_pos = Inkscape::Util::Quantity::convert(d_pos, unit, *document_unit);
+ d_pos = Inkscape::Util::Quantity::convert(d_pos, unit, document_unit);
}
_satellite.setAmount( d_pos);
unsigned int steps = (unsigned int)_fillet_chamfer_chamfer_subdivisions.get_value();
@@ -230,7 +234,7 @@ void FilletChamferPropertiesDialog::_set_satellite(Geom::Satellite satellite)
std::string posConcat = Glib::ustring::compose (_("%1 (%2):"), distance_or_radius, unit);
_fillet_chamfer_position_label.set_label(_(posConcat.c_str()));
position = amount;
- position = Inkscape::Util::Quantity::convert(position, *document_unit, unit);
+ position = Inkscape::Util::Quantity::convert(position, document_unit, unit);
}
_fillet_chamfer_position_numeric.set_value(position);
if (satellite.getSatelliteType() == Geom::F) {
@@ -261,6 +265,7 @@ void FilletChamferPropertiesDialog::_set_unit(const gchar *abbr)
unit = abbr;
}
+<<<<<<< TREE
void FilletChamferPropertiesDialog::_set_amount(double amm)
{
amount = amm;
@@ -270,6 +275,9 @@ void FilletChamferPropertiesDialog::_set_amount(double amm)
void FilletChamferPropertiesDialog::_set_document_unit(Glib::ustring const *abbr)
+=======
+void FilletChamferPropertiesDialog::_set_document_unit(Glib::ustring abbr)
+>>>>>>> MERGE-SOURCE
{
document_unit = abbr;
}
diff --git a/src/ui/dialog/lpe-fillet-chamfer-properties.h b/src/ui/dialog/lpe-fillet-chamfer-properties.h
index 6051b49d3..533f7af2a 100644
--- a/src/ui/dialog/lpe-fillet-chamfer-properties.h
+++ b/src/ui/dialog/lpe-fillet-chamfer-properties.h
@@ -33,7 +33,7 @@ public:
const gchar *unit,
bool use_distance,
bool aprox_radius,
- Glib::ustring const * documentUnit,
+ Glib::ustring documentUnit,
Geom::Satellite satellite);
protected:
@@ -69,7 +69,7 @@ protected:
void _set_pt(const Inkscape::LivePathEffect::
FilletChamferKnotHolderEntity *pt);
void _set_unit(const gchar *abbr);
- void _set_document_unit(Glib::ustring const * abbr);
+ void _set_document_unit(Glib::ustring abbr);
void _set_use_distance(bool use_knot_distance);
void _set_aprox(bool aprox_radius);
void _apply();
@@ -77,7 +77,7 @@ protected:
bool _flexible;
Geom::Satellite _satellite;
const gchar *unit;
- Glib::ustring const * document_unit;
+ Glib::ustring document_unit;
bool use_distance;
double amount;
bool aprox;