summaryrefslogtreecommitdiffstats
path: root/src/ui
diff options
context:
space:
mode:
authorTomasz Boczkowski <penginsbacon@gmail.com>2015-05-09 12:53:54 +0000
committerTomasz Boczkowski <penginsbacon@gmail.com>2015-05-09 12:53:54 +0000
commitcd9885ddc7dfbf7769f902dd7ee043892a2c8ee9 (patch)
treeb85f04d5bca6bce7590685b2b7f019805afcc7ec /src/ui
parentUsing MODE_SOLID_COLOR in paint selector instead of duplicated MODE_COLOR_RGB... (diff)
downloadinkscape-cd9885ddc7dfbf7769f902dd7ee043892a2c8ee9.tar.gz
inkscape-cd9885ddc7dfbf7769f902dd7ee043892a2c8ee9.zip
fixed crash in paint selector when changing from gradient to solid color
(bzr r14059.1.23)
Diffstat (limited to 'src/ui')
-rw-r--r--src/ui/selected-color.cpp17
-rw-r--r--src/ui/selected-color.h2
-rw-r--r--src/ui/widget/color-scales.cpp11
3 files changed, 14 insertions, 16 deletions
diff --git a/src/ui/selected-color.cpp b/src/ui/selected-color.cpp
index 7652e5acf..6573129d3 100644
--- a/src/ui/selected-color.cpp
+++ b/src/ui/selected-color.cpp
@@ -72,7 +72,7 @@ guint32 SelectedColor::value() const
return color().toRGBA32(_alpha);
}
-void SelectedColor::setColorAlpha(SPColor const &color, gfloat alpha)
+void SelectedColor::setColorAlpha(SPColor const &color, gfloat alpha, bool emit_signal)
{
#ifdef DUMP_CHANGE_INFO
g_message("SelectedColor::setColorAlpha( this=%p, %f, %f, %f, %s, %f, %s) in %s", this, color.v.c[0], color.v.c[1], color.v.c[2], (color.icc?color.icc->colorProfile.c_str():"<null>"), alpha, (emit?"YES":"no"), FOO_NAME(_csel));
@@ -100,13 +100,16 @@ void SelectedColor::setColorAlpha(SPColor const &color, gfloat alpha)
_color = color;
_alpha = alpha;
- _updating = true;
- if (_held) {
- signal_dragged.emit();
- } else {
- signal_changed.emit();
+ if (emit_signal)
+ {
+ _updating = true;
+ if (_held) {
+ signal_dragged.emit();
+ } else {
+ signal_changed.emit();
+ }
+ _updating = false;
}
- _updating = false;
#ifdef DUMP_CHANGE_INFO
} else {
diff --git a/src/ui/selected-color.h b/src/ui/selected-color.h
index 168099c82..e9e702d43 100644
--- a/src/ui/selected-color.h
+++ b/src/ui/selected-color.h
@@ -38,7 +38,7 @@ public:
void setValue(guint32 value);
guint32 value() const;
- void setColorAlpha(SPColor const &color, gfloat alpha);
+ void setColorAlpha(SPColor const &color, gfloat alpha, bool emit_signal = true);
void colorAlpha(SPColor &color, gfloat &alpha) const;
void setHeld(bool held);
diff --git a/src/ui/widget/color-scales.cpp b/src/ui/widget/color-scales.cpp
index 5fa5af902..ead636406 100644
--- a/src/ui/widget/color-scales.cpp
+++ b/src/ui/widget/color-scales.cpp
@@ -376,8 +376,8 @@ void ColorScales::setMode(SPColorScalesMode mode)
setScaled(_a[1], rgba[1]);
setScaled(_a[2], rgba[2]);
setScaled(_a[3], rgba[3]);
- _updating = FALSE;
_updateSliders(CSC_CHANNELS_ALL);
+ _updating = FALSE;
break;
case SP_COLOR_SCALES_MODE_HSV:
_setRangeLimit(255.0);
@@ -404,8 +404,8 @@ void ColorScales::setMode(SPColorScalesMode mode)
setScaled(_a[1], c[1]);
setScaled(_a[2], c[2]);
setScaled(_a[3], rgba[3]);
- _updating = FALSE;
_updateSliders(CSC_CHANNELS_ALL);
+ _updating = FALSE;
break;
case SP_COLOR_SCALES_MODE_CMYK:
_setRangeLimit(100.0);
@@ -437,8 +437,8 @@ void ColorScales::setMode(SPColorScalesMode mode)
setScaled(_a[3], c[3]);
setScaled(_a[4], rgba[3]);
- _updating = FALSE;
_updateSliders(CSC_CHANNELS_ALL);
+ _updating = FALSE;
break;
default:
g_warning("file %s: line %d: Illegal color selector mode", __FILE__, __LINE__);
@@ -607,11 +607,6 @@ void ColorScales::_updateSliders(guint channels)
break;
}
- // Force the internal color to be updated
- if (!_updating) {
- _recalcColor();
- }
-
#ifdef SPCS_PREVIEW
rgba = sp_color_scales_get_rgba32(cs);
sp_color_preview_set_rgba32(SP_COLOR_PREVIEW(_p), rgba);