Review Request: Plasma::Svg: Do not require exact match for size hinted elements.
Ingomar Wesp
ingomar at wesp.name
Tue Oct 26 01:28:53 CEST 2010
> On 2010-10-25 20:43:20, Marco Martin wrote:
> > /trunk/KDE/kdelibs/plasma/svg.cpp, line 259
> > <http://svn.reviewboard.kde.org/r/5689/diff/3/?file=40220#file40220line259>
> >
> > this creates a renderer too often.
> > since the purpose of the cache is avoid to create renderers this is not good
>
> Manuel Mommertz wrote:
> Right, but this is solvable by inserting the size hints in SvgPrivate::localRectCache.
> Right, but this is solvable by inserting the size hints in SvgPrivate::localRectCache.
To be honest, I'm not sure I understand the cache related code well enough, so please be patient with me here...
>From what I (think I) understand, you intend to move the search for the best fit to SvgPrivate::findAndCacheElementRect and insert it into the theme's rect cache? Because if I'm not mistaken, just adding it to the localRectCache would not allow the entry to be persisted and would thus not help prevent the creation of a renderer in the future.
- Ingomar
-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
http://svn.reviewboard.kde.org/r/5689/#review8349
-----------------------------------------------------------
On 2010-10-25 15:29:32, Ingomar Wesp wrote:
>
> -----------------------------------------------------------
> This is an automatically generated e-mail. To reply, visit:
> http://svn.reviewboard.kde.org/r/5689/
> -----------------------------------------------------------
>
> (Updated 2010-10-25 15:29:32)
>
>
> Review request for Plasma.
>
>
> Summary
> -------
>
> Previously, if an SVG contained size hinted elements, they were only used when the display size matched the size hint exactly. This patch tries to relax this condition by searching for the smallest size hinted element that is still bigger than the display size (in order for the element to be chosen, it also has to have the same aspect ratio). If no such element can be found, it falls back to the normal element id as passed.
>
> In order to speed up the lookup (and because it appears to be impossible to access the DOM of an already loaded SvgRenderer), all size hinted element ids are stored in SharedSvgRenderer at load time.
>
> I think it would be good to change the QRegExp based id fetching into a proper DOM traversal. Are there any convenience functions in KDELibs that allow easy iterating over all elements (couldn't find any) or do I have to implement that myself based on Qt's DOM classes?
>
> Please tell me what you think... Have I missed something?
>
>
> Diffs
> -----
>
> /trunk/KDE/kdelibs/plasma/private/svg_p.h 1189690
> /trunk/KDE/kdelibs/plasma/svg.cpp 1189690
>
> Diff: http://svn.reviewboard.kde.org/r/5689/diff
>
>
> Testing
> -------
>
>
> Thanks,
>
> Ingomar
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://mail.kde.org/pipermail/plasma-devel/attachments/20101025/31454726/attachment.html
More information about the Plasma-devel
mailing list