<br><br><div class="gmail_quote">On Fri, Apr 9, 2010 at 2:04 PM, Cyrille Berger <span dir="ltr"><<a href="mailto:cberger@cberger.net">cberger@cberger.net</a>></span> wrote:<br><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
<div class="im">On Wednesday 24 March 2010, Dmitry Kazakov wrote:<br>
> Hmm.. I've added these functions just recently:<br>
> <a href="http://websvn.kde.org/?view=revision&revision=1099644" target="_blank">http://websvn.kde.org/?view=revision&revision=1099644</a><br>
><br>
> The logic was the following:<br>
><br>
> extent() - is the area where the node has an influence on the result image.<br>
> In other words, it is an area, where we should update when the layer<br>
> changes it's visibility.<br>
><br>
> KisMask::extent() - works right this way. It tells the area, where<br>
> selection is. And this is right for most of the masks, except of the<br>
> transparency mask. A transparency mask changes the entire image, except of<br>
> the selection. It means that we should update everywhere, except of the<br>
> selection. And if we don't have parent, we can't do anything.<br>
<br>
</div>Btw, shouldn't that be:<br>
<br>
QRect KisTransparencyMask::extent() const<br>
{<br>
return parent() ? parent()->extent().intersect(selection().extent()) :<br>
QRect();<br>
}<br>
<br>
QRect KisTransparencyMask::exactBounds() const<br>
{<br>
return parent() ? parent()-<br>
>exactBounds().intersect(selection().exactBounds()) : QRect();<br>
}<br>
<br>
(which would be true for all masks, no ?)<br></blockquote><div><br>It is true for all the masks, except a transparency mask. The transparency mask is special, because it influences the entire image. It removes *all* the image's content and paint's it's selection on the top.<br>
<br>If you change transparency mask extent back, there will be a bug showing that: the image will be updated wrongly after you switch off/on visibility of the transparency mask.<br></div></div><br clear="all"><br>-- <br>Dmitry Kazakov<br>