diff options
| author | Joshua L. Blocher <verbalshadow@gmail.com> | 2006-05-17 04:04:50 +0000 |
|---|---|---|
| committer | verbalshadow <verbalshadow@users.sourceforge.net> | 2006-05-17 04:04:50 +0000 |
| commit | 6ae30c84dcc569c271177dca89efa5929e381b82 (patch) | |
| tree | d83571abc4f47fd4d09c9fc16f954e68b187ad97 /src | |
| parent | Switched icons to stock generic. (diff) | |
| download | inkscape-6ae30c84dcc569c271177dca89efa5929e381b82.tar.gz inkscape-6ae30c84dcc569c271177dca89efa5929e381b82.zip | |
Fixes calligraphy tool so drawing now uses the the correct opacity.
(bzr r861)
Diffstat (limited to 'src')
| -rw-r--r-- | src/desktop-style.cpp | 30 | ||||
| -rw-r--r-- | src/desktop-style.h | 4 |
2 files changed, 31 insertions, 3 deletions
diff --git a/src/desktop-style.cpp b/src/desktop-style.cpp index 58209aaa3..afb3a1045 100644 --- a/src/desktop-style.cpp +++ b/src/desktop-style.cpp @@ -5,8 +5,9 @@ * * Authors: * bulia byak + * verbalshadow * - * Copyright (C) 2004 authors + * Copyright (C) 2004, 2006 authors * * Released under GNU GPL, read the file 'COPYING' for more information */ @@ -14,6 +15,7 @@ #include "desktop.h" #include "color-rgba.h" #include "svg/css-ostringstream.h" +#include "svg/svg.h" #include "svg/svg-color.h" #include "selection.h" #include "sp-tspan.h" @@ -31,6 +33,7 @@ #include "xml/repr.h" #include "libnrtype/font-style-to-pos.h" + #include "desktop-style.h" /** @@ -218,11 +221,34 @@ sp_desktop_get_color(SPDesktop *desktop, bool is_fill) return r; } +double +sp_desktop_get_opacity_tool(SPDesktop *desktop, char const *tool, bool op) +{ + SPCSSAttr *css = NULL; + gfloat value = 1.0; // default if nothing else found + if (prefs_get_double_attribute(tool, "usecurrent", 0) != 0) { + css = sp_desktop_get_style(desktop, op); + } else { + Inkscape::XML::Node *tool_repr = inkscape_get_repr(INKSCAPE, tool); + css = sp_repr_css_attr_inherited(tool_repr, "style"); + } + + gchar const *property = css ? sp_repr_css_property(css, "opacity", "1.000") : 0; + + if (desktop->current && property) { // if there is style and the property in it, + if ( !sp_svg_number_read_f(property, &value) ) { + value = 1.0; // things failed. set back to the default + } + } + return value; +} guint32 sp_desktop_get_color_tool(SPDesktop *desktop, char const *tool, bool is_fill) { SPCSSAttr *css = NULL; guint32 r = 0; // if there's no color, return black + bool op = true; + double opacity = sp_desktop_get_opacity_tool(SP_ACTIVE_DESKTOP, "tools.calligraphic", op); if (prefs_get_int_attribute(tool, "usecurrent", 0) != 0) { css = sp_desktop_get_style(desktop, is_fill); } else { @@ -238,7 +264,7 @@ sp_desktop_get_color_tool(SPDesktop *desktop, char const *tool, bool is_fill) r = sp_svg_read_color(property, r); } } - return r | 0xff; + return r | SP_COLOR_F_TO_U( opacity ); // return RGBA color } /** * Apply the desktop's current style or the tool style to repr. diff --git a/src/desktop-style.h b/src/desktop-style.h index 9f080648a..cec36aca5 100644 --- a/src/desktop-style.h +++ b/src/desktop-style.h @@ -6,8 +6,9 @@ * * Authors: * bulia byak + * verbalshadow * - * Copyright (C) 2004 authors + * Copyright (C) 2004, 2006 authors * * Released under GNU GPL, read the file 'COPYING' for more information */ @@ -53,6 +54,7 @@ void sp_desktop_set_color(SPDesktop *desktop, ColorRGBA const &color, bool is_re void sp_desktop_set_style(SPDesktop *desktop, SPCSSAttr *css, bool change = true, bool write_current = true); SPCSSAttr *sp_desktop_get_style(SPDesktop *desktop, bool with_text); guint32 sp_desktop_get_color (SPDesktop *desktop, bool is_fill); +double sp_desktop_get_opacity_tool(SPDesktop *desktop, char const *tool, bool op); guint32 sp_desktop_get_color_tool(SPDesktop *desktop, char const *tool, bool is_fill); double sp_desktop_get_font_size_tool (SPDesktop *desktop); void sp_desktop_apply_style_tool(SPDesktop *desktop, Inkscape::XML::Node *repr, char const *tool, bool with_text); |
