summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorJabier Arraiza <jabier.arraiza@marker.es>2018-03-31 07:44:37 +0000
committerJabier Arraiza <jabier.arraiza@marker.es>2018-03-31 19:13:38 +0000
commit31839078f4801444e430d77fd122948a4e936cb4 (patch)
treebb4a23ca882d74896a1f970315b9f08cb123fa88 /src
parentCMake/MSYS2: Add new curl dependency (libbrotli) (diff)
downloadinkscape-31839078f4801444e430d77fd122948a4e936cb4.tar.gz
inkscape-31839078f4801444e430d77fd122948a4e936cb4.zip
Fix fillet chamfer LPE bug on adding points to paths
Diffstat (limited to 'src')
-rw-r--r--src/helper/geom-pathvectorsatellites.cpp20
-rw-r--r--src/live_effects/lpe-fillet-chamfer.cpp7
2 files changed, 21 insertions, 6 deletions
diff --git a/src/helper/geom-pathvectorsatellites.cpp b/src/helper/geom-pathvectorsatellites.cpp
index e995c0a9b..85192bd75 100644
--- a/src/helper/geom-pathvectorsatellites.cpp
+++ b/src/helper/geom-pathvectorsatellites.cpp
@@ -41,7 +41,7 @@ size_t PathVectorSatellites::getTotalSatellites()
{
size_t counter = 0;
for (size_t i = 0; i < _satellites.size(); ++i) {
- for (size_t j = 0; j < _satellites[i].size(); ++j) {
+ for (size_t j = 0; j < _satellites[i].size(); ++j) {
counter++;
}
}
@@ -204,10 +204,24 @@ void PathVectorSatellites::recalculateForNewPathVector(Geom::PathVector const pa
size_t previous_number_nodes = _pathvector.nodes().size();
for (size_t i = 0; i < pathv.size(); i++) {
std::vector<Satellite> path_satellites;
- for (size_t j = 0; j < pathv[i].size_closed(); j++) {
+ size_t count = pathv[i].size_default();
+ if ( pathv[i].closed()) {
+ const Geom::Curve &closingline = pathv[i].back_closed();
+ if (are_near(closingline.initialPoint(), closingline.finalPoint())) {
+ count = pathv[i].size_open();
+ }
+ }
+ for (size_t j = 0; j < count; j++) {
found = false;
for (size_t k = 0; k < _pathvector.size(); k++) {
- for (size_t l = 0; l < _pathvector[k].size_closed(); l++) {
+ size_t count2 = _pathvector[k].size_default();
+ if ( _pathvector[k].closed()) {
+ const Geom::Curve &closingline = _pathvector[k].back_closed();
+ if (are_near(closingline.initialPoint(), closingline.finalPoint())) {
+ count2 = _pathvector[k].size_open();
+ }
+ }
+ for (size_t l = 0; l < count2; l++) {
if (Geom::are_near(_pathvector[k][l].initialPoint(), pathv[i][j].initialPoint()))
{
path_satellites.push_back(_satellites[k][l]);
diff --git a/src/live_effects/lpe-fillet-chamfer.cpp b/src/live_effects/lpe-fillet-chamfer.cpp
index 59a6324e7..dffd09ec3 100644
--- a/src/live_effects/lpe-fillet-chamfer.cpp
+++ b/src/live_effects/lpe-fillet-chamfer.cpp
@@ -338,11 +338,11 @@ void LPEFilletChamfer::doBeforeEffect(SPLPEItem const *lpeItem)
doOnApply(lpeItem);
satellites = satellites_param.data();
}
+ bool write = false;
if (_pathvector_satellites) {
size_t number_nodes = pathv.nodes().size();
size_t previous_number_nodes = _pathvector_satellites->getTotalSatellites();
if (number_nodes != previous_number_nodes) {
- Satellites satellites;
double power = radius;
if (!flexible) {
SPDocument * document = SP_ACTIVE_DOCUMENT;
@@ -367,6 +367,7 @@ void LPEFilletChamfer::doBeforeEffect(SPLPEItem const *lpeItem)
satellite.setHidden(hide_knots);
_pathvector_satellites->recalculateForNewPathVector(pathv, satellite);
satellites = _pathvector_satellites->getSatellites();
+ write = true;
}
}
if (_degenerate_hide) {
@@ -410,7 +411,7 @@ void LPEFilletChamfer::doBeforeEffect(SPLPEItem const *lpeItem)
}
_pathvector_satellites->setPathVector(pathv);
_pathvector_satellites->setSatellites(satellites);
- satellites_param.setPathVectorSatellites(_pathvector_satellites, false);
+ satellites_param.setPathVectorSatellites(_pathvector_satellites, write);
refreshKnots();
} else {
g_warning("LPE Fillet can only be applied to shapes (not groups).");
@@ -549,7 +550,7 @@ LPEFilletChamfer::doEffect_path(Geom::PathVector const &path_in)
if (time1 == time0) {
start_arc_point = curve_it1->pointAt(time0);
}
- if (time1 != 1) {
+ if (time1 != 1 && !Geom::are_near(angle,Geom::rad_from_deg(360))) {
if (time1 != time0 || (time1 == 1 && time0 == 1)) {
if (!knot_curve_1->isDegenerate()) {
tmp_path.append(*knot_curve_1);