rather omit lanczos than capping windows
capping shadows is seen as bug (and is ugly and because of the non lanczos transition causes visual flicker) so if the window+shadows extends the buffer, lanczos is simply not possible. BUG: 314838 FIXED-IN: 4.11 REVIEW: 111425
This commit is contained in:
parent
674a1a051f
commit
04aa9e9531
1 changed files with 8 additions and 22 deletions
|
@ -184,28 +184,14 @@ void LanczosFilter::performPaint(EffectWindowImpl* w, int mask, QRegion region,
|
||||||
init();
|
init();
|
||||||
const QRect screenRect = Workspace::self()->clientArea(ScreenArea, w->screen(), w->desktop());
|
const QRect screenRect = Workspace::self()->clientArea(ScreenArea, w->screen(), w->desktop());
|
||||||
// window geometry may not be bigger than screen geometry to fit into the FBO
|
// window geometry may not be bigger than screen geometry to fit into the FBO
|
||||||
if (m_shader && w->width() <= screenRect.width() && w->height() <= screenRect.height()) {
|
QRect winGeo(w->expandedGeometry());
|
||||||
double left = 0;
|
if (m_shader && winGeo.width() <= screenRect.width() && winGeo.height() <= screenRect.height()) {
|
||||||
double top = 0;
|
winGeo.translate(-w->geometry().topLeft());
|
||||||
double right = w->width();
|
double left = winGeo.left();
|
||||||
double bottom = w->height();
|
double top = winGeo.top();
|
||||||
foreach (const WindowQuad & quad, data.quads) {
|
double width = winGeo.right() - left;
|
||||||
// we need this loop to include the decoration padding
|
double height = winGeo.bottom() - top;
|
||||||
left = qMin(left, quad.left());
|
|
||||||
top = qMin(top, quad.top());
|
|
||||||
right = qMax(right, quad.right());
|
|
||||||
bottom = qMax(bottom, quad.bottom());
|
|
||||||
}
|
|
||||||
double width = right - left;
|
|
||||||
double height = bottom - top;
|
|
||||||
if (width > screenRect.width() || height > screenRect.height()) {
|
|
||||||
// window with padding does not fit into the framebuffer
|
|
||||||
// so cut of the shadow
|
|
||||||
left = 0;
|
|
||||||
top = 0;
|
|
||||||
width = w->width();
|
|
||||||
height = w->height();
|
|
||||||
}
|
|
||||||
int tx = data.xTranslation() + w->x() + left * data.xScale();
|
int tx = data.xTranslation() + w->x() + left * data.xScale();
|
||||||
int ty = data.yTranslation() + w->y() + top * data.yScale();
|
int ty = data.yTranslation() + w->y() + top * data.yScale();
|
||||||
int tw = width * data.xScale();
|
int tw = width * data.xScale();
|
||||||
|
|
Loading…
Reference in a new issue