summaryrefslogtreecommitdiffstats
path: root/src/desktop-style.cpp
diff options
context:
space:
mode:
authorDiederik van Lierop <mail@diedenrezi.nl>2011-09-05 21:32:08 +0000
committerDiederik van Lierop <mail@diedenrezi.nl>2011-09-05 21:32:08 +0000
commit45125f4504bd611ab43d9c6529b45fca81e98948 (patch)
tree73baeb9c3a0e1cb160944ddeccafa7649cd10e85 /src/desktop-style.cpp
parentFix bugs in text stroke rendering and picking (diff)
downloadinkscape-45125f4504bd611ab43d9c6529b45fca81e98948.tar.gz
inkscape-45125f4504bd611ab43d9c6529b45fca81e98948.zip
When scaling a diagonal line to a horizontal line, the strokewidth becomes NaN. This commit allows to change the strokewidth back to a more useful value (as reported by ~suv in lp:825840)
(bzr r10621)
Diffstat (limited to 'src/desktop-style.cpp')
-rw-r--r--src/desktop-style.cpp46
1 files changed, 30 insertions, 16 deletions
diff --git a/src/desktop-style.cpp b/src/desktop-style.cpp
index 1cad282b3..c08ee8677 100644
--- a/src/desktop-style.cpp
+++ b/src/desktop-style.cpp
@@ -424,14 +424,16 @@ stroke_average_width (GSList const *objects)
SPObject *object = SP_OBJECT(l->data);
- if ( object->style->stroke.isNone() ) {
+ double width = object->style->stroke_width.computed * i2dt.descrim();
+
+ if ( object->style->stroke.isNone() || isnan(width)) {
++n_notstroked; // do not count nonstroked objects
continue;
} else {
notstroked = false;
}
- avgwidth += object->style->stroke_width.computed * i2dt.descrim();
+ avgwidth += width;
}
if (notstroked)
@@ -721,18 +723,19 @@ objects_query_strokewidth (GSList *objects, SPStyle *style_res)
continue;
}
- n_stroked ++;
-
noneSet &= style->stroke.isNone();
Geom::Affine i2d = SP_ITEM(obj)->i2dt_affine();
double sw = style->stroke_width.computed * i2d.descrim();
- if (prev_sw != -1 && fabs(sw - prev_sw) > 1e-3)
- same_sw = false;
- prev_sw = sw;
+ if (!isnan(sw)) {
+ if (prev_sw != -1 && fabs(sw - prev_sw) > 1e-3)
+ same_sw = false;
+ prev_sw = sw;
- avgwidth += sw;
+ avgwidth += sw;
+ n_stroked ++;
+ }
}
if (n_stroked > 1)
@@ -945,6 +948,7 @@ objects_query_fontnumbers (GSList *objects, SPStyle *style_res)
double linespacing_prev = 0;
int texts = 0;
+ int no_size = 0;
for (GSList const *i = objects; i != NULL; i = i->next) {
SPObject *obj = SP_OBJECT (i->data);
@@ -961,7 +965,12 @@ objects_query_fontnumbers (GSList *objects, SPStyle *style_res)
}
texts ++;
- size += style->font_size.computed * Geom::Affine(SP_ITEM(obj)->i2dt_affine()).descrim(); /// \todo FIXME: we assume non-% units here
+ double dummy = style->font_size.computed * Geom::Affine(SP_ITEM(obj)->i2dt_affine()).descrim();
+ if (!isnan(dummy)) {
+ size += dummy; /// \todo FIXME: we assume non-% units here
+ } else {
+ no_size++;
+ }
if (style->letter_spacing.normal) {
if (!different && (letterspacing_prev == 0 || letterspacing_prev == letterspacing)) {
@@ -1016,7 +1025,9 @@ objects_query_fontnumbers (GSList *objects, SPStyle *style_res)
return QUERY_STYLE_NOTHING;
if (texts > 1) {
- size /= texts;
+ if (texts - no_size > 0) {
+ size /= (texts - no_size);
+ }
letterspacing /= texts;
wordspacing /= texts;
linespacing /= texts;
@@ -1444,12 +1455,15 @@ objects_query_blur (GSList *objects, SPStyle *style_res)
if(SP_IS_GAUSSIANBLUR(primitive)) {
SPGaussianBlur * spblur = SP_GAUSSIANBLUR(primitive);
float num = spblur->stdDeviation.getNumber();
- blur_sum += num * i2d.descrim();
- if (blur_prev != -1 && fabs (num - blur_prev) > 1e-2) // rather low tolerance because difference in blur radii is much harder to notice than e.g. difference in sizes
- same_blur = false;
- blur_prev = num;
- //TODO: deal with opt number, for the moment it's not necessary to the ui.
- blur_items ++;
+ float dummy = num * i2d.descrim();
+ if (!isnan(dummy)) {
+ blur_sum += dummy;
+ if (blur_prev != -1 && fabs (num - blur_prev) > 1e-2) // rather low tolerance because difference in blur radii is much harder to notice than e.g. difference in sizes
+ same_blur = false;
+ blur_prev = num;
+ //TODO: deal with opt number, for the moment it's not necessary to the ui.
+ blur_items ++;
+ }
}
}
primitive_obj = primitive_obj->next;