kwin: Simplify WindowQuadList::makeArrays()

Note that unlike the previous commit, this doesn't fix texture coordinates
for rectangular textures. That case cannot be handled correctly without
knowing the dimensions of the texture.
This commit is contained in:
Fredrik Höglund 2012-09-11 18:13:27 +02:00
parent 6891c900b3
commit a5a2561f69

View file

@ -1050,50 +1050,24 @@ void WindowQuadList::makeArrays(float** vertices, float** texcoords, const QSize
{ {
*vertices = new float[count() * 6 * 2]; *vertices = new float[count() * 6 * 2];
*texcoords = new float[count() * 6 * 2]; *texcoords = new float[count() * 6 * 2];
float *vpos = *vertices; float *vpos = *vertices;
float *tpos = *texcoords; float *tpos = *texcoords;
for (int i = 0;
i < count();
++i) {
*vpos++ = at(i)[ 1 ].x();
*vpos++ = at(i)[ 1 ].y();
*vpos++ = at(i)[ 0 ].x();
*vpos++ = at(i)[ 0 ].y();
*vpos++ = at(i)[ 3 ].x();
*vpos++ = at(i)[ 3 ].y();
*vpos++ = at(i)[ 3 ].x();
*vpos++ = at(i)[ 3 ].y();
*vpos++ = at(i)[ 2 ].x();
*vpos++ = at(i)[ 2 ].y();
*vpos++ = at(i)[ 1 ].x();
*vpos++ = at(i)[ 1 ].y();
if (yInverted) { // Note: The positions in a WindowQuad are stored in clockwise order
*tpos++ = at(i)[ 1 ].tx / size.width(); const int index[] = { 1, 0, 3, 3, 2, 1 };
*tpos++ = at(i)[ 1 ].ty / size.height();
*tpos++ = at(i)[ 0 ].tx / size.width(); for (int i = 0; i < count(); i++) {
*tpos++ = at(i)[ 0 ].ty / size.height(); const WindowQuad &quad = at(i);
*tpos++ = at(i)[ 3 ].tx / size.width();
*tpos++ = at(i)[ 3 ].ty / size.height(); for (int j = 0; j < 6; j++) {
*tpos++ = at(i)[ 3 ].tx / size.width(); const WindowVertex &wv = quad[index[j]];
*tpos++ = at(i)[ 3 ].ty / size.height();
*tpos++ = at(i)[ 2 ].tx / size.width(); *vpos++ = wv.x();
*tpos++ = at(i)[ 2 ].ty / size.height(); *vpos++ = wv.y();
*tpos++ = at(i)[ 1 ].tx / size.width();
*tpos++ = at(i)[ 1 ].ty / size.height(); *tpos++ = wv.u() / size.width();
} else { *tpos++ = yInverted ? (wv.v() / size.height()) : (1.0 - wv.v() / size.height());
*tpos++ = at(i)[ 1 ].tx / size.width();
*tpos++ = 1.0f - at(i)[ 1 ].ty / size.height();
*tpos++ = at(i)[ 0 ].tx / size.width();
*tpos++ = 1.0f - at(i)[ 0 ].ty / size.height();
*tpos++ = at(i)[ 3 ].tx / size.width();
*tpos++ = 1.0f - at(i)[ 3 ].ty / size.height();
*tpos++ = at(i)[ 3 ].tx / size.width();
*tpos++ = 1.0f - at(i)[ 3 ].ty / size.height();
*tpos++ = at(i)[ 2 ].tx / size.width();
*tpos++ = 1.0f - at(i)[ 2 ].ty / size.height();
*tpos++ = at(i)[ 1 ].tx / size.width();
*tpos++ = 1.0f - at(i)[ 1 ].ty / size.height();
} }
} }
} }