diff options
49 files changed, 5 insertions, 5227 deletions
diff --git a/src/declarative/canvas/canvas.pri b/src/declarative/canvas/canvas.pri index 9bdd3fa..28cab9b 100644 --- a/src/declarative/canvas/canvas.pri +++ b/src/declarative/canvas/canvas.pri @@ -1,19 +1,14 @@ SOURCES += \ canvas/qsimplecanvas.cpp \ canvas/qsimplecanvasitem.cpp \ - canvas/qsimplecanvasfilter.cpp \ - canvas/qsimplecanvasdebugplugin.cpp + canvas/qsimplecanvasdebugplugin.cpp \ + canvas/qsimplecanvas_software.cpp \ + canvas/qsimplecanvas_graphicsview.cpp HEADERS += \ canvas/qsimplecanvas.h \ canvas/qsimplecanvasitem.h \ - canvas/qsimplecanvasfilter.h \ canvas/qsimplecanvas_p.h \ canvas/qsimplecanvasitem_p.h \ - canvas/qsimplecanvasfilter_p.h \ canvas/qsimplecanvasdebugplugin_p.h -contains(QT_CONFIG, opengles2): SOURCES += canvas/qsimplecanvas_opengl.cpp -else:contains(QT_CONFIG, opengles1): SOURCES += canvas/qsimplecanvas_opengl1.cpp -else:SOURCES += canvas/qsimplecanvas_software.cpp -SOURCES += canvas/qsimplecanvas_graphicsview.cpp diff --git a/src/declarative/canvas/qsimplecanvas.cpp b/src/declarative/canvas/qsimplecanvas.cpp index cb46f94..cbbc26d 100644 --- a/src/declarative/canvas/qsimplecanvas.cpp +++ b/src/declarative/canvas/qsimplecanvas.cpp @@ -49,9 +49,6 @@ #include "qtimer.h" #include "qdatetime.h" #include "qgraphicssceneevent.h" -#if defined(QFX_RENDER_OPENGL) -#include <glheaders.h> -#endif #include "qboxlayout.h" #include "qsimplecanvasdebugplugin_p.h" #include "qsimplecanvas.h" @@ -601,13 +598,6 @@ void QSimpleCanvasPrivate::init(QSimpleCanvas::CanvasMode mode) view->scene()->setItemIndexMethod(QGraphicsScene::NoIndex); view->viewport()->setFocusPolicy(Qt::NoFocus); } - -#if defined(QFX_RENDER_OPENGL) && defined(Q_WS_X11) - QTimer *t = new QTimer(q); - t->setInterval(200); - QObject::connect(t, SIGNAL(timeout()), &egl, SLOT(updateGL())); - t->start(); -#endif } QSimpleCanvas::~QSimpleCanvas() @@ -795,9 +785,6 @@ bool QSimpleCanvas::focusNextPrevChild(bool) void QSimpleCanvas::showEvent(QShowEvent *e) { -#if defined(QFX_RENDER_OPENGL) - d->egl.resize(width(), height()); -#endif if (d->isGraphicsView()) d->view->setSceneRect(rect()); @@ -806,9 +793,6 @@ void QSimpleCanvas::showEvent(QShowEvent *e) void QSimpleCanvas::resizeEvent(QResizeEvent *e) { -#if defined(QFX_RENDER_OPENGL) - d->egl.resize(width(), height()); -#endif if (d->isGraphicsView()) d->view->setSceneRect(rect()); QWidget::resizeEvent(e); @@ -833,21 +817,6 @@ void QSimpleCanvas::addDirty(QSimpleCanvasItem *c) Q_ASSERT(d->isSimpleCanvas()); queueUpdate(); d->oldDirty |= c->d_func()->data()->lastPaintRect; -#if defined(QFX_RENDER_OPENGL) - // ### Is this parent crawl going to be a problem for scenes with nots - // of things changing? - // Check for filters - QSimpleCanvasItem *fi = c->parent(); - while(fi) { - if (fi->d_func()->data()->dirty) { - break; - } else if (fi->filter()) { - fi->update(); - break; - } - fi = fi->parent(); - } -#endif d->dirtyItems.append(c); } @@ -855,15 +824,8 @@ QRect QSimpleCanvasPrivate::dirtyItemClip() const { QRect rv; if (isSimpleCanvas()) { -#if defined(QFX_RENDER_OPENGL) - QRectF r; - for (int ii = 0; ii < dirtyItems.count(); ++ii) - r |= dirtyItems.at(ii)->d_func()->data()->lastPaintRect; - rv = egl.map(r); -#else for (int ii = 0; ii < dirtyItems.count(); ++ii) rv |= dirtyItems.at(ii)->d_func()->data()->lastPaintRect; -#endif } return rv; } @@ -871,11 +833,7 @@ QRect QSimpleCanvasPrivate::dirtyItemClip() const QRect QSimpleCanvasPrivate::resetDirty() { if (isSimpleCanvas()) { -#if defined(QFX_RENDER_OPENGL) - QRect r = egl.map(oldDirty) | dirtyItemClip(); -#else QRect r = oldDirty | dirtyItemClip(); -#endif if (!r.isEmpty()) r.adjust(-1,-1,2,2); //make sure we get everything (since we rounded from floats to ints) for (int ii = 0; ii < dirtyItems.count(); ++ii) @@ -918,37 +876,16 @@ bool QSimpleCanvas::event(QEvent *e) int tbf = d->frameTimer.restart(); d->timer = 0; d->isSetup = true; -#if defined(QFX_RENDER_OPENGL1) - unsigned int zero = 0; - d->root->d_func()->setupPainting(0, rect(), &zero); -#elif defined(QFX_RENDER_OPENGL2) - ++d->paintVersion; - d->opaqueList = 0; - int z = 0; - d->root->d_func()->setupPainting(0, z, &d->opaqueList); -#else ++d->paintVersion; d->root->d_func()->setupPainting(0, rect()); -#endif QRect r = d->resetDirty(); -#if defined(QFX_RENDER_QPAINTER) if (r.isEmpty() || fullUpdate()) repaint(); else repaint(r); emit framePainted(); -#else - - QRect nr(r.x(), height() - r.y() - r.height(), r.width(), r.height()); - - if (r.isEmpty() || fullUpdate()) - d->egl.updateGL(); - else - d->egl.updateGL(nr); - emit framePainted(); -#endif d->isSetup = false; int frametimer = d->frameTimer.elapsed(); @@ -1016,14 +953,10 @@ void QSimpleCanvas::checkState() QImage QSimpleCanvas::asImage() const { if (d->isSimpleCanvas()) { -#if defined(QFX_RENDER_QPAINTER) QImage img(width(),height(),QImage::Format_RGB32); QPainter p(&img); const_cast<QSimpleCanvas*>(this)->d->paint(p); return img; -#elif defined(QFX_RENDER_OPENGL) - return d->egl.grabFrameBuffer(); -#endif } else { QImage img(width(),height(),QImage::Format_RGB32); QPainter p(&img); diff --git a/src/declarative/canvas/qsimplecanvas.h b/src/declarative/canvas/qsimplecanvas.h index 1cbd3c7..b9f8ddb 100644 --- a/src/declarative/canvas/qsimplecanvas.h +++ b/src/declarative/canvas/qsimplecanvas.h @@ -44,10 +44,6 @@ #include <QtDeclarative/qfxglobal.h> -#ifdef QFX_RENDER_OPENGL -#include <QtGui/qmatrix4x4.h> -#endif - #include <QtGui/QTransform> #include <QtGui/QPainter> #include <QtCore/QDebug> @@ -65,42 +61,18 @@ namespace QSimpleCanvasConfig { enum ImageType { Opaque, Translucent }; -#ifdef QFX_RENDER_OPENGL - typedef QMatrix4x4 Matrix; - typedef QImage Image; - - inline Matrix transformToMatrix(const QTransform &) - { - return Matrix(); // XXX - } - inline QTransform matrixToTransform(const Matrix &) - { - return QTransform(); // XXX - } - inline bool needConvert(ImageType, const Image &) - { return false; } - inline Image convert(ImageType, const Image &i) - { return i; } - inline Image create(const QSize &s) - { return QImage(s, QImage::Format_ARGB32); } - inline const Image &toImage(const QImage &i) - { return i; } - -#elif defined(QFX_RENDER_QPAINTER) typedef QTransform Matrix; inline Matrix transformToMatrix(const QTransform &t) { return t; } inline QTransform matrixToTransform(const Matrix &t) { return t; } -#endif } class QSimpleCanvas; class QSimpleCanvasLayer; class QGraphicsSceneMouseEvent; -class GLBasicShaders; class QSimpleCanvasItem; class QSimpleCanvasPrivate; class Q_DECLARATIVE_EXPORT QSimpleCanvas : public QWidget @@ -157,7 +129,6 @@ private: friend class QSimpleCanvasPrivate; friend class QSimpleCanvasItem; friend class QSimpleCanvasItemPrivate; - friend class QSimpleCanvasFilter; friend class QSimpleGraphicsItem; void queueUpdate(); diff --git a/src/declarative/canvas/qsimplecanvas_opengl.cpp b/src/declarative/canvas/qsimplecanvas_opengl.cpp deleted file mode 100644 index 7969a2a..0000000 --- a/src/declarative/canvas/qsimplecanvas_opengl.cpp +++ /dev/null @@ -1,680 +0,0 @@ -/**************************************************************************** -** -** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies). -** Contact: Qt Software Information (qt-info@nokia.com) -** -** This file is part of the QtDeclarative module of the Qt Toolkit. -** -** $QT_BEGIN_LICENSE:LGPL$ -** No Commercial Usage -** This file contains pre-release code and may not be distributed. -** You may use this file in accordance with the terms and conditions -** contained in the either Technology Preview License Agreement or the -** Beta Release License Agreement. -** -** GNU Lesser General Public License Usage -** Alternatively, this file may be used under the terms of the GNU Lesser -** General Public License version 2.1 as published by the Free Software -** Foundation and appearing in the file LICENSE.LGPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU Lesser General Public License version 2.1 requirements -** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. -** -** In addition, as a special exception, Nokia gives you certain -** additional rights. These rights are described in the Nokia Qt LGPL -** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this -** package. -** -** GNU General Public License Usage -** Alternatively, this file may be used under the terms of the GNU -** General Public License version 3.0 as published by the Free Software -** Foundation and appearing in the file LICENSE.GPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU General Public License version 3.0 requirements will be -** met: http://www.gnu.org/copyleft/gpl.html. -** -** If you are unsure which license is appropriate for your use, please -** contact the sales department at qt-sales@nokia.com. -** $QT_END_LICENSE$ -** -****************************************************************************/ - -#include "qsimplecanvas.h" -#include "qsimplecanvas_p.h" -#include "qsimplecanvasitem_p.h" -#include "qsimplecanvasfilter_p.h" -#include <glsave.h> -#include <QtOpenGL/qglframebufferobject.h> -#include <gltexture.h> -#include <math.h> - - -QT_BEGIN_NAMESPACE -void CanvasEGLWidget::paintGL() -{ - glClearColor(0.0f, 0.0f, 0.0f, 1.0f); - glClear(GL_COLOR_BUFFER_BIT | GL_STENCIL_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - - _canvas->paintGL(); -} - -void CanvasEGLWidget::updateGL() -{ - _clip = QRect(); - QGLWidget::updateGL(); -} - -void CanvasEGLWidget::updateGL(const QRect &r) -{ - if (r.isEmpty()) - return; - - _clip = r; - QGLWidget::updateGL(); -} - -void CanvasEGLWidget::resizeGL(int w, int h) -{ - glViewport(0, 0, w, h); -} - -QRect CanvasEGLWidget::map(const QRectF &f) const -{ - return invDefaultTransform.mapRect(f).toAlignedRect(); -} - -void CanvasEGLWidget::resizeEvent(QResizeEvent *e) -{ - defaultTransform.setIdentity(); - defaultTransform.flipCoordinates(); - defaultTransform.translate(-1, -1, 0); - defaultTransform.scale(2. / width(), 2. / height(), 1. / (1024. * 1024.)); - invDefaultTransform = defaultTransform.inverted(); - _canvas->root->d_func()->data()->transformActive = defaultTransform; - _canvas->root->d_func()->data()->transformValid = true; - - QGLWidget::resizeEvent(e); -} - -void CanvasEGLWidget::initializeGL() -{ - glEnable(GL_BLEND); - glEnable(GL_STENCIL_TEST); - glBlendFuncSeparate(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA, - GL_ONE, GL_ONE_MINUS_SRC_ALPHA); - - glStencilFunc(GL_EQUAL, 0, 0xFFFFFFFF); - glStencilOp(GL_KEEP, GL_KEEP, GL_KEEP); -} - -void QSimpleCanvasPrivate::paintGL() -{ - lrpTimer.start(); - - QSimpleCanvasItemPrivate::GLPaintParameters p; - QSimpleCanvasItem::GLPainter painter; - - p.sceneRect = QRect(0, 0, q->width(), q->height()); - p.clipRect = p.sceneRect; - p.stencilValue = 0; - p.opacity = 1; - p.forceParamRefresh = false; - p.painter = &painter; - if (!isSetup) { - opaqueList = 0; - int z = 0; - root->d_func()->setupPainting(0, z, &opaqueList); - } - - glEnable(GL_DEPTH_TEST); - - glDisable(GL_BLEND); - painter.blendEnabled = false; - painter.activeOpacity = 1; - while (opaqueList) { - painter.item = opaqueList; - painter.activeTransform = opaqueList->d_func()->data()->transformActive; - // ### - I don't think this is right - painter.sceneClipRect = p.clipRect; - - opaqueList->paintGLContents(painter); - opaqueList = opaqueList->d_func()->nextOpaque; - } - glEnable(GL_BLEND); - painter.blendEnabled = true; - - root->d_func()->paint(p); - - lrpTime = lrpTimer.elapsed(); -} - -QGLFramebufferObject *QSimpleCanvasPrivate::acquire(int w, int h) -{ - if (w <= 0 || h <= 0) - return 0; - - int size = qMax(w, h); - for (int ii = 0; ii < frameBuffers.count(); ++ii) { - if (frameBuffers.at(ii)->width() >= size) { - QGLFramebufferObject *rv = frameBuffers.at(ii); - frameBuffers.removeAt(ii); - return rv; - } - } - - // Find power of two - size--; - size |= size >> 1; - size |= size >> 2; - size |= size >> 4; - size |= size >> 8; - size |= size >> 16; - size++; - - QGLFramebufferObject *fbo = new QGLFramebufferObject(size, size); - return fbo; -} - -void QSimpleCanvasPrivate::release(QGLFramebufferObject *buf) -{ - int size = qMax(buf->width(), buf->height()); - for (int ii = 0; ii < frameBuffers.count(); ++ii) { - if (frameBuffers.at(ii)->width() >= size) { - frameBuffers.insert(ii, buf); - return; - } - } - frameBuffers.append(buf); -} - -GLBasicShaders *QSimpleCanvasItemPrivate::basicShaders() const -{ - return canvas->d->basicShaders(); -} - -QSimpleCanvas::Matrix QSimpleCanvasItemPrivate::localTransform() const -{ - Q_Q(const QSimpleCanvasItem); - - QSimpleCanvas::Matrix trans; - trans.translate(q->x(), q->y()); - QPointF to = transformOrigin(); - trans.translate(to.x(), to.y()); - trans.scale(q->scale(), q->scale()); - trans.translate(-to.x(), -to.y()); - if (data()->transformUser) - trans *= *data()->transformUser; - return trans; -} - -void QSimpleCanvasItemPrivate::simplePaintChild(const GLPaintParameters ¶ms, QSimpleCanvasItem *child) -{ - Q_Q(QSimpleCanvasItem); - - GLPaintParameters childParams = params; - if (clip) - ++childParams.stencilValue; - - if (child->d_func()->data()->activeOpacity != 0) { - childParams.boundingRect = child->boundingRect(); - - if (child->filter() && child->filter()->enabled()) { - QSimpleCanvasItem::GLPainter &painter = *params.painter; - painter.item = q; - painter.activeTransform = child->d_func()->data()->transformActive; - painter.activeOpacity = child->d_func()->data()->activeOpacity; - painter.sceneClipRect = params.clipRect; - child->filter()->d->doFilterGL(painter, childParams); - } else { - child->d_func()->paint(childParams); - } - } -} - -void QSimpleCanvasItemPrivate::paintChild(const GLPaintParameters ¶ms, - QSimpleCanvasItem *child) -{ - if (params.forceParamRefresh) { - QSimpleCanvas::Matrix t = child->d_func()->data()->transformActive; - qreal o = child->d_func()->data()->activeOpacity; - setupChildState(child); - simplePaintChild(params, child); - child->d_func()->data()->transformActive = t; - child->d_func()->data()->transformValid = true; - child->d_func()->data()->activeOpacity = o; - } else { - simplePaintChild(params, child); - } -} - -void QSimpleCanvasItemPrivate::setupChildState(QSimpleCanvasItem *child) -{ - QSimpleCanvasItemData *const myData = data(); - QSimpleCanvasItemPrivate *const childPrivate = child->d_func(); - QSimpleCanvasItemData *const childData = childPrivate->data(); - - childData->activeOpacity = myData->activeOpacity; - if (childData->visible != 1.) - childData->activeOpacity *= childData->visible; - - if (childData->activeOpacity != 0.) { - QSimpleCanvas::Matrix &am = childData->transformActive; - am = myData->transformActive; - - // Calculate child's transform - const qreal x = childData->x; - const qreal y = childData->y; - const qreal scale = childPrivate->scale; - QSimpleCanvasItem::Flip flip = childData->flip; - - if (x != 0. || y != 0.) - am.translate(x, y); - - if (scale != 1.) { - if (childPrivate->origin == QSimpleCanvasItem::TopLeft) { - am.scale(scale, scale); - } else { - QPointF to = childPrivate->transformOrigin(); - am.translate(to.x(), to.y()); - am.scale(scale, scale); - am.translate(-to.x(), -to.y()); - } - } - - if (childData->transformUser) - am *= *childData->transformUser; - if (flip) { - QRectF br = child->boundingRect(); - am.translate(br.width() / 2., br.height() / 2); - am.rotate(180, (flip & QSimpleCanvasItem::VerticalFlip)?1:0, (flip & QSimpleCanvasItem::HorizontalFlip)?1:0, 0); - am.translate(-br.width() / 2., -br.height() / 2); - } - - childData->transformValid = true; - } -} - -#define QSIMPLECANVAS_DISABLE_TREE_CLIPPING -QRectF QSimpleCanvasItemPrivate::setupPainting(int version, int &z, QSimpleCanvasItem **opaqueList) -{ - static QRectF scene(-1., -1., 2., 2.); - Q_Q(QSimpleCanvasItem); - - bool hasContents = options & QSimpleCanvasItem::HasContents; - - QSimpleCanvasItemData *myData = data(); - - QRectF rv; - if (hasContents) { - QRectF filteredBoundRect = q->boundingRect(); - if (filter) - filteredBoundRect = filter->itemBoundingRect(filteredBoundRect); - const QMatrix4x4 &active = myData->transformActive; - - rv = active.mapRect(filteredBoundRect); - } -#ifdef QSIMPLECANVAS_DISABLE_TREE_CLIPPING - myData->doNotPaint = false; - myData->doNotPaintChildren = false; -#else - myData->doNotPaint = !hasContents || !rv.intersects(scene); - myData->doNotPaintChildren = hasContents && myData->doNotPaint && - (clip != QSimpleCanvasItem::NoClip); -#endif - - if (!myData->doNotPaint && - (options & QSimpleCanvasItem::IsOpaque) && - (myData->activeOpacity == 1.) && - (clip == 0)) { - - nextOpaque = *opaqueList; - *opaqueList = q; - myData->doNotPaint = true; - - } - - int myZ = z++; - - if (myData->doNotPaintChildren) { - rv = QRectF(); - } else { - zOrderChildren(); - - for (int ii = 0; ii < children.count(); ++ii) { - QSimpleCanvasItem *child = children.at(ii); - setupChildState(child); - - QSimpleCanvasItemData *childData = child->d_func()->data(); - if (childData->activeOpacity != 0) - rv |= child->d_func()->setupPainting(version, z, opaqueList); - } - -#ifndef QSIMPLECANVAS_DISABLE_TREE_CLIPPING - myData->doNotPaintChildren |= !rv.intersects(scene); -#endif - } - - myData->transformActive.translate(0, 0, myZ); - - myData->lastPaintRect = rv; - - return rv; -} - - -void QSimpleCanvasItemPrivate::paint(GLPaintParameters &oldParams, QSimpleCanvasFilter::Layer layer) -{ - if (!layer) - return; - - Q_Q(QSimpleCanvasItem); - - bool doNotPaintChildren = data()->doNotPaintChildren; - if (doNotPaintChildren) - return; - - GLPaintParameters params = oldParams; - - qreal width = params.boundingRect.width(); - qreal height = params.boundingRect.height(); - - GLfloat vertices[] = { 0, height, - width, height, - 0, 0, - width, 0 }; - - // XXX Handle separate cliping modes - if (clip) { - if (params.stencilValue == 255) - qWarning() - << "OpenGL: Clip recursion greater than 255 not permitted."; - glColorMask(GL_FALSE, GL_FALSE, GL_FALSE, GL_FALSE); - - glStencilFunc(GL_EQUAL, params.stencilValue, 0xFFFFFFFF); - glStencilOp(GL_KEEP, GL_KEEP, GL_INCR); - - ConstantColorShader *shader = basicShaders()->constantColor(); - params.painter->invalidate(); - shader->enable(); - shader->setTransform(data()->transformActive); - - shader->setAttributeArray(ConstantColorShader::Vertices, vertices, 2); - glDrawArrays(GL_TRIANGLE_STRIP, 0, 4); - - glStencilFunc(GL_EQUAL, params.stencilValue + 1, 0xFFFFFFFF); - glStencilOp(GL_KEEP, GL_KEEP, GL_KEEP); - - glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE); - - // XXX Copied from qsimplecanvas_opengl1 scissor based clipping - QRectF r = data()->transformActive.mapRect(params.boundingRect); - r.translate(1, 1); - float xscale = 0.5 * float(params.sceneRect.width()); - float yscale = 0.5 * float(params.sceneRect.height()); - r.moveTo(r.x() * xscale, r.y() * yscale); - r.setSize(QSizeF(r.width() * xscale, r.height() * yscale)); - int sr_x = int(::floorf(r.x())); - int sr_y = int(::floorf(r.y())); - int sr_width = int(::ceilf(r.right())) - sr_x; - int sr_height = int(::ceilf(r.bottom())) - sr_y; - QRect sr(sr_x, sr_y, sr_width, sr_height); - sr.moveTo(sr.x(), params.sceneRect.height() - sr.y() - sr.height()); - sr &= params.clipRect; - params.clipRect = sr; - } - - int upto = 0; - for (upto = 0; upto < children.count(); ++upto) { - QSimpleCanvasItem *c = children.at(upto); - if (c->z() < 0) { - if (layer & QSimpleCanvasFilter::ChildrenUnderItem) - paintChild(params, c); - } else { - break; - } - } - - bool doNotPaint = data()->doNotPaint; - - if (!doNotPaint && layer & QSimpleCanvasFilter::Item) { - QSimpleCanvasItem::GLPainter &painter = *params.painter; - painter.item = q; - painter.activeTransform = data()->transformActive; - painter.activeOpacity = data()->activeOpacity; - painter.sceneClipRect = params.clipRect; - - q->paintGLContents(painter); - } - - if (layer & QSimpleCanvasFilter::ChildrenAboveItem) { - for (; upto < children.count(); ++upto) { - QSimpleCanvasItem *c = children.at(upto); - paintChild(params, c); - } - } - - if (clip) { - glColorMask(GL_FALSE, GL_FALSE, GL_FALSE, GL_FALSE); - glStencilFunc(GL_EQUAL, params.stencilValue + 1, 0xFFFFFFFF); - glStencilOp(GL_KEEP, GL_KEEP, GL_DECR); - - params.painter->invalidate(); - ConstantColorShader *shader = basicShaders()->constantColor(); - shader->enable(); - shader->setTransform(data()->transformActive); - - shader->setAttributeArray(ConstantColorShader::Vertices, vertices, 2); - glDrawArrays(GL_TRIANGLE_STRIP, 0, 4); - - glStencilFunc(GL_EQUAL, params.stencilValue, 0xFFFFFFFF); - glStencilOp(GL_KEEP, GL_KEEP, GL_KEEP); - glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE); - } -} - -enum ShaderType { ST_None, ST_SingleTexture, ST_SingleTextureOpacity, ST_Color }; - -QSimpleCanvasItem::GLPainter::GLPainter() -: item(0), activeOpacity(1), blendEnabled(true), flags(0) -{ -} - -QSimpleCanvasItem::GLPainter::GLPainter(QSimpleCanvasItem *i) -: item(i), activeOpacity(1), blendEnabled(true), flags(0) -{ -} - -QGLShaderProgram *QSimpleCanvasItem::GLPainter::useTextureShader() -{ - if (activeOpacity == 1.) { - SingleTextureShader *shader = item->basicShaders()->singleTexture(); - if (flags != ST_SingleTexture) { - shader->enable(); - flags = ST_SingleTexture; - } - - shader->setTransform(activeTransform); - return shader; - } else { - SingleTextureOpacityShader *shader = item->basicShaders()->singleTextureOpacity(); - - if (flags != ST_SingleTextureOpacity) { - shader->enable(); - flags = ST_SingleTextureOpacity; - } - - shader->setTransform(activeTransform); - shader->setOpacity(activeOpacity); - return shader; - } -} - -void QSimpleCanvasItem::GLPainter::invalidate() -{ - flags = ST_None; -} - -QGLShaderProgram *QSimpleCanvasItem::GLPainter::useColorShader(const QColor &color) -{ - QColor c = color; - - ConstantColorShader *shader = item->basicShaders()->constantColor(); - - if (flags != ST_Color) { - shader->enable(); - flags = ST_Color; - } - - if (activeOpacity != 1.) - c.setAlpha(int(c.alpha() * activeOpacity)); - - shader->setColor(c); - shader->setTransform(activeTransform); - - return shader; -} - -void QSimpleCanvasItem::GLPainter::drawPixmap(const QPointF &point, - const GLTexture &texture) -{ - drawPixmap(QRectF(point, QSizeF(texture.width(), texture.height())), texture); -} - -void QSimpleCanvasItem::GLPainter::drawPixmap(const QRectF &rect, - const GLTexture &img) -{ - QGLShaderProgram *shader = useTextureShader(); - - GLfloat vertices[8]; - GLfloat texVertices[8]; - - float widthV = img.width(); - float heightV = img.height(); - - vertices[0] = rect.x(); vertices[1] = rect.y()+heightV; - vertices[2] = rect.x()+widthV; vertices[3] = rect.y()+heightV; - vertices[4] = rect.x(); vertices[5] = rect.y(); - vertices[6] = rect.x()+widthV; vertices[7] = rect.y(); - - texVertices[0] = 0; texVertices[1] = 0; - texVertices[2] = 1; texVertices[3] = 0; - texVertices[4] = 0; texVertices[5] = 1; - texVertices[6] = 1; texVertices[7] = 1; - - shader->setAttributeArray(SingleTextureShader::Vertices, vertices, 2); - shader->setAttributeArray(SingleTextureShader::TextureCoords, texVertices, 2); - - glBindTexture(GL_TEXTURE_2D, img.texture()); - glDrawArrays(GL_TRIANGLE_STRIP, 0, 4); -} - -void QSimpleCanvasItem::GLPainter::fillRect(const QRectF &rect, - const QColor &color) -{ - if (color.alpha() == 0xFF) - glDisable(GL_BLEND); - - QGLShaderProgram *shader = useColorShader(color); - float x = rect.x(); - float y = rect.y(); - float width = rect.width(); - float height = rect.height(); - - GLfloat vertices[] = { x, height, - width, height, - x, y, - - width, height, - x, y, - width, y }; - - shader->setAttributeArray(ConstantColorShader::Vertices, vertices, 2); - glDrawArrays(GL_TRIANGLES, 0, 6); - - if (color.alpha() == 0xFF) - glEnable(GL_BLEND); -} - -void QSimpleCanvasItem::CachedTexture::addRef() -{ - ++r; -} - -void QSimpleCanvasItem::CachedTexture::release() -{ - Q_ASSERT(r > 0); - --r; - - if (r == 0) { - if (!s.isEmpty()) - d->cachedTextures.remove(s); - delete this; - } -} - -int QSimpleCanvasItem::CachedTexture::pixmapWidth() const -{ - return w; -} - -int QSimpleCanvasItem::CachedTexture::pixmapHeight() const -{ - return h; -} - -QSimpleCanvasItem::CachedTexture::CachedTexture() -: r(0), w(0), h(0) -{ -} - -QSimpleCanvasItem::CachedTexture * -QSimpleCanvasItem::cachedTexture(const QString &key) -{ - Q_D(QSimpleCanvasItem); - if (!d->canvas || key.isEmpty()) - return 0; - - QSimpleCanvasPrivate *canvas = d->canvas->d; - QHash<QString, QSimpleCanvasItem::CachedTexture *>::ConstIterator iter = - canvas->cachedTextures.find(key); - if (iter != canvas->cachedTextures.end()) { - (*iter)->addRef(); - return (*iter); - } else { - return 0; - } -} - -QSimpleCanvasItem::CachedTexture * -QSimpleCanvasItem::cachedTexture(const QString &key, const QPixmap &pix) -{ - Q_D(QSimpleCanvasItem); - if (!d->canvas) - return 0; - - QSimpleCanvasPrivate *canvas = d->canvas->d; - QHash<QString, QSimpleCanvasItem::CachedTexture *>::ConstIterator iter = - canvas->cachedTextures.end(); - if (!key.isEmpty()) - iter = canvas->cachedTextures.find(key); - - if (iter != canvas->cachedTextures.end()) { - (*iter)->addRef(); - return (*iter); - } else { - CachedTexture *rv = new CachedTexture; - rv->s = key; - rv->d = canvas; - rv->w = pix.width(); - rv->h = pix.height(); - rv->setImage(pix.toImage(), GLTexture::PowerOfTwo); - rv->setHorizontalWrap(GLTexture::Repeat); - rv->setVerticalWrap(GLTexture::Repeat); - rv->addRef(); - if (!key.isEmpty()) - canvas->cachedTextures.insert(key, rv); - return rv; - } -} - -QT_END_NAMESPACE diff --git a/src/declarative/canvas/qsimplecanvas_opengl1.cpp b/src/declarative/canvas/qsimplecanvas_opengl1.cpp deleted file mode 100644 index 6e50ef8..0000000 --- a/src/declarative/canvas/qsimplecanvas_opengl1.cpp +++ /dev/null @@ -1,401 +0,0 @@ -/**************************************************************************** -** -** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies). -** Contact: Qt Software Information (qt-info@nokia.com) -** -** This file is part of the QtDeclarative module of the Qt Toolkit. -** -** $QT_BEGIN_LICENSE:LGPL$ -** No Commercial Usage -** This file contains pre-release code and may not be distributed. -** You may use this file in accordance with the terms and conditions -** contained in the either Technology Preview License Agreement or the -** Beta Release License Agreement. -** -** GNU Lesser General Public License Usage -** Alternatively, this file may be used under the terms of the GNU Lesser -** General Public License version 2.1 as published by the Free Software -** Foundation and appearing in the file LICENSE.LGPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU Lesser General Public License version 2.1 requirements -** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. -** -** In addition, as a special exception, Nokia gives you certain -** additional rights. These rights are described in the Nokia Qt LGPL -** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this -** package. -** -** GNU General Public License Usage -** Alternatively, this file may be used under the terms of the GNU -** General Public License version 3.0 as published by the Free Software -** Foundation and appearing in the file LICENSE.GPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU General Public License version 3.0 requirements will be -** met: http://www.gnu.org/copyleft/gpl.html. -** -** If you are unsure which license is appropriate for your use, please -** contact the sales department at qt-sales@nokia.com. -** $QT_END_LICENSE$ -** -****************************************************************************/ - -#include "qsimplecanvas.h" -#include "qsimplecanvas_p.h" -#include "qsimplecanvasitem_p.h" -#include "qsimplecanvasfilter_p.h" -#include <gltexture.h> -#include <glsave.h> -#include <math.h> - - -QT_BEGIN_NAMESPACE -void CanvasEGLWidget::updateGL() -{ - _clip = QRect(); - QGLWidget::updateGL(); -} - -void CanvasEGLWidget::updateGL(const QRect &r) -{ - if (r.isEmpty()) - return; - - _clip = r; - QGLWidget::updateGL(); -} - -void CanvasEGLWidget::paintGL() -{ - if (!_clip.isEmpty()) { - glEnable(GL_SCISSOR_TEST); - glScissor(_clip.x(), _clip.y(), _clip.width(), _clip.height()); - } else { - glDisable(GL_SCISSOR_TEST); - } - - glDepthMask(GL_TRUE); - glClearColor(0.0f, 0.0f, 0.0f, 1.0f); - glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); - glDepthMask(GL_FALSE); - - _canvas->paintGL(); -} - -QRect CanvasEGLWidget::map(const QRectF &f) -{ - return invDefaultTransform.mapRect(f).toAlignedRect(); -} - -void CanvasEGLWidget::resizeGL(int w, int h) -{ - glViewport(0, 0, w, h); -} - -void CanvasEGLWidget::resizeEvent(QResizeEvent *e) -{ - defaultTransform.identity(); - defaultTransform.flipCoordinates(); - defaultTransform.translate(-1, -1, 0); - defaultTransform.scale(2. / width(), 2. / height(), -2. / 65536.); - invDefaultTransform = defaultTransform.inverted(); - _canvas->root->d_func()->transformActive = defaultTransform; - QGLWidget::resizeEvent(e); -} - -void CanvasEGLWidget::initializeGL() -{ - glEnable(GL_BLEND); - glEnable(GL_DEPTH_TEST); - glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); - glDepthFunc(GL_GREATER); -#ifdef QT_OPENGL_ES - glClearDepthf(0); -#else - glClearDepth(0); -#endif -} - -void QSimpleCanvasPrivate::paintGL() -{ - lrpTimer.start(); - - QSimpleCanvasItemPrivate::GLPaintParameters p; - p.sceneRect = QRect(0, 0, q->width(), q->height()); - p.clipRect = p.sceneRect; - p.opacity = 1; - p.forceParamRefresh = false; - if (!isSetup) { - unsigned int zero = 0; - root->d_func()->setupPainting(0, QRect(), &zero); - } - root->d_func()->paint(p); - - lrpTime = lrpTimer.elapsed(); -} - -QSimpleCanvas::Matrix QSimpleCanvasItemPrivate::localTransform() const -{ - Q_Q(const QSimpleCanvasItem); - - QSimpleCanvas::Matrix trans; - trans.translate(q->x(), q->y()); - QPointF to = transformOrigin(); - trans.translate(to.x(), to.y()); - trans.scale(q->scale().value(), q->scale().value()); - trans.translate(-to.x(), -to.y()); - trans *= transformUser; - return trans; -} - -void QSimpleCanvasItemPrivate::simplePaintChild(const GLPaintParameters ¶ms, QSimpleCanvasItem *child) -{ - GLPaintParameters childParams = params; - - if (child->d_func()->activeOpacity != 0) { - childParams.boundingRect = child->boundingRect(); - child->d_func()->paint(childParams); - } -} - -void QSimpleCanvasItemPrivate::paintChild(const GLPaintParameters ¶ms, - QSimpleCanvasItem *child) -{ - if (params.forceParamRefresh) { - QSimpleCanvas::Matrix t = child->d_func()->transformActive; - qreal o = child->d_func()->activeOpacity; - setupChildState(child); - simplePaintChild(params, child); - child->d_func()->transformActive = t; - child->d_func()->activeOpacity = o; - } else { - simplePaintChild(params, child); - } -} - - -void QSimpleCanvasItemPrivate::setupChildState(QSimpleCanvasItem *child) -{ - qreal visible = child->visible().value(); - child->d_func()->activeOpacity = activeOpacity; - if (visible != 1) - child->d_func()->activeOpacity *= visible; - - if (child->d_func()->activeOpacity != 0) { - // Calculate child's transform - qreal x = child->x(); - qreal y = child->y(); - qreal scale = child->scale().value(); - QSimpleCanvasItem::Flip flip = child->flip(); - - QSimpleCanvas::Matrix &am = child->d_func()->transformActive; - am = transformActive; - if (x != 0 || y != 0) - am.translate(x, y); - if (scale != 1) { - QPointF to = child->d_func()->transformOrigin(); - if (to.x() != 0. || to.y() != 0.) - am.translate(to.x(), to.y()); - am.scale(scale, scale); - if (to.x() != 0. || to.y() != 0.) - am.translate(-to.x(), -to.y()); - } - if (child->d_func()->transformUserSet) - am *= child->d_func()->transformUser; - if (flip) { - QRectF br = child->boundingRect(); - am.translate(br.width() / 2., br.height() / 2); - am.rotate(180, (flip & QSimpleCanvasItem::VerticalFlip)?1:0, (flip & QSimpleCanvasItem::HorizontalFlip)?1:0, 0); - am.translate(-br.width() / 2., -br.height() / 2); - } - } -} - -QRectF QSimpleCanvasItemPrivate::setupPainting(int version, const QRect &bounding, unsigned int *zero) -{ - Q_Q(QSimpleCanvasItem); - - QRectF rv = transformActive.mapRect(q->boundingRect()); - - unsigned int oldZero = *zero; - - for (int ii = 0; ii < children.count(); ++ii) { - QSimpleCanvasItem *child = children.at(ii); - setupChildState(child); - - if (child->d_func()->activeOpacity != 0) - rv |= child->d_func()->setupPainting(version, bounding, zero); - } - - if (clip || oldZero != *zero) - (*zero)++; - transformActive.translate(0, 0, *zero); - - lastPaintRect = rv; - return rv; -} - -void QSimpleCanvasItemPrivate::paintNoClip(GLPaintParameters ¶ms, QSimpleCanvasFilter::Layer layer) -{ - Q_Q(QSimpleCanvasItem); - - zOrderChildren(); - - int upto = 0; - for (upto = 0; upto < children.count(); ++upto) { - QSimpleCanvasItem *c = children.at(upto); - if (c->zValue().value() < 0) { - if (layer & QSimpleCanvasFilter::ChildrenUnderItem) - paintChild(params, c); - } else { - break; - } - } - - if (layer & QSimpleCanvasFilter::Item && - q->options() & QSimpleCanvasItem::HasContents) { - QSimpleCanvasItem::GLPainter painter(q); - painter.activeTransform = transformActive; - painter.activeOpacity = activeOpacity; - painter.sceneClipRect = params.clipRect; - - q->paintGLContents(painter); - } - - if (layer & QSimpleCanvasFilter::ChildrenAboveItem) { - for (; upto < children.count(); ++upto) { - QSimpleCanvasItem *c = children.at(upto); - paintChild(params, c); - } - } -} - -void QSimpleCanvasItemPrivate::paint(GLPaintParameters ¶ms, QSimpleCanvasFilter::Layer layer) -{ - if (!layer) - return; - - // XXX Handle separate cliping modes - if (clip) { - - GLSaveScissor ss; - qreal width = params.boundingRect.width(); - qreal height = params.boundingRect.height(); - float margin = width + height; - - GLfloat clipvertices[] = - { - -margin, -margin, - margin, -margin, - margin, 0, - - -margin, -margin, - -margin, 0, - margin, 0, - - -margin, 0, - -margin, margin, - 0, 0, - - 0, 0, - 0, margin, - -margin, margin, - - 0, height, - 0, margin, - margin, margin, - - margin, margin, - 0, height, - margin, height, - - width, 0, - margin, 0, - margin, height, - - margin, height, - width, height, - width, 0 - }; - - QRectF r = transformActive.mapRect(params.boundingRect); - r.translate(1, 1); - float xscale = 0.5 * float(params.sceneRect.width()); - float yscale = 0.5 * float(params.sceneRect.height()); - r.moveTo(r.x() * xscale, r.y() * yscale); - r.setSize(QSizeF(r.width() * xscale, r.height() * yscale)); - - glEnable(GL_SCISSOR_TEST); - int sr_x = ::floorf(r.x()); - int sr_y = ::floorf(r.y()); - int sr_width = ::ceilf(r.right()) - sr_x; - int sr_height = ::ceilf(r.bottom()) - sr_y; - - QRect sr(sr_x, sr_y, sr_width, sr_height); - if (ss.wasEnabled()) - sr &= ss.rect(); - - glScissor(sr.x(), sr.y(), sr.width(), sr.height()); - - { - glMatrixMode(GL_MODELVIEW); - glLoadMatrixf(transformActive.data()); - glDepthMask(GL_TRUE); - glColorMask(GL_FALSE, GL_FALSE, GL_FALSE, GL_FALSE); - glEnableClientState(GL_VERTEX_ARRAY); - glVertexPointer(2, GL_FLOAT, 0, clipvertices); - glDrawArrays(GL_TRIANGLES, 0, 24); - glDisableClientState(GL_VERTEX_ARRAY); - glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE); - glDepthMask(GL_FALSE); - } - - GLPaintParameters newParams = params; - newParams.clipRect = sr; - newParams.clipRect.moveTo(sr.x(), params.sceneRect.height() - sr.y() - sr.height()); - paintNoClip(newParams, layer); - } else { - paintNoClip(params, layer); - } -} - -QGLShaderProgram *QSimpleCanvasItem::GLPainter::useTextureShader() -{ - qFatal("Cannot call QSimpleCanvasItem::GLPainter::useTextureShader() when using OpenGL ES 1.1"); - return 0; -} - -QGLShaderProgram *QSimpleCanvasItem::GLPainter::useColorShader(const QColor &color) -{ - Q_UNUSED(color); - qFatal("Cannot call QSimpleCanvasItem::GLPainter::useColorShader() when using OpenGL ES 1.1"); - return 0; -} - -GLBasicShaders *QSimpleCanvasItemPrivate::basicShaders() const -{ - qFatal("Cannot call QSimpleCanvasItem::basicShaders() when using OpenGL ES 1.1"); - return 0; -} - -QGLFramebufferObject *QSimpleCanvasPrivate::acquire(int, int) -{ - return 0; -} - -void QSimpleCanvasPrivate::release(QGLFramebufferObject *) -{ -} - -void QSimpleCanvasItem::GLPainter::drawPixmap(const QPointF &point, - const GLTexture &texture) -{ - drawPixmap(QRectF(point, QSizeF(texture.width(), texture.height())), texture); -} - -void QSimpleCanvasItem::GLPainter::drawPixmap(const QRectF &rect, - const GLTexture &img) -{ - qFatal("Cannot call QSimpleCanvasItem::GLPainter::drawPixmap() when using OpenGL ES 1.1"); -} - -QT_END_NAMESPACE diff --git a/src/declarative/canvas/qsimplecanvas_p.h b/src/declarative/canvas/qsimplecanvas_p.h index 3a0186e..cd76b22 100644 --- a/src/declarative/canvas/qsimplecanvas_p.h +++ b/src/declarative/canvas/qsimplecanvas_p.h @@ -47,41 +47,6 @@ #include <qstack.h> #include <qdatetime.h> -#if defined(QFX_RENDER_OPENGL) - -#if defined(QFX_RENDER_OPENGL2) -#include "glbasicshaders.h" -#endif - -#include <QGLWidget> -QT_BEGIN_NAMESPACE - -class CanvasEGLWidget : public QGLWidget -{ -public: - CanvasEGLWidget(QSimpleCanvas *parent, QSimpleCanvasPrivate *canvas) - : - QGLWidget(parent), - _canvas(canvas) - { - } - - virtual void paintGL(); - virtual void resizeGL(int,int); - virtual void resizeEvent(QResizeEvent *e); - virtual void initializeGL(); - - void updateGL(); - void updateGL(const QRect &); - - QRect map(const QRectF &) const; -private: - QRect _clip; - QSimpleCanvasPrivate *_canvas; - QSimpleCanvas::Matrix defaultTransform; - QSimpleCanvas::Matrix invDefaultTransform; -}; -#endif #include <QGraphicsView> #include <QGraphicsScene> @@ -101,7 +66,6 @@ private: QGraphicsScene _scene; }; -class QGLFramebufferObject; class QSimpleCanvasDebugPlugin; class QSimpleCanvasPrivate { @@ -110,9 +74,6 @@ public: : q(canvas), timer(0), root(0), lrpTime(0), debugPlugin(0), focusItem(0), lastFocusItem(0), lastMouseItem(0), isSetup(false), view(0) -#if defined(QFX_RENDER_OPENGL) - ,egl(q, this), basicShadersInstance(0) -#endif , paintVersion(1) { } @@ -122,11 +83,7 @@ public: bool isSimpleCanvas() const { return mode == QSimpleCanvas::SimpleCanvas; } bool isGraphicsView() const { return mode == QSimpleCanvas::GraphicsView; } -#if defined(QFX_RENDER_OPENGL) - QRectF oldDirty; -#else QRect oldDirty; -#endif QRect resetDirty(); void paint(QPainter &p); @@ -174,27 +131,6 @@ public: QSimpleCanvasGraphicsView *view; -#if defined(QFX_RENDER_OPENGL) - CanvasEGLWidget egl; - GLBasicShaders *basicShaders() const - { -#if defined(QFX_RENDER_OPENGL2) - if (!basicShadersInstance) - basicShadersInstance = new GLBasicShaders; - return basicShadersInstance; -#else - return 0; -#endif - } - mutable GLBasicShaders *basicShadersInstance; - - QHash<QString, QSimpleCanvasItem::CachedTexture *> cachedTextures; - - QList<QGLFramebufferObject *> frameBuffers; - QGLFramebufferObject *acquire(int, int); - void release(QGLFramebufferObject *); - void paintGL(); -#endif int paintVersion; }; diff --git a/src/declarative/canvas/qsimplecanvasdebugplugin.cpp b/src/declarative/canvas/qsimplecanvasdebugplugin.cpp index 12088c1..91ef7dc 100644 --- a/src/declarative/canvas/qsimplecanvasdebugplugin.cpp +++ b/src/declarative/canvas/qsimplecanvasdebugplugin.cpp @@ -123,11 +123,7 @@ void QSimpleCanvasSceneDebugPlugin::refresh(QDataStream &ds, ds << QmlDebugServerPlugin::objectToString(item) << item->x() << item->y() << item->z() << item->width() << item->height() << (int)item->transformOrigin() << item->scale() << (int)item->flip() -#ifdef QFX_RENDER_OPENGL - << item->transform().toTransform() -#elif defined(QFX_RENDER_QPAINTER) << item->transform() -#endif << item->hasActiveFocus() << (int)item->options(); QPixmap pix; diff --git a/src/declarative/canvas/qsimplecanvasfilter.cpp b/src/declarative/canvas/qsimplecanvasfilter.cpp deleted file mode 100644 index 5bc6b35..0000000 --- a/src/declarative/canvas/qsimplecanvasfilter.cpp +++ /dev/null @@ -1,323 +0,0 @@ -/**************************************************************************** -** -** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies). -** Contact: Qt Software Information (qt-info@nokia.com) -** -** This file is part of the QtDeclarative module of the Qt Toolkit. -** -** $QT_BEGIN_LICENSE:LGPL$ -** No Commercial Usage -** This file contains pre-release code and may not be distributed. -** You may use this file in accordance with the terms and conditions -** contained in the either Technology Preview License Agreement or the -** Beta Release License Agreement. -** -** GNU Lesser General Public License Usage -** Alternatively, this file may be used under the terms of the GNU Lesser -** General Public License version 2.1 as published by the Free Software -** Foundation and appearing in the file LICENSE.LGPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU Lesser General Public License version 2.1 requirements -** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. -** -** In addition, as a special exception, Nokia gives you certain -** additional rights. These rights are described in the Nokia Qt LGPL -** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this -** package. -** -** GNU General Public License Usage -** Alternatively, this file may be used under the terms of the GNU -** General Public License version 3.0 as published by the Free Software -** Foundation and appearing in the file LICENSE.GPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU General Public License version 3.0 requirements will be -** met: http://www.gnu.org/copyleft/gpl.html. -** -** If you are unsure which license is appropriate for your use, please -** contact the sales department at qt-sales@nokia.com. -** $QT_END_LICENSE$ -** -****************************************************************************/ - -#include "qsimplecanvasfilter.h" -#include "qsimplecanvasfilter_p.h" -#include "qsimplecanvasitem_p.h" -#include "qsimplecanvas.h" -#include "qsimplecanvas_p.h" - -#if defined(QFX_RENDER_OPENGL2) -#include <glsave.h> -#include <QtOpenGL/qglframebufferobject.h> -#endif - -QT_BEGIN_NAMESPACE - -/*! - \qmlclass Filter - \brief A Filter is a graphical filter that can be applied to items. -*/ - -QSimpleCanvasFilter::QSimpleCanvasFilter(QObject *parent) -: QObject(parent), d(new QSimpleCanvasFilterPrivate(this)) -{ -} - -QSimpleCanvasFilter::~QSimpleCanvasFilter() -{ - if (d->item) d->item->setFilter(0); - delete d; d = 0; -} - -bool QSimpleCanvasFilter::enabled() const -{ - return d->enabled; -} - -/*! - \qmlproperty bool Filter::enabled - \brief Controls whether the filter is applied. -*/ - -void QSimpleCanvasFilter::setEnabled(bool e) -{ - if (e == d->enabled) - return; - d->enabled = e; - emit enabledChanged(); - update(); -} - -QGLFramebufferObject *QSimpleCanvasFilter::renderToFBO(float scale, const QRectF &src, const QPoint &offset, Layer) -{ - // XXX - respect src -#if defined(QFX_RENDER_OPENGL2) - Q_UNUSED(src); - Q_UNUSED(offset); - - QSimpleCanvasItem *item = d->item; - QRect br = item->itemBoundingRect(); - if (br.isEmpty()) - return 0; - QGLFramebufferObject *fbo = - item->canvas()->d->acquire(int(br.width() * scale), int(br.height() * scale)); - - GLSaveViewport sv; GLSaveScissor ss; - qreal oldOpacity = item->d_func()->data()->activeOpacity; - item->d_func()->data()->activeOpacity = 1; - - fbo->bind(); - - glClearColor(0,0,0,0); - glEnable(GL_SCISSOR_TEST); - glScissor(0, 0, int(br.width() * scale), int(br.height() * scale)); - glClear(GL_COLOR_BUFFER_BIT); - glViewport(0, 0, int(br.width() * scale), int(br.height() * scale)); - - QMatrix4x4 mat; - mat.flipCoordinates(); - mat.translate(-1, -1, 0); - mat.scale(2. / (br.width()), 2. / (br.height()), 1. / (1024. * 1024.)); - - renderToScreen(mat); - - fbo->release(); - - item->d_func()->data()->activeOpacity = oldOpacity; - return fbo; -#else - Q_UNUSED(src); - Q_UNUSED(offset); - Q_UNUSED(scale); - return 0; -#endif -} - -QGLFramebufferObject *QSimpleCanvasFilter::renderToFBO(const QRectF &src, const QPoint &offset, Layer) -{ - // XXX - respect src -#if defined(QFX_RENDER_OPENGL2) - Q_UNUSED(src); - Q_UNUSED(offset); - - QSimpleCanvasItem *item = d->item; - QRect br = item->itemBoundingRect(); - if (br.isEmpty()) - return 0; - QGLFramebufferObject *fbo = - item->canvas()->d->acquire(br.width(), br.height()); - - GLSaveViewport sv; GLSaveScissor ss; - qreal oldOpacity = item->d_func()->data()->activeOpacity; - item->d_func()->data()->activeOpacity = 1; - - fbo->bind(); - - glClearColor(0,0,0,0); - glEnable(GL_SCISSOR_TEST); - glScissor(0, 0, br.width(), br.height()); - glClear(GL_COLOR_BUFFER_BIT); - glViewport(0, 0, br.width(), br.height()); - - QMatrix4x4 mat; - mat.flipCoordinates(); - mat.translate(-1, -1, 0); - mat.scale(2. / br.width(), 2. / br.height(), 1. / (1024. * 1024.)); - - renderToScreen(mat); - - fbo->release(); - - item->d_func()->data()->activeOpacity = oldOpacity; - return fbo; -#else - Q_UNUSED(src); - Q_UNUSED(offset); - return 0; -#endif -} - -QGLFramebufferObject *QSimpleCanvasFilter::acquireFBO(const QSize &s) -{ -#if defined(QFX_RENDER_OPENGL2) - QSize size; - QSimpleCanvasItem *item = d->item; - if (size.isNull()) { - QRect br = item->itemBoundingRect(); - size = br.size(); - } else { - size = s; - } - - QGLFramebufferObject *fbo = - item->canvas()->d->acquire(s.width(), s.height()); - - return fbo; -#else - Q_UNUSED(s); - return 0; -#endif -} - -void QSimpleCanvasFilter::releaseFBO(QGLFramebufferObject *fbo) -{ -#if defined(QFX_RENDER_OPENGL2) - d->item->d_func()->canvas->d->release(fbo); -#else - Q_UNUSED(fbo); -#endif -} - -void QSimpleCanvasFilter::renderToScreen(const QRectF &src, Layer layer) -{ - // XXX - respect src -#if defined(QFX_RENDER_OPENGL2) - Q_UNUSED(src); - Q_UNUSED(layer); - d->item->d_func()->paint(d->params, layer); -#else - Q_UNUSED(src); - Q_UNUSED(layer); -#endif -} - -void QSimpleCanvasFilter::renderToScreen(const QSimpleCanvas::Matrix &trans, const QRectF &src, Layer layer) -{ - // XXX - respect src -#if defined(QFX_RENDER_OPENGL2) - Q_UNUSED(src); - QSimpleCanvas::Matrix old = d->item->d_func()->data()->transformActive; - d->item->d_func()->data()->transformActive = trans; - QSimpleCanvasItemPrivate::GLPaintParameters params = d->params; - params.forceParamRefresh = true; - d->item->d_func()->paint(params, layer); - d->item->d_func()->data()->transformActive = old; -#else - Q_UNUSED(trans); - Q_UNUSED(src); - Q_UNUSED(layer); -#endif -} - -QSimpleCanvasItem *QSimpleCanvasFilter::item() const -{ - return d->item; -} - -void QSimpleCanvasFilter::setItem(QSimpleCanvasItem *i) -{ - if (d->item == i) - return; - if (d->item) { - d->item->setFilter(0); - d->item = 0; - } - - if (i->filter() != this) { - i->setFilter(this); - } else { - d->item = i; - } -} - -#if defined(QFX_RENDER_OPENGL2) -void QSimpleCanvasFilterPrivate::doFilterGL(QSimpleCanvasItem::GLPainter &p, const QSimpleCanvasItemPrivate::GLPaintParameters &prms) -{ - params = prms; - q->filterGL(p); -} -#endif - -QRectF QSimpleCanvasFilter::itemBoundingRect(const QRectF &r) const -{ - return r; -} - -void QSimpleCanvasFilter::filterGL(QSimpleCanvasItem::GLPainter &p) -{ - Q_UNUSED(p); -} - -void QSimpleCanvasFilter::filter(QPainter &) -{ -} - -void QSimpleCanvasFilter::update() -{ - if (d->item) - d->item->update(); -} - -#if defined(QFX_RENDER_OPENGL2) -bool QSimpleCanvasFilterPrivate::isSimpleItem(QSimpleCanvasItem *item, QSimpleCanvasItem **out, QSimpleCanvas::Matrix *mout) -{ - if (item->options() & QSimpleCanvasItem::SimpleItem && !item->hasChildren()) { - *out = item; - return true; - } else if (!(item->options() & QSimpleCanvasItem::HasContents) && - item->children().count() == 1) { - QSimpleCanvasItem *child = item->children().first(); - if (child->filter() && child->filter()->enabled()) - return false; - bool rv = isSimpleItem(child, out, mout); - if (rv) - *mout *= child->d_func()->localTransform(); - return rv; - } else { - return false; - } -} -#endif - -bool QSimpleCanvasFilter::isSimpleItem(QSimpleCanvasItem **out, QSimpleCanvas::Matrix *mout) -{ -#if defined(QFX_RENDER_OPENGL2) - return d->isSimpleItem(item(), out, mout); -#else - Q_UNUSED(out); - Q_UNUSED(mout); -#endif - - return false; -} - -QT_END_NAMESPACE diff --git a/src/declarative/canvas/qsimplecanvasfilter.h b/src/declarative/canvas/qsimplecanvasfilter.h deleted file mode 100644 index 14bb765..0000000 --- a/src/declarative/canvas/qsimplecanvasfilter.h +++ /dev/null @@ -1,113 +0,0 @@ -/**************************************************************************** -** -** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies). -** Contact: Qt Software Information (qt-info@nokia.com) -** -** This file is part of the QtDeclarative module of the Qt Toolkit. -** -** $QT_BEGIN_LICENSE:LGPL$ -** No Commercial Usage -** This file contains pre-release code and may not be distributed. -** You may use this file in accordance with the terms and conditions -** contained in the either Technology Preview License Agreement or the -** Beta Release License Agreement. -** -** GNU Lesser General Public License Usage -** Alternatively, this file may be used under the terms of the GNU Lesser -** General Public License version 2.1 as published by the Free Software -** Foundation and appearing in the file LICENSE.LGPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU Lesser General Public License version 2.1 requirements -** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. -** -** In addition, as a special exception, Nokia gives you certain -** additional rights. These rights are described in the Nokia Qt LGPL -** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this -** package. -** -** GNU General Public License Usage -** Alternatively, this file may be used under the terms of the GNU -** General Public License version 3.0 as published by the Free Software -** Foundation and appearing in the file LICENSE.GPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU General Public License version 3.0 requirements will be -** met: http://www.gnu.org/copyleft/gpl.html. -** -** If you are unsure which license is appropriate for your use, please -** contact the sales department at qt-sales@nokia.com. -** $QT_END_LICENSE$ -** -****************************************************************************/ - -#ifndef QSIMPLECANVASFILTER_H -#define QSIMPLECANVASFILTER_H - -#include <QtCore/qobject.h> -#include <QtDeclarative/qfxglobal.h> -#include <QtDeclarative/qsimplecanvasitem.h> -#include <QtDeclarative/qsimplecanvas.h> - - -QT_BEGIN_HEADER - -QT_BEGIN_NAMESPACE - -QT_MODULE(Declarative) -class QSimpleCanvasFilterPrivate; -class QRectF; -class QPoint; -class QGLFramebufferObject; -class GLShaderProgram; -class Q_DECLARATIVE_EXPORT QSimpleCanvasFilter : public QObject -{ -Q_OBJECT -public: - QSimpleCanvasFilter(QObject *parent); - virtual ~QSimpleCanvasFilter(); - - enum Layer { ChildrenUnderItem = 0x01, - Item = 0x02, - ChildrenAboveItem = 0x04, - All = 0x07 }; - - Q_PROPERTY(bool enabled READ enabled WRITE setEnabled NOTIFY enabledChanged) - bool enabled() const; - void setEnabled(bool); - - QSimpleCanvasItem *item() const; - void setItem(QSimpleCanvasItem *); -Q_SIGNALS: - void enabledChanged(); - -protected: - - virtual QRectF itemBoundingRect(const QRectF &) const; - virtual void filterGL(QSimpleCanvasItem::GLPainter &p); - virtual void filter(QPainter &p); - - QGLFramebufferObject *renderToFBO(const QRectF &src = QRect(), const QPoint &offset = QPoint(), Layer = All); - QGLFramebufferObject *renderToFBO(float scale, const QRectF &src = QRect(), const QPoint &offset = QPoint(), Layer = All); - QGLFramebufferObject *acquireFBO(const QSize & = QSize()); - void releaseFBO(QGLFramebufferObject *); - - void renderToScreen(const QRectF &src = QRect(), Layer = All); - void renderToScreen(const QSimpleCanvas::Matrix &trans, const QRectF &src = QRect(), Layer = All); - - void update(); - - bool isSimpleItem(QSimpleCanvasItem **, QSimpleCanvas::Matrix *); - -private: - friend class QSimpleCanvasFilterPrivate; - friend class QSimpleCanvasItemPrivate; - friend class QSimpleCanvasItem; - - QSimpleCanvasFilterPrivate *d; -}; - - - -QT_END_NAMESPACE - -QT_END_HEADER -#endif diff --git a/src/declarative/canvas/qsimplecanvasfilter_p.h b/src/declarative/canvas/qsimplecanvasfilter_p.h deleted file mode 100644 index 1c72993..0000000 --- a/src/declarative/canvas/qsimplecanvasfilter_p.h +++ /dev/null @@ -1,70 +0,0 @@ -/**************************************************************************** -** -** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies). -** Contact: Qt Software Information (qt-info@nokia.com) -** -** This file is part of the QtDeclarative module of the Qt Toolkit. -** -** $QT_BEGIN_LICENSE:LGPL$ -** No Commercial Usage -** This file contains pre-release code and may not be distributed. -** You may use this file in accordance with the terms and conditions -** contained in the either Technology Preview License Agreement or the -** Beta Release License Agreement. -** -** GNU Lesser General Public License Usage -** Alternatively, this file may be used under the terms of the GNU Lesser -** General Public License version 2.1 as published by the Free Software -** Foundation and appearing in the file LICENSE.LGPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU Lesser General Public License version 2.1 requirements -** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. -** -** In addition, as a special exception, Nokia gives you certain -** additional rights. These rights are described in the Nokia Qt LGPL -** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this -** package. -** -** GNU General Public License Usage -** Alternatively, this file may be used under the terms of the GNU -** General Public License version 3.0 as published by the Free Software -** Foundation and appearing in the file LICENSE.GPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU General Public License version 3.0 requirements will be -** met: http://www.gnu.org/copyleft/gpl.html. -** -** If you are unsure which license is appropriate for your use, please -** contact the sales department at qt-sales@nokia.com. -** $QT_END_LICENSE$ -** -****************************************************************************/ - -#ifndef QSIMPLECANVASFILTER_P_H -#define QSIMPLECANVASFILTER_P_H - -#include "qsimplecanvasitem.h" -#include "qsimplecanvasitem_p.h" - - -QT_BEGIN_NAMESPACE -class QSimpleCanvasFilterPrivate -{ -public: - QSimpleCanvasFilterPrivate(QSimpleCanvasFilter *_q) - : q(_q), item(0), enabled(true) {} - - QSimpleCanvasFilter *q; - - QSimpleCanvasItem *item; - bool enabled; -#if defined(QFX_RENDER_OPENGL) - QSimpleCanvasItemPrivate::GLPaintParameters params; - - void doFilterGL(QSimpleCanvasItem::GLPainter &, const QSimpleCanvasItemPrivate::GLPaintParameters &); - - bool isSimpleItem(QSimpleCanvasItem *item, QSimpleCanvasItem **out, QSimpleCanvas::Matrix *mout); -#endif -}; - -QT_END_NAMESPACE -#endif diff --git a/src/declarative/canvas/qsimplecanvasitem.cpp b/src/declarative/canvas/qsimplecanvasitem.cpp index cbdc324..f53ae72 100644 --- a/src/declarative/canvas/qsimplecanvasitem.cpp +++ b/src/declarative/canvas/qsimplecanvasitem.cpp @@ -199,20 +199,6 @@ void QSimpleCanvasItem::paintContents(QPainter &) { } -void QSimpleCanvasItem::paintGLContents(GLPainter &) -{ -} - -uint QSimpleCanvasItem::glSimpleItemData(float *vertices, float *texVertices, - GLTexture **texture, uint count) -{ - Q_UNUSED(vertices); - Q_UNUSED(texVertices); - Q_UNUSED(texture); - Q_UNUSED(count); - return 0; -} - void QSimpleCanvasItem::canvasChanged() { } @@ -229,15 +215,6 @@ void QSimpleCanvasItem::parentChanged(QSimpleCanvasItem *, QSimpleCanvasItem *) { } -GLBasicShaders *QSimpleCanvasItem::basicShaders() const -{ -#if defined(QFX_RENDER_OPENGL2) - return canvas()->d->basicShaders(); -#else - return 0; -#endif -} - /*! Returns the item's (0, 0) point relative to its parent. */ @@ -668,27 +645,6 @@ void QSimpleCanvasItem::remChild(QSimpleCanvasItem *c) childrenChanged(); } -QSimpleCanvasFilter *QSimpleCanvasItem::filter() const -{ - Q_D(const QSimpleCanvasItem); - return d->filter; -} - -/*! -QSimpleCanvasItem takes ownership of filter. -*/ -void QSimpleCanvasItem::setFilter(QSimpleCanvasFilter *f) -{ - Q_D(QSimpleCanvasItem); - if (!d || f == d->filter) - return; - - d->filter = f; - if (d->filter) - d->filter->setItem(this); - update(); -} - const QList<QSimpleCanvasItem *> &QSimpleCanvasItem::children() const { Q_D(const QSimpleCanvasItem); @@ -795,66 +751,22 @@ QRect QSimpleCanvasItem::itemBoundingRect() QPointF QSimpleCanvasItemPrivate::adjustFrom(const QPointF &p) const { -#if defined(QFX_RENDER_OPENGL) - if (!canvas) - return p; - - QPointF rv(-1. + 2. * p.x() / qreal(canvas->width()), - 1 - 2. * p.y() / qreal(canvas->height())); - - return rv; -#else return p; -#endif } QRectF QSimpleCanvasItemPrivate::adjustFrom(const QRectF &r) const { -#if defined(QFX_RENDER_OPENGL) - if (!canvas) - return r; - - qreal width = r.width() * 2. / qreal(canvas->width()); - qreal height = r.height() * 2. / qreal(canvas->height()); - qreal x = -1. + 2. * r.x() / qreal(canvas->width()); - qreal y = 1. - 2. * r.y() / qreal(canvas->height()) - height; - - return QRectF(x, y, width, height); -#else return r; -#endif } QPointF QSimpleCanvasItemPrivate::adjustTo(const QPointF &p) const { -#if defined(QFX_RENDER_OPENGL) - if (!canvas) - return p; - - QPointF rv(0.5 * (p.x() + 1.) * qreal(canvas->width()), - 0.5 * (1. - p.y()) * qreal(canvas->height())); - - return rv; -#else return p; -#endif } QRectF QSimpleCanvasItemPrivate::adjustTo(const QRectF &r) const { -#if defined(QFX_RENDER_OPENGL) - if (!canvas) - return r; - - qreal width = 0.5 * r.width() * qreal(canvas->width()); - qreal height = 0.5 * r.height() * qreal(canvas->height()); - qreal x = 0.5 * (r.x() + 1.) * qreal(canvas->width()); - qreal y = 0.5 * (1. - r.y()) * qreal(canvas->height()) - height; - - return QRectF(x, y, width, height); -#else return r; -#endif } QPointF QSimpleCanvasItem::mapFromScene(const QPointF &p) const @@ -865,20 +777,7 @@ QPointF QSimpleCanvasItem::mapFromScene(const QPointF &p) const } else { QPointF mp = d->adjustFrom(p); d->freshenTransforms(); -#if defined(QFX_RENDER_OPENGL) - // m20X + m21Y + m22Z + m23 = 1 - // Z = (1 - m23 - m20X - m21Y) / m22 - - QMatrix4x4 inv = d->data()->transformActive.inverted(); - qreal z_s = (1 - inv(2,3) - inv(2,0) * mp.x() - inv(2, 1) * mp.y()) / inv(2, 2); - - QVector3D vec(mp.x(), mp.y(), z_s); - QVector3D r = inv.map(vec); - - return r.toPointF(); -#else return d->data()->transformActive.inverted().map(mp); -#endif } } @@ -890,32 +789,7 @@ QRectF QSimpleCanvasItem::mapFromScene(const QRectF &r) const } else { QRectF mr = d->adjustFrom(r); d->freshenTransforms(); -#if defined(QFX_RENDER_OPENGL) - // m20X + m21Y + m22Z + m23 = 1 - // Z = (1 - m23 - m20X - m21Y) / m22 - - QMatrix4x4 inv = d->data()->transformActive.inverted(); - qreal tl_z_s = (1 - inv(2,3) - inv(2,0) * mr.topLeft().x() - inv(2, 1) * mr.topLeft().y()) / inv(2, 2); - qreal tr_z_s = (1 - inv(2,3) - inv(2,0) * mr.topRight().x() - inv(2, 1) * mr.topRight().y()) / inv(2, 2); - qreal bl_z_s = (1 - inv(2,3) - inv(2,0) * mr.bottomLeft().x() - inv(2, 1) * mr.bottomLeft().y()) / inv(2, 2); - qreal br_z_s = (1 - inv(2,3) - inv(2,0) * mr.bottomRight().x() - inv(2, 1) * mr.bottomRight().y()) / inv(2, 2); - - QVector3D tl(mr.topLeft().x(), mr.topLeft().y(), tl_z_s); - QVector3D tr(mr.topRight().x(), mr.topRight().y(), tr_z_s); - QVector3D bl(mr.bottomLeft().x(), mr.bottomLeft().y(), bl_z_s); - QVector3D br(mr.bottomRight().x(), mr.bottomRight().y(), br_z_s); - - tl = inv.map(tl); tr = inv.map(tr); bl = inv.map(bl); br = inv.map(br); - - qreal xmin = qMin(qMin(tl.x(), tr.x()), qMin(bl.x(), br.x())); - qreal xmax = qMax(qMax(tl.x(), tr.x()), qMax(bl.x(), br.x())); - qreal ymin = qMin(qMin(tl.y(), tr.y()), qMin(bl.y(), br.y())); - qreal ymax = qMax(qMax(tl.y(), tr.y()), qMax(bl.y(), br.y())); - - return QRectF(QPointF(xmin, ymin), QPointF(xmax, ymax)); -#else return d->data()->transformActive.inverted().mapRect(mr); -#endif } } @@ -992,20 +866,12 @@ void QSimpleCanvasItemPrivate::doFreshenTransforms() const } Q_Q(const QSimpleCanvasItem); -#if defined(QFX_RENDER_OPENGL) - if (q->d_func()->data()->transformUser) - data()->transformActive *= *q->d_func()->data()->transformUser; -#endif if (data()->flip) { QRectF br = q->boundingRect(); data()->transformActive.translate(br.width() / 2., br.height() / 2); -#if defined(QFX_RENDER_OPENGL) - data()->transformActive.rotate(180, (data()->flip & QSimpleCanvasItem::VerticalFlip)?1:0, (data()->flip & QSimpleCanvasItem::HorizontalFlip)?1:0, 0); -#else data()->transformActive.scale((data()->flip & QSimpleCanvasItem::HorizontalFlip)?-1:1, (data()->flip & QSimpleCanvasItem::VerticalFlip)?-1:1); -#endif data()->transformActive.translate(-br.width() / 2., -br.height() / 2); } } @@ -1345,8 +1211,6 @@ QSimpleCanvasItem::~QSimpleCanvasItem() if (prnt && d->canvas->d->focusPanelData.value(prnt) == this) d->canvas->d->focusPanelData.remove(prnt); } - if (d->filter) - delete d->filter; qDeleteAll(children()); if (parent()) @@ -1372,8 +1236,6 @@ QSimpleCanvasItem::~QSimpleCanvasItem() delete child; } - delete d->filter; - if (parent() && d->data_ptr && d->data()->dirty) { QSimpleCanvasLayer *l = parent()->layer(); if (l) { diff --git a/src/declarative/canvas/qsimplecanvasitem.h b/src/declarative/canvas/qsimplecanvasitem.h index dce3007..74841ea 100644 --- a/src/declarative/canvas/qsimplecanvasitem.h +++ b/src/declarative/canvas/qsimplecanvasitem.h @@ -45,9 +45,6 @@ #include <QtDeclarative/qfxglobal.h> #include <QtDeclarative/qmldebuggerstatus.h> #include <QtDeclarative/qsimplecanvas.h> -#if defined(QFX_RENDER_OPENGL) -#include <QtDeclarative/gltexture.h> -#endif #include <QtCore/qobject.h> #include <QtGui/qgraphicsitem.h> @@ -66,9 +63,6 @@ class QSimpleCanvasLayer; class QPointF; class QRectF; class QGraphicsSceneHoverEvent; -class QSimpleCanvasFilter; -class GLTexture; -class QGLShaderProgram; class Q_DECLARATIVE_EXPORT QSimpleCanvasItem : public QObject { @@ -168,39 +162,9 @@ public: QRect itemBoundingRect(); - class GLPainter - { - public: - GLPainter(); - GLPainter(QSimpleCanvasItem *i); - QSimpleCanvasItem *item; - QSimpleCanvas::Matrix activeTransform; - qreal activeOpacity; - QRect sceneClipRect; - - QGLShaderProgram *useTextureShader(); - QGLShaderProgram *useColorShader(const QColor &); - void drawPixmap(const QPointF &, const GLTexture &); - void drawPixmap(const QRectF &, const GLTexture &); - void fillRect(const QRectF &, const QColor &); - - void invalidate(); - - bool blendEnabled; - - private: - int flags; - GLPainter(const GLPainter &); - GLPainter &operator=(const GLPainter &); - }; - - void setPaintMargin(qreal margin); QRectF boundingRect() const; virtual void paintContents(QPainter &); - virtual void paintGLContents(GLPainter &); - virtual uint glSimpleItemData(float *vertices, float *texVertices, - GLTexture **texture, uint count); void update(); @@ -217,9 +181,6 @@ public: QSimpleCanvas::Matrix transform() const; void setTransform(const QSimpleCanvas::Matrix &); - QSimpleCanvasFilter *filter() const; - void setFilter(QSimpleCanvasFilter *); - QSimpleCanvasItem *mouseGrabberItem() const; void ungrabMouse(); void grabMouse(); @@ -238,30 +199,6 @@ public: static QSimpleCanvasItem *findPrevFocus(QSimpleCanvasItem *item); static QSimpleCanvasItem *findNextFocus(QSimpleCanvasItem *item); - GLBasicShaders *basicShaders() const; - -#if defined(QFX_RENDER_OPENGL) - class CachedTexture : public GLTexture - { - public: - void addRef(); - void release(); - - int pixmapWidth() const; - int pixmapHeight() const; - - private: - CachedTexture(); - friend class QSimpleCanvasItem; - QSimpleCanvasPrivate *d; - QString s; - int r, w, h; - }; - - CachedTexture *cachedTexture(const QString &); - CachedTexture *cachedTexture(const QString &, const QPixmap &); -#endif - static QPixmap string(const QString &, const QColor & = Qt::black, const QFont & = QFont()); protected: @@ -299,12 +236,8 @@ private: friend class QSimpleCanvas; friend class QSimpleCanvasPrivate; friend class QSimpleCanvasRootLayer; - friend class QSimpleCanvasItem::GLPainter; - friend class QSimpleCanvasFilter; friend class QGraphicsQSimpleCanvasItem; friend class QSimpleGraphicsItem; - friend class CanvasEGLWidget; - friend class QSimpleCanvasFilterPrivate; public: QSimpleCanvasItem(QSimpleCanvasItemPrivate &dd, QSimpleCanvasItem *parent); diff --git a/src/declarative/canvas/qsimplecanvasitem_p.h b/src/declarative/canvas/qsimplecanvasitem_p.h index 6c21d9f..a062054 100644 --- a/src/declarative/canvas/qsimplecanvasitem_p.h +++ b/src/declarative/canvas/qsimplecanvasitem_p.h @@ -45,11 +45,6 @@ #include "private/qobject_p.h" #include "qsimplecanvas.h" #include "qsimplecanvasitem.h" -#include "qsimplecanvasfilter.h" - -#if defined(QFX_RENDER_OPENGL2) -#include <glbasicshaders.h> -#endif #include "qgraphicsitem.h" @@ -106,11 +101,7 @@ public: float activeOpacity; -#if defined(QFX_RENDER_OPENGL) - QRectF lastPaintRect; -#else QRect lastPaintRect; -#endif }; class QSimpleCanvasItemDebuggerStatus : public QmlDebuggerStatus @@ -129,14 +120,13 @@ public: bool selected; }; -class QSimpleCanvasFilter; class QGraphicsQSimpleCanvasItem; class QSimpleCanvasItemPrivate : public QObjectPrivate { Q_DECLARE_PUBLIC(QSimpleCanvasItem) public: QSimpleCanvasItemPrivate() - : parent(0), canvas(0), debuggerStatus(0), filter(0), + : parent(0), canvas(0), debuggerStatus(0), clip(QSimpleCanvasItem::NoClip), origin(QSimpleCanvasItem::TopLeft), options(QSimpleCanvasItem::NoOption), focusable(false), wantsActiveFocusPanelPendingCanvas(false), @@ -157,7 +147,6 @@ public: QList<QSimpleCanvasItem *> children; QSimpleCanvasItemDebuggerStatus *debuggerStatus; - QSimpleCanvasFilter *filter; QSimpleCanvasItem::ClipType clip:3; QSimpleCanvasItem::TransformOrigin origin:4; @@ -203,43 +192,9 @@ public: void setParentInternal(QSimpleCanvasItem *); void convertToGraphicsItem(QGraphicsItem * = 0); -#if defined(QFX_RENDER_QPAINTER) void paint(QPainter &); void paintChild(QPainter &, QSimpleCanvasItem *); QRect setupPainting(int version, const QRect &bounding); -#else - struct GLPaintParameters - { - QRect sceneRect; - QRectF boundingRect; - QRect clipRect; -#if defined(QFX_RENDER_OPENGL2) - uchar stencilValue; -#endif - float opacity; - bool forceParamRefresh; - - QSimpleCanvasItem::GLPainter *painter; - }; -#if defined(QFX_RENDER_OPENGL2) - QRectF setupPainting(int version, int &z, QSimpleCanvasItem **); -#elif defined(QFX_RENDER_OPENGL1) - QRectF setupPainting(int version, const QRect &bounding, unsigned int *zero); -#endif - void setupChildState(QSimpleCanvasItem *); - - void paint(GLPaintParameters &, QSimpleCanvasFilter::Layer = QSimpleCanvasFilter::All); -#if defined(QFX_RENDER_OPENGL1) - void paintNoClip(GLPaintParameters &, QSimpleCanvasFilter::Layer = QSimpleCanvasFilter::All); -#endif - void paintChild(const GLPaintParameters &, QSimpleCanvasItem *); - void simplePaintChild(const GLPaintParameters &, QSimpleCanvasItem *); - - inline GLBasicShaders *basicShaders() const; - - QSimpleCanvas::Matrix localTransform() const; - -#endif QSimpleCanvasItem *nextOpaque; diff --git a/src/declarative/declarative.pro b/src/declarative/declarative.pro index 382f3cb..31830a0 100644 --- a/src/declarative/declarative.pro +++ b/src/declarative/declarative.pro @@ -26,6 +26,4 @@ include(widgets/widgets.pri) include(test/test.pri) include(debugger/debugger.pri) -contains(QT_CONFIG, opengles2)|contains(QT_CONFIG, opengles1):include(opengl/opengl.pri) - symbian:TARGET.UID3=0x2001E623 diff --git a/src/declarative/fx/fx.pri b/src/declarative/fx/fx.pri index 166ad58..801725d 100644 --- a/src/declarative/fx/fx.pri +++ b/src/declarative/fx/fx.pri @@ -2,7 +2,6 @@ HEADERS += \ fx/qfxanchors.h \ fx/qfxanchors_p.h \ fx/qfxanimatedimageitem.h \ - fx/qfxblendedimage.h \ fx/qfxcomponentinstance.h \ fx/qfxcomponentinstance_p.h \ fx/qfxcontentwrapper.h \ @@ -50,7 +49,6 @@ HEADERS += \ SOURCES += \ fx/qfxanchors.cpp \ fx/qfxanimatedimageitem.cpp \ - fx/qfxblendedimage.cpp \ fx/qfxcomponentinstance.cpp \ fx/qfxcontentwrapper.cpp \ fx/qfxevents.cpp \ diff --git a/src/declarative/fx/qfxblendedimage.cpp b/src/declarative/fx/qfxblendedimage.cpp deleted file mode 100644 index 0c93fef..0000000 --- a/src/declarative/fx/qfxblendedimage.cpp +++ /dev/null @@ -1,308 +0,0 @@ -/**************************************************************************** -** -** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies). -** Contact: Qt Software Information (qt-info@nokia.com) -** -** This file is part of the QtDeclarative module of the Qt Toolkit. -** -** $QT_BEGIN_LICENSE:LGPL$ -** No Commercial Usage -** This file contains pre-release code and may not be distributed. -** You may use this file in accordance with the terms and conditions -** contained in the either Technology Preview License Agreement or the -** Beta Release License Agreement. -** -** GNU Lesser General Public License Usage -** Alternatively, this file may be used under the terms of the GNU Lesser -** General Public License version 2.1 as published by the Free Software -** Foundation and appearing in the file LICENSE.LGPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU Lesser General Public License version 2.1 requirements -** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. -** -** In addition, as a special exception, Nokia gives you certain -** additional rights. These rights are described in the Nokia Qt LGPL -** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this -** package. -** -** GNU General Public License Usage -** Alternatively, this file may be used under the terms of the GNU -** General Public License version 3.0 as published by the Free Software -** Foundation and appearing in the file LICENSE.GPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU General Public License version 3.0 requirements will be -** met: http://www.gnu.org/copyleft/gpl.html. -** -** If you are unsure which license is appropriate for your use, please -** contact the sales department at qt-sales@nokia.com. -** $QT_END_LICENSE$ -** -****************************************************************************/ - -#include "qfxblendedimage.h" -#include <QtDeclarative/qmlcontext.h> - -#if defined(QFX_RENDER_OPENGL2) -#include <glbasicshaders.h> -#endif - -QT_BEGIN_NAMESPACE - -/*! - \qmlclass BlendedImage - \brief The BlendedImage elements blends two different images depending on a blend ratio. - - This element can be used to simulate blur on slow devices by setting secondaryUrl with - a pre-rendered blurred version of primaryUrl. - - Note that this class will only work under OpenGL. On the software canvas it will display - only the primary image unless the blend is > 0.75, in which case it will display only the - secondary image. -*/ - -/*! - \internal - \class QFxBlendedImage - \brief The QFxBlendedImage blends two different images depending on a blend ratio. - - This class can be used to simulate blur on slow devices by setting secondaryUrl with - a pre-rendered blurred version of primaryUrl. - - Note that this class will only work under OpenGL. On the software canvas it will display - only the primary image unless the blend is > 0.75, in which case it will display only the - secondary image. -*/ -QFxBlendedImage::QFxBlendedImage(QFxItem *parent) -: QFxItem(parent), _blend(0), _smooth(false), dirty(false) -{ -#if defined(QFX_RENDER_OPENGL2) - setOptions(HasContents); -#endif -} - -/*! - Cancels any pending image loads and destroys the image. -*/ -QFxBlendedImage::~QFxBlendedImage() -{ - if (!primUrl.isEmpty()) - QFxPixmap::cancelGet(primUrl,this); - if (!secUrl.isEmpty()) - QFxPixmap::cancelGet(secUrl,this); -} - -/*! - \qmlproperty string BlendedImage::primaryUrl - The URL of the first image to be displayed in this item. -*/ -QUrl QFxBlendedImage::primaryUrl() const -{ - return primUrl; -} - -void QFxBlendedImage::primaryLoaded() -{ - primPix = QFxPixmap(primUrl); - dirty = true; - update(); -} - -void QFxBlendedImage::setPrimaryUrl(const QUrl &url) -{ - if (primUrl == url) - return; - if (!primUrl.isEmpty()) - QFxPixmap::cancelGet(primUrl,this); - Q_ASSERT(!url.isRelative()); - primUrl = url; - if (!primUrl.isEmpty()) - QFxPixmap::get(qmlEngine(this), primUrl,this,SLOT(primaryLoaded())); -} - -/*! - \qmlproperty string BlendedImage::secondaryUrl - The URL of the second image to be displayed in this item. -*/ -QUrl QFxBlendedImage::secondaryUrl() const -{ - return secUrl; -} - -void QFxBlendedImage::secondaryLoaded() -{ - secPix = QFxPixmap(secUrl); - dirty = true; - update(); -} - -void QFxBlendedImage::setSecondaryUrl(const QUrl &url) -{ - if (secUrl == url) - return; - if (!secUrl.isEmpty()) - QFxPixmap::cancelGet(secUrl,this); - Q_ASSERT(!url.isRelative()); - secUrl = url; - if (!secUrl.isEmpty()) - QFxPixmap::get(qmlEngine(this), secUrl,this,SLOT(secondaryLoaded())); -} - -/*! - \qmlproperty real BlendedImage::blend - The ratio used to blend the two images. - - If blend has a value of 0, only the first image will be displayed. - If blend has a value of 1, only the second image will be displayed. -*/ -qreal QFxBlendedImage::blend() const -{ - return _blend; -} - -void QFxBlendedImage::setBlend(qreal b) -{ - _blend = b; - update(); -} - -/*! - \qmlproperty bool BlendedImage::smooth - - Set this property if you want the image to be smoothly filtered when scaled or - transformed. Smooth filtering gives better visual quality, but is slower. If - the BlendedImage is displayed at its natural size, this property has no visual or - performance effect. - - \note Generally scaling artifacts are only visible if the image is stationary on - the screen. A common pattern when animating an image is to disable smooth - filtering at the beginning of the animation and reenable it at the conclusion. - */ -bool QFxBlendedImage::smoothTransform() const -{ - return _smooth; -} - -void QFxBlendedImage::setSmoothTransform(bool s) -{ - if (_smooth == s) - return; - _smooth = s; - update(); -} - -#if defined(QFX_RENDER_QPAINTER) - -void QFxBlendedImage::paintContents(QPainter &p) -{ - if (primUrl.isEmpty() && secUrl.isEmpty()) - return; - - if (_smooth) { - p.save(); - p.setRenderHints(QPainter::Antialiasing | QPainter::SmoothPixmapTransform, _smooth); - } - - if (_blend < 0.75) - p.drawPixmap(0, 0, primPix); - else - p.drawPixmap(0, 0, secPix); - - if (_smooth) { - p.restore(); - } -} - -#elif defined(QFX_RENDER_OPENGL2) - -void QFxBlendedImage::paintGLContents(GLPainter &p) -{ - static DualTextureBlendShader *shader = 0; - if (!shader) - shader = new DualTextureBlendShader(); - - if (dirty) { - prim.clear(); - sec.clear(); - prim.setImage(primPix.toImage()); - sec.setImage(secPix.toImage()); - - dirty = false; - } - - if (prim.isNull() || sec.isNull()) { - - return; - } - - GLfloat vertices[8]; - GLfloat texVertices[8]; - - float widthV = width(); - float heightV = height(); - if (!widthV) - widthV = qMax(primPix.width(), secPix.width()); - if (!heightV) - heightV = qMax(primPix.height(), secPix.height()); - - vertices[0] = 0; vertices[1] = heightV; - vertices[2] = widthV; vertices[3] = heightV; - vertices[4] = 0; vertices[5] = 0; - vertices[6] = widthV; vertices[7] = 0; - - texVertices[0] = 0; texVertices[1] = 0; - texVertices[2] = 1; texVertices[3] = 0; - texVertices[4] = 0; texVertices[5] = 1; - texVertices[6] = 1; texVertices[7] = 1; - - if (_blend == 0 || _blend == 1) { - QGLShaderProgram *tshader = p.useTextureShader(); - - GLTexture *tex = 0; - - if (_blend == 0) - tex = &prim; - else - tex = &sec; - - tshader->setAttributeArray(SingleTextureShader::Vertices, vertices, 2); - tshader->setAttributeArray(SingleTextureShader::TextureCoords, texVertices, 2); - - glBindTexture(GL_TEXTURE_2D, tex->texture()); - glDrawArrays(GL_TRIANGLE_STRIP, 0, 4); - - tshader->disableAttributeArray(SingleTextureShader::Vertices); - tshader->disableAttributeArray(SingleTextureShader::TextureCoords); - } else { - - glActiveTexture(GL_TEXTURE0); - glBindTexture(GL_TEXTURE_2D, prim.texture()); - glActiveTexture(GL_TEXTURE1); - glBindTexture(GL_TEXTURE_2D, sec.texture()); - - shader->enable(); - shader->setOpacity(1); - qreal b = _blend; - if (b > 1) b = 1; - else if (b < 0) b = 0; - shader->setBlend(b); - shader->setTransform(p.activeTransform); - - shader->setAttributeArray(DualTextureBlendShader::Vertices, vertices, 2); - shader->setAttributeArray(DualTextureBlendShader::TextureCoords, texVertices, 2); - shader->setAttributeArray(DualTextureBlendShader::BlendTextureCoords, texVertices, 2); - - glDrawArrays(GL_TRIANGLE_STRIP, 0, 4); - - shader->disableAttributeArray(DualTextureBlendShader::Vertices); - shader->disableAttributeArray(DualTextureBlendShader::TextureCoords); - shader->disableAttributeArray(DualTextureBlendShader::BlendTextureCoords); - - glBindTexture(GL_TEXTURE_2D, 0); - glActiveTexture(GL_TEXTURE0); - } -} -#endif - -QML_DEFINE_TYPE(QFxBlendedImage,BlendedImage) - -QT_END_NAMESPACE diff --git a/src/declarative/fx/qfxblendedimage.h b/src/declarative/fx/qfxblendedimage.h deleted file mode 100644 index 248cc9d..0000000 --- a/src/declarative/fx/qfxblendedimage.h +++ /dev/null @@ -1,110 +0,0 @@ -/**************************************************************************** -** -** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies). -** Contact: Qt Software Information (qt-info@nokia.com) -** -** This file is part of the QtDeclarative module of the Qt Toolkit. -** -** $QT_BEGIN_LICENSE:LGPL$ -** No Commercial Usage -** This file contains pre-release code and may not be distributed. -** You may use this file in accordance with the terms and conditions -** contained in the either Technology Preview License Agreement or the -** Beta Release License Agreement. -** -** GNU Lesser General Public License Usage -** Alternatively, this file may be used under the terms of the GNU Lesser -** General Public License version 2.1 as published by the Free Software -** Foundation and appearing in the file LICENSE.LGPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU Lesser General Public License version 2.1 requirements -** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. -** -** In addition, as a special exception, Nokia gives you certain -** additional rights. These rights are described in the Nokia Qt LGPL -** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this -** package. -** -** GNU General Public License Usage -** Alternatively, this file may be used under the terms of the GNU -** General Public License version 3.0 as published by the Free Software -** Foundation and appearing in the file LICENSE.GPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU General Public License version 3.0 requirements will be -** met: http://www.gnu.org/copyleft/gpl.html. -** -** If you are unsure which license is appropriate for your use, please -** contact the sales department at qt-sales@nokia.com. -** $QT_END_LICENSE$ -** -****************************************************************************/ - -#ifndef QFXBLENDEDIMAGE_H -#define QFXBLENDEDIMAGE_H - -#include <QtDeclarative/qfxitem.h> -#if defined(QFX_RENDER_OPENGL2) -#include <gltexture.h> -#endif - -QT_BEGIN_HEADER - -QT_BEGIN_NAMESPACE - -QT_MODULE(Declarative) - -class Q_DECLARATIVE_EXPORT QFxBlendedImage : public QFxItem -{ - Q_OBJECT - - Q_PROPERTY(QUrl primaryUrl READ primaryUrl WRITE setPrimaryUrl) - Q_PROPERTY(QUrl secondaryUrl READ secondaryUrl WRITE setSecondaryUrl) - Q_PROPERTY(qreal blend READ blend WRITE setBlend) - Q_PROPERTY(bool smooth READ smoothTransform WRITE setSmoothTransform) -public: - QFxBlendedImage(QFxItem *parent=0); - ~QFxBlendedImage(); - - QUrl primaryUrl() const; - void setPrimaryUrl(const QUrl &); - - QUrl secondaryUrl() const; - void setSecondaryUrl(const QUrl &); - - qreal blend() const; - void setBlend(qreal); - - bool smoothTransform() const; - void setSmoothTransform(bool); - -#if defined(QFX_RENDER_QPAINTER) - void paintContents(QPainter &painter); -#elif defined(QFX_RENDER_OPENGL2) - void paintGLContents(GLPainter &); -#endif - -private Q_SLOTS: - void primaryLoaded(); - void secondaryLoaded(); - -private: - QUrl primUrl; - QUrl secUrl; - - qreal _blend; - bool _smooth; - bool dirty; -#if defined(QFX_RENDER_OPENGL2) - GLTexture prim; - GLTexture sec; -#endif - QPixmap primPix; - QPixmap secPix; -}; -QML_DECLARE_TYPE(QFxBlendedImage) - - -QT_END_NAMESPACE - -QT_END_HEADER -#endif // QFXBLENDEDIMAGE_H diff --git a/src/declarative/fx/qfxflipable.cpp b/src/declarative/fx/qfxflipable.cpp index 4c02e74..0957c2f 100644 --- a/src/declarative/fx/qfxflipable.cpp +++ b/src/declarative/fx/qfxflipable.cpp @@ -220,21 +220,12 @@ void QFxFlipablePrivate::setBackTransform() axisRotation.setAngle(rotation); QSimpleCanvas::Matrix mat; -#ifdef QFX_RENDER_OPENGL - mat.translate(back->width()/2,back->height()/2, 0); - if (back->width() && p1.x() >= p2.x()) - mat.rotate(180, 0, 1, 0); - if (back->height() && p2.y() >= p3.y()) - mat.rotate(180, 1, 0, 0); - mat.translate(-back->width()/2,-back->height()/2, 0); -#else mat.translate(back->width()/2,back->height()/2); if (back->width() && p1.x() >= p2.x()) mat.rotate(180, Qt::YAxis); if (back->height() && p2.y() >= p3.y()) mat.rotate(180, Qt::XAxis); mat.translate(-back->width()/2,-back->height()/2); -#endif back->setTransform(mat); } @@ -318,21 +309,12 @@ void QFxFlipable::transformChanged(const QSimpleCanvas::Matrix &trans) d->current = newSide; if (d->current==Back) { QSimpleCanvas::Matrix mat; -#ifdef QFX_RENDER_OPENGL - mat.translate(d->back->width()/2,d->back->height()/2, 0); - if (d->back->width() && p1.x() >= p2.x()) - mat.rotate(180, 0, 1, 0); - if (d->back->height() && p2.y() >= p3.y()) - mat.rotate(180, 1, 0, 0); - mat.translate(-d->back->width()/2,-d->back->height()/2, 0); -#else mat.translate(d->back->width()/2,d->back->height()/2); if (d->back->width() && p1.x() >= p2.x()) mat.rotate(180, Qt::YAxis); if (d->back->height() && p2.y() >= p3.y()) mat.rotate(180, Qt::XAxis); mat.translate(-d->back->width()/2,-d->back->height()/2); -#endif d->back->setTransform(mat); } if (d->front) diff --git a/src/declarative/fx/qfxflipable.h b/src/declarative/fx/qfxflipable.h index 6630633..f00e023 100644 --- a/src/declarative/fx/qfxflipable.h +++ b/src/declarative/fx/qfxflipable.h @@ -44,9 +44,6 @@ #include <QtCore/QObject> #include <QtGui/QTransform> -#if defined(QFX_RENDER_OPENGL) -#include <QtGui/qmatrix4x4.h> -#endif #include <QtDeclarative/qfxitem.h> QT_BEGIN_HEADER diff --git a/src/declarative/fx/qfximage.cpp b/src/declarative/fx/qfximage.cpp index 40389c4..2ac035d 100644 --- a/src/declarative/fx/qfximage.cpp +++ b/src/declarative/fx/qfximage.cpp @@ -42,9 +42,6 @@ #include "qfximage.h" #include "qfximage_p.h" #include <qfxperf.h> -#if defined(QFX_RENDER_OPENGL) -#include <glsave.h> -#endif #include <QNetworkRequest> #include <QNetworkReply> #include <QFile> @@ -131,12 +128,6 @@ QFxImage::~QFxImage() QFxPixmap::cancelGet(d->url, this); if (!d->sciurl.isEmpty()) QFxPixmap::cancelGet(d->sciurl, this); -#if defined(QFX_RENDER_OPENGL) - if (d->tex) { - d->tex->release(); - d->tex = 0; - } -#endif } /*! @@ -164,13 +155,6 @@ void QFxImage::setPixmap(const QPixmap &pix) setImplicitWidth(d->pix.width()); setImplicitHeight(d->pix.height()); -#if defined(QFX_RENDER_OPENGL) - d->texDirty = true; - if (d->tex) { - d->tex->release(); - d->tex = 0; - } -#endif update(); } @@ -329,7 +313,6 @@ void QFxImage::dump(int depth) QFxItem::dump(depth); } -#if defined(QFX_RENDER_QPAINTER) void QFxImage::paintContents(QPainter &p) { Q_D(QFxImage); @@ -431,333 +414,6 @@ void QFxImage::paintContents(QPainter &p) if (d->smooth) p.setRenderHints(oldHints); } -#elif defined(QFX_RENDER_OPENGL) -uint QFxImage::glSimpleItemData(float *vertices, float *texVertices, - GLTexture **texture, uint count) -{ - Q_D(QFxImage); - - if (d->pix.isNull() || (d->scaleGrid && !d->scaleGrid->isNull())) - return 0; - - if (count < 8) - return 8; - - d->checkDirty(); - - float widthV = width(); - float heightV = height(); - - vertices[0] = 0; vertices[1] = heightV; - vertices[2] = widthV; vertices[3] = heightV; - vertices[4] = 0; vertices[5] = 0; - vertices[6] = widthV; vertices[7] = 0; - - *texture = d->tex; - - if (d->tiled) { - float tileWidth = widthV / d->pix.width(); - float tileHeight = heightV / d->pix.height(); - texVertices[0] = 0; texVertices[1] = 0; - texVertices[2] = tileWidth; texVertices[3] = 0; - texVertices[4] = 0; texVertices[5] = tileHeight; - texVertices[6] = tileWidth; texVertices[7] = tileHeight; - } else { - texVertices[0] = 0; texVertices[1] = 0; - texVertices[2] = d->tex->glWidth(); texVertices[3] = 0; - texVertices[4] = 0; texVertices[5] = d->tex->glHeight(); - texVertices[6] = d->tex->glWidth(); texVertices[7] = d->tex->glHeight(); - } - - return 8; -} - -void QFxImagePrivate::checkDirty() -{ - Q_Q(QFxImage); - if (texDirty && !pix.isNull()) - tex = q->cachedTexture(url.toString(), pix); - texDirty = false; -} - -#if defined(QFX_RENDER_OPENGL2) -void QFxImage::paintGLContents(GLPainter &p) -{ - Q_D(QFxImage); - if (d->pix.isNull()) - return; - - QGLShaderProgram *shader = p.useTextureShader(); - - bool restoreBlend = false; - if (p.blendEnabled && isOpaque() && p.activeOpacity == 1) { - glDisable(GL_BLEND); - restoreBlend = true; - } - - d->checkDirty(); - - if (d->tiled || (!d->scaleGrid || d->scaleGrid->isNull())) { - - if (!d->tiled) { - - float widthV = width(); - float heightV = height(); - float glWidth = d->tex->glWidth(); - float glHeight = d->tex->glHeight(); - - float deltaX = 0.5 / qreal(d->tex->glSize().width()); - float deltaY = 0.5 / qreal(d->tex->glSize().height()); - glWidth -= deltaX; - glHeight -= deltaY; - - - float vert[] = { - 0, heightV, - widthV, heightV, - 0, 0, - - widthV, heightV, - 0, 0, - widthV, 0 }; - - float tex[] = { - deltaX, deltaY, - glWidth, deltaY, - deltaX, glHeight, - - glWidth, deltaY, - deltaX, glHeight, - glWidth, glHeight - }; - - shader->setAttributeArray(SingleTextureShader::Vertices, vert, 2); - shader->setAttributeArray(SingleTextureShader::TextureCoords, tex, 2); - glBindTexture(GL_TEXTURE_2D, d->tex->texture()); - glDrawArrays(GL_TRIANGLES, 0, 6); - - } else { - - GLfloat vertices[8]; - GLfloat texVertices[8]; - GLTexture *tex = 0; - - QFxImage::glSimpleItemData(vertices, texVertices, &tex, 8); - - shader->setAttributeArray(SingleTextureShader::Vertices, vertices, 2); - shader->setAttributeArray(SingleTextureShader::TextureCoords, texVertices, 2); - - glBindTexture(GL_TEXTURE_2D, tex->texture()); - glDrawArrays(GL_TRIANGLE_STRIP, 0, 4); - } - - } else { - - float imgWidth = d->pix.width(); - float imgHeight = d->pix.height(); - if (!imgWidth || !imgHeight) { - if (restoreBlend) - glEnable(GL_BLEND); - return; - } - - float widthV = width(); - float heightV = height(); - float glWidth = d->tex->glWidth(); - float glHeight = d->tex->glHeight(); - float deltaX = 0.5 / qreal(d->tex->glSize().width()); - float deltaY = 0.5 / qreal(d->tex->glSize().height()); - glHeight -= deltaY; - glWidth -= deltaX; - - float texleft = deltaX; - float texright = glWidth; - float textop = glHeight; - float texbottom = deltaY; - float imgleft = 0; - float imgright = widthV; - float imgtop = 0; - float imgbottom = heightV; - - const int sgl = d->scaleGrid->left(); - const int sgr = d->scaleGrid->right(); - const int sgt = d->scaleGrid->top(); - const int sgb = d->scaleGrid->bottom(); - - if (sgl) { - texleft = deltaX + d->tex->glWidth() * float(sgl) / imgWidth; - imgleft = sgl; - } - if (sgr) { - texright = d->tex->glWidth() - float(sgr) / imgWidth - deltaX; - imgright = widthV - sgr; - } - if (sgt) { - textop = d->tex->glHeight() - float(sgb) / imgHeight - deltaY; - imgtop = sgt; - } - if (sgb) { - texbottom = deltaY + d->tex->glHeight() * float(sgt) / imgHeight; - imgbottom = heightV - sgb; - } - - float vert1[] = { 0, 0, - 0, imgtop, - imgleft, 0, - - 0, imgtop, - imgleft, 0, - imgleft, imgtop, - - imgleft, 0, - imgleft, imgtop, - imgright, 0, - - imgleft, imgtop, - imgright, 0, - imgright, imgtop, - - imgright, 0, - imgright, imgtop, - widthV, 0, - - imgright, imgtop, - widthV, 0, - widthV, imgtop, - - 0, imgtop, - 0, imgbottom, - imgleft, imgtop, - - 0, imgbottom, - imgleft, imgtop, - imgleft, imgbottom, - - imgleft, imgtop, - imgleft, imgbottom, - imgright, imgtop, - - imgleft, imgbottom, - imgright, imgtop, - imgright, imgbottom, - - imgright, imgtop, - imgright, imgbottom, - widthV, imgtop, - - imgright, imgbottom, - widthV, imgtop, - widthV, imgbottom, - - 0, imgbottom, - 0, heightV, - imgleft, imgbottom, - - 0, heightV, - imgleft, imgbottom, - imgleft, heightV, - - imgleft, imgbottom, - imgleft, heightV, - imgright, imgbottom, - - imgleft, heightV, - imgright, imgbottom, - imgright, heightV, - - imgright, imgbottom, - imgright, heightV, - widthV, imgbottom, - - imgright, heightV, - widthV, imgbottom, - widthV, heightV }; - - float tex1[] = { deltaX, glHeight, - deltaX, textop, - texleft, glHeight, - - deltaX, textop, - texleft, glHeight, - texleft, textop, - - texleft, glHeight, - texleft, textop, - texright, glHeight, - - texleft, textop, - texright, glHeight, - texright, textop, - - texright, glHeight, - texright, textop, - glWidth, glHeight, - - texright, textop, - glWidth, glHeight, - glWidth, textop, - - deltaX, textop, - deltaX, texbottom, - texleft, textop, - - deltaX, texbottom, - texleft, textop, - texleft, texbottom, - - texleft, textop, - texleft, texbottom, - texright, textop, - - texleft, texbottom, - texright, textop, - texright, texbottom, - - texright, textop, - texright, texbottom, - glWidth, textop, - - texright, texbottom, - glWidth, textop, - glWidth, texbottom, - - deltaX, texbottom, - deltaX, deltaY, - texleft, texbottom, - - deltaX, deltaY, - texleft, texbottom, - texleft, deltaY, - - texleft, texbottom, - texleft, deltaY, - texright, texbottom, - - texleft, deltaY, - texright, texbottom, - texright, deltaY, - - texright, texbottom, - texright, deltaY, - glWidth, texbottom, - - texright, deltaY, - glWidth, texbottom, - glWidth, deltaY }; - - glBindTexture(GL_TEXTURE_2D, d->tex->texture()); - - shader->setAttributeArray(SingleTextureShader::Vertices, vert1, 2); - shader->setAttributeArray(SingleTextureShader::TextureCoords, tex1, 2); - glDrawArrays(GL_TRIANGLES, 0, 54); - } - - if (restoreBlend) - glEnable(GL_BLEND); -} -#endif - -#endif QString QFxImage::propertyInfo() const { @@ -867,13 +523,6 @@ void QFxImage::setSource(const QUrl &url) d->progress = 1.0; setImplicitWidth(0); setImplicitHeight(0); -#if defined(QFX_RENDER_OPENGL) - d->texDirty = true; - if (d->tex) { - d->tex->release(); - d->tex = 0; - } -#endif emit statusChanged(d->status); emit sourceChanged(d->url); emit progressChanged(1.0); @@ -931,13 +580,6 @@ void QFxImage::requestFinished() if (d->status == Loading) d->status = Idle; d->progress = 1.0; -#if defined(QFX_RENDER_OPENGL) - d->texDirty = true; - if (d->tex) { - d->tex->release(); - d->tex = 0; - } -#endif emit statusChanged(d->status); emit sourceChanged(d->url); emit progressChanged(1.0); diff --git a/src/declarative/fx/qfximage.h b/src/declarative/fx/qfximage.h index 35b921a..039334a 100644 --- a/src/declarative/fx/qfximage.h +++ b/src/declarative/fx/qfximage.h @@ -93,13 +93,7 @@ public: virtual void dump(int depth); virtual QString propertyInfo() const; -#if defined(QFX_RENDER_QPAINTER) void paintContents(QPainter &painter); -#elif defined(QFX_RENDER_OPENGL) - void paintGLContents(GLPainter &); - uint glSimpleItemData(float *vertices, float *texVertices, - GLTexture **texture, uint count); -#endif Q_SIGNALS: void sourceChanged(const QUrl &); diff --git a/src/declarative/fx/qfximage_p.h b/src/declarative/fx/qfximage_p.h index 1785abb..e4a3a90 100644 --- a/src/declarative/fx/qfximage_p.h +++ b/src/declarative/fx/qfximage_p.h @@ -55,10 +55,6 @@ #include "qfxitem_p.h" -#if defined(QFX_RENDER_OPENGL) -#include "gltexture.h" -#endif - QT_BEGIN_NAMESPACE class QSvgRenderer; @@ -73,9 +69,6 @@ class QFxImagePrivate : public QFxItemPrivate public: QFxImagePrivate() : scaleGrid(0), tiled(false), smooth(false), opaque(false), -#if defined(QFX_RENDER_OPENGL) - texDirty(true), tex(0), -#endif status(QFxImage::Idle), sciReply(0), progress(0.0) { } @@ -99,11 +92,6 @@ public: bool tiled : 1; bool smooth : 1; bool opaque : 1; -#if defined(QFX_RENDER_OPENGL) - bool texDirty : 1; - void checkDirty(); - QSimpleCanvasItem::CachedTexture *tex; -#endif QFxImage::Status status; QUrl url; diff --git a/src/declarative/fx/qfxitem.cpp b/src/declarative/fx/qfxitem.cpp index 079d691..b4de109 100644 --- a/src/declarative/fx/qfxitem.cpp +++ b/src/declarative/fx/qfxitem.cpp @@ -62,7 +62,6 @@ #include "qfxitem_p.h" #include "qfxitem.h" #include "qfxevents_p.h" -#include <qsimplecanvasfilter.h> #include <qmlcomponent.h> @@ -73,7 +72,6 @@ QT_BEGIN_NAMESPACE QML_DEFINE_NOCREATE_TYPE(QFxContents) QML_DEFINE_TYPE(QFxItem,Item) -QML_DEFINE_NOCREATE_TYPE(QSimpleCanvasFilter) /*! \group group_animation @@ -1483,18 +1481,10 @@ void QFxItem::setRotation(qreal rotation) if (d->_rotation == rotation) return; d->_rotation = rotation; -#if defined(QFX_RENDER_OPENGL) - QMatrix4x4 trans; - QPointF to = transformOriginPoint(); - trans.translate(to.x(), to.y()); - trans.rotate(d->_rotation, 0, 0, 1); - trans.translate(-to.x(), -to.y()); -#else QPointF to = d->transformOrigin(); QTransform trans = QTransform::fromTranslate(to.x(), to.y()); trans.rotate(d->_rotation); trans.translate(-to.x(), -to.y()); -#endif setTransform(trans); emit rotationChanged(); } diff --git a/src/declarative/fx/qfxitem.h b/src/declarative/fx/qfxitem.h index 3c872e1..3188516 100644 --- a/src/declarative/fx/qfxitem.h +++ b/src/declarative/fx/qfxitem.h @@ -131,7 +131,6 @@ class Q_DECLARATIVE_EXPORT QFxItem : public QSimpleCanvasItem, public QmlParserS Q_PROPERTY(qreal rotation READ rotation WRITE setRotation NOTIFY rotationChanged) Q_PROPERTY(qreal scale READ scale WRITE setScale NOTIFY scaleChanged) Q_PROPERTY(qreal opacity READ opacity WRITE setOpacity NOTIFY opacityChanged) - Q_PROPERTY(QSimpleCanvasFilter *filter READ filter WRITE setFilter) Q_PROPERTY(bool clip READ clip WRITE setClip) Q_PROPERTY(bool focusable READ isFocusable WRITE setFocusable) Q_PROPERTY(bool focus READ hasFocus WRITE setFocus NOTIFY focusChanged) @@ -269,8 +268,6 @@ private: }; QML_DECLARE_TYPE(QFxItem) -QML_DECLARE_TYPE(QSimpleCanvasFilter) - QT_END_NAMESPACE QT_END_HEADER diff --git a/src/declarative/fx/qfxpainteditem.cpp b/src/declarative/fx/qfxpainteditem.cpp index 44adba7..850f20a 100644 --- a/src/declarative/fx/qfxpainteditem.cpp +++ b/src/declarative/fx/qfxpainteditem.cpp @@ -49,11 +49,6 @@ #include <QApplication> #include <QGraphicsSceneMouseEvent> -#if defined(QFX_RENDER_OPENGL2) -#include <QtOpenGL/qglframebufferobject.h> -#include <glsave.h> -#endif - QT_BEGIN_NAMESPACE /*! @@ -211,26 +206,16 @@ void QFxPaintedItem::init() connect(this,SIGNAL(visibleChanged()),this,SLOT(clearCache())); } -#if defined(QFX_RENDER_QPAINTER) /*! \reimp */ void QFxPaintedItem::paintContents(QPainter &p) -#elif defined(QFX_RENDER_OPENGL) -/*! - \reimp -*/ -void QFxPaintedItem::paintGLContents(GLPainter &p) -#else -#error "What render?" -#endif { Q_D(QFxPaintedItem); const QRect content(QPoint(0,0),d->contentsSize); if (content.width() <= 0 || content.height() <= 0) return; -#if defined(QFX_RENDER_QPAINTER) bool oldAntiAliasing = p.testRenderHint(QPainter::Antialiasing); bool oldSmoothPixmap = p.testRenderHint(QPainter::SmoothPixmapTransform); if (d->smooth) { @@ -243,29 +228,12 @@ void QFxPaintedItem::paintGLContents(GLPainter &p) else clipf = mapToScene(clipf); -#elif defined(QFX_RENDER_OPENGL2) - p.useTextureShader(); - const QRectF clipf = p.sceneClipRect; - -#elif defined(QFX_RENDER_OPENGL1) - p.useTextureShader(); - const QRectF clipf = p.sceneClipRect; -#endif - const QRect clip = mapFromScene(clipf).toRect(); QRegion topaint(clip); topaint &= content; QRegion uncached(content); -#if defined(QFX_RENDER_OPENGL2) - glEnableVertexAttribArray(SingleTextureShader::Vertices); - glEnableVertexAttribArray(SingleTextureShader::TextureCoords); -#elif defined(QFX_RENDER_OPENGL1) - glEnableClientState(GL_VERTEX_ARRAY); - glEnableClientState(GL_TEXTURE_COORD_ARRAY); -#endif - int cachesize=0; for (int i=0; i<d->imagecache.count(); ++i) { QRect area = d->imagecache[i]->area; @@ -312,29 +280,16 @@ void QFxPaintedItem::paintGLContents(GLPainter &p) } QFxPaintedItemPrivate::ImageCacheItem *newitem = new QFxPaintedItemPrivate::ImageCacheItem; newitem->area = r; -#if defined(QFX_RENDER_QPAINTER) newitem->image = img; -#else - newitem->image.setImage(img.toImage()); -#endif d->imagecache.append(newitem); QRectF target(r.x(), r.y(), r.width(), r.height()); p.drawPixmap(target.toRect(), newitem->image); } } -#if defined(QFX_RENDER_OPENGL2) - glDisableVertexAttribArray(SingleTextureShader::Vertices); - glDisableVertexAttribArray(SingleTextureShader::TextureCoords); -#elif defined(QFX_RENDER_OPENGL1) - glDisableClientState(GL_VERTEX_ARRAY); - glDisableClientState(GL_TEXTURE_COORD_ARRAY); -#endif -#if defined(QFX_RENDER_QPAINTER) if (d->smooth) { p.setRenderHints(QPainter::Antialiasing, oldAntiAliasing); p.setRenderHints(QPainter::SmoothPixmapTransform, oldSmoothPixmap); } -#endif } QT_END_NAMESPACE diff --git a/src/declarative/fx/qfxpainteditem.h b/src/declarative/fx/qfxpainteditem.h index e086894..ed254ce 100644 --- a/src/declarative/fx/qfxpainteditem.h +++ b/src/declarative/fx/qfxpainteditem.h @@ -63,11 +63,7 @@ public: Q_PROPERTY(QSize contentsSize READ contentsSize WRITE setContentsSize) Q_PROPERTY(bool smooth READ isSmooth WRITE setSmooth) -#if defined(QFX_RENDER_QPAINTER) void paintContents(QPainter &painter); -#elif defined(QFX_RENDER_OPENGL) - void paintGLContents(GLPainter &); -#endif bool isSmooth() const; QSize contentsSize() const; diff --git a/src/declarative/fx/qfxpainteditem_p.h b/src/declarative/fx/qfxpainteditem_p.h index d8d1a2a..ec507fb 100644 --- a/src/declarative/fx/qfxpainteditem_p.h +++ b/src/declarative/fx/qfxpainteditem_p.h @@ -56,10 +56,6 @@ #include <private/qfxitem_p.h> #include <QtDeclarative/qsimplecanvas.h> -#if defined(QFX_RENDER_OPENGL) -#include "gltexture.h" -#endif - QT_BEGIN_NAMESPACE class QFxPaintedItemPrivate : public QFxItemPrivate @@ -77,11 +73,7 @@ public: ~ImageCacheItem() { } int age; QRect area; -#if defined(QFX_RENDER_QPAINTER) QPixmap image; -#else - GLTexture image; -#endif }; QList<ImageCacheItem*> imagecache; diff --git a/src/declarative/fx/qfxparticles.cpp b/src/declarative/fx/qfxparticles.cpp index 4cd34c4..5e84c88 100644 --- a/src/declarative/fx/qfxparticles.cpp +++ b/src/declarative/fx/qfxparticles.cpp @@ -40,9 +40,6 @@ ****************************************************************************/ #include "qfxitem_p.h" -#if defined(QFX_RENDER_OPENGL) -#include "gltexture.h" -#endif #include <stdlib.h> #include <math.h> @@ -350,11 +347,7 @@ public: maxX = minX = maxY = minY = 0; } -#if defined(QFX_RENDER_QPAINTER) void paintContents(QPainter &p); -#elif defined(QFX_RENDER_OPENGL2) - void paintGLContents(GLPainter &); -#endif void updateSize(); @@ -375,9 +368,6 @@ public: , angle(0), angleDev(0), velocity(0), velocityDev(0) , addParticleTime(0), addParticleCount(0), lastAdvTime(0), stream(false), streamDelay(0) , emitting(true), motion(0), clock(this) -#if defined(QFX_RENDER_OPENGL) - , texDirty(true) -#endif { } @@ -418,10 +408,6 @@ public: QList<QFxParticle> particles; QTickAnimationProxy<QFxParticlesPrivate, &QFxParticlesPrivate::tick> clock; -#if defined(QFX_RENDER_OPENGL) - bool texDirty; - GLTexture tex; -#endif }; //TODO: Stop the clock if no visible particles and not emitting (restart on emittingChanged) @@ -654,10 +640,6 @@ void QFxParticles::imageLoaded() { Q_D(QFxParticles); d->image = QFxPixmap(d->url); -#if defined(QFX_RENDER_OPENGL) - d->texDirty = true; - d->tex.clear(); -#endif update(); } @@ -673,10 +655,6 @@ void QFxParticles::setSource(const QUrl &name) if (name.isEmpty()) { d->url = name; d->image = QPixmap(); -#if defined(QFX_RENDER_OPENGL) - d->texDirty = true; - d->tex.clear(); -#endif update(); } else { d->url = name; @@ -1106,7 +1084,6 @@ void QFxParticlesPainter::updateSize(){ setY(myY); } -#if defined(QFX_RENDER_QPAINTER) void QFxParticles::paintContents(QPainter &p) { Q_UNUSED(p); @@ -1129,64 +1106,6 @@ void QFxParticlesPainter::paintContents(QPainter &p) } update();//Should I need this? (GV does) } -#elif defined(QFX_RENDER_OPENGL2) -void QFxParticles::paintGLContents(GLPainter &) -{ - //painting is done by the ParticlesPainter, so it can have the right size -} - -void QFxParticlesPainter::paintGLContents(GLPainter &p) -{ - - if (d->image.isNull()) - return; - - updateSize(); - - if (d->texDirty && !d->image.isNull()) { - d->tex.setImage(d->image.toImage()); - d->tex.setHorizontalWrap(GLTexture::Repeat); - d->tex.setVerticalWrap(GLTexture::Repeat); - } - d->texDirty = false; - - SingleTextureOpacityShader *shader = basicShaders()->singleTextureOpacity(); - shader->enable(); - shader->setTransform(p.activeTransform); - - glBindTexture(GL_TEXTURE_2D, d->tex.texture()); - - const int myX = (int)(x() + parent()->x()); - const int myY = (int)(y() + parent()->y()); - float widthV = d->image.width(); - float heightV = d->image.height(); - for (int i = 0; i < d->particles.count(); ++i) { - const QFxParticle &particle = d->particles.at(i); - float left = particle.x - myX; - float right = particle.x - myX + widthV; - float top = particle.y - myY; - float bottom = particle.y - myY + heightV; - - GLfloat vertices[] = { left, bottom, - right, bottom, - left, top, - right, top }; - - GLfloat texVertices[] = { 0, 0, - 1, 0, - 0, 1, - 1, 1 }; - - shader->setAttributeArray(SingleTextureShader::Vertices, vertices, 2); - shader->setAttributeArray(SingleTextureShader::TextureCoords, texVertices, 2); - shader->setOpacity(particle.opacity * p.activeOpacity); - glDrawArrays(GL_TRIANGLE_STRIP, 0, 4); - } - - shader->disableAttributeArray(SingleTextureShader::Vertices); - shader->disableAttributeArray(SingleTextureShader::TextureCoords); -} -#endif void QFxParticles::componentComplete() { diff --git a/src/declarative/fx/qfxparticles.h b/src/declarative/fx/qfxparticles.h index b3a569b..a0373d7 100644 --- a/src/declarative/fx/qfxparticles.h +++ b/src/declarative/fx/qfxparticles.h @@ -44,10 +44,6 @@ #include <QtDeclarative/qfxitem.h> -#if defined(QFX_RENDER_OPENGL) -#include "gltexture.h" -#endif - QT_BEGIN_HEADER QT_BEGIN_NAMESPACE @@ -214,11 +210,7 @@ public: virtual void dump(int depth); virtual QString propertyInfo() const; -#if defined(QFX_RENDER_QPAINTER) void paintContents(QPainter &p); -#elif defined(QFX_RENDER_OPENGL2) - void paintGLContents(GLPainter &); -#endif protected: virtual void componentComplete(); diff --git a/src/declarative/fx/qfxrect.cpp b/src/declarative/fx/qfxrect.cpp index fd8d9ca..03ab426 100644 --- a/src/declarative/fx/qfxrect.cpp +++ b/src/declarative/fx/qfxrect.cpp @@ -251,17 +251,8 @@ QFxRect::QFxRect(QFxRectPrivate &dd, QFxItem *parent) void QFxRect::doUpdate() { -#if defined(QFX_RENDER_QPAINTER) Q_D(QFxRect); d->rectImage = QPixmap(); -#endif -#if defined(QFX_RENDER_OPENGL) - Q_D(QFxRect); - if (d->rectTexture) { - d->rectTexture->release(); - d->rectTexture = 0; - } -#endif const int pw = d->pen && d->pen->isValid() ? d->pen->width() : 0; setPaintMargin((pw+1)/2); update(); @@ -361,14 +352,7 @@ void QFxRect::setRadius(qreal radius) return; d->radius = radius; -#if defined(QFX_RENDER_QPAINTER) d->rectImage = QPixmap(); -#elif defined(QFX_RENDER_OPENGL) - if (d->rectTexture) { - d->rectTexture->release(); - d->rectTexture = 0; - } -#endif update(); } @@ -412,15 +396,7 @@ void QFxRect::setColor(const QColor &c) return; d->color = c; -#if defined(QFX_RENDER_QPAINTER) d->rectImage = QPixmap(); -#endif -#if defined(QFX_RENDER_OPENGL) - if (d->rectTexture) { - d->rectTexture->release(); - d->rectTexture = 0; - } -#endif update(); } @@ -488,7 +464,6 @@ QColor QFxRectPrivate::getColor() } -#if defined(QFX_RENDER_QPAINTER) void QFxRect::generateRoundedRect() { Q_D(QFxRect); @@ -528,65 +503,7 @@ void QFxRect::generateBorderedRect() p.drawRect(qreal(pw+1)/2, qreal(pw+1)/2, d->rectImage.width()-(pw+1)/2*2, d->rectImage.height()-(pw+1)/2*2); } } -#elif defined(QFX_RENDER_OPENGL) -void QFxRect::generateRoundedRect() -{ - Q_D(QFxRect); - if (!d->rectTexture) { - const int pw = d->pen && d->pen->isValid() ? d->pen->width() : 0; - QString key = QString("QFxRect://r_%1_%2_%3_%4").arg(pw).arg(d->radius).arg((d->pen && d->pen->isValid())?d->pen->color().name():QString()).arg(d->color.name()); - - d->rectTexture = cachedTexture(key); - - if (!d->rectTexture) { - QPixmap roundRect(d->radius*2 + 4 + pw*2, d->radius*2 + 4 + pw*2); - roundRect.fill(Qt::transparent); - QPainter p(&roundRect); - p.setRenderHint(QPainter::Antialiasing); - if (d->pen && d->pen->isValid()) { - QPen pn(QColor(pen()->color()), pen()->width()); - p.setPen(pn); - } else { - p.setPen(Qt::NoPen); - } - p.setBrush(d->color); - p.drawRoundedRect((pw+1)/2, (pw+1)/2, roundRect.width()-(pw+1)/2*2, roundRect.height()-(pw+1)/2*2, d->radius, d->radius); - - d->rectTexture = cachedTexture(key, roundRect); - } - } -} -void QFxRect::generateBorderedRect() -{ - Q_D(QFxRect); - if (!d->rectTexture) { - const int pw = d->pen && d->pen->isValid() ? d->pen->width() : 0; - QString key = QString("QFxRect://b_%1_%2_%3_%4").arg(pw).arg(d->radius).arg((d->pen && d->pen->isValid())?d->pen->color().name():QString()).arg(d->color.name()); - - d->rectTexture = cachedTexture(key); - - if (!d->rectTexture) { - QPixmap borderedRect(pw*2 + 4, pw*2 + 4); - borderedRect.fill(Qt::transparent); - QPainter p(&(borderedRect)); - p.setRenderHint(QPainter::Antialiasing); - if (d->pen && d->pen->isValid()) { - QPen pn(QColor(pen()->color()), pen()->width()); - p.setPen(pn); - } else { - p.setPen(Qt::NoPen); - } - p.setBrush(d->color); - p.drawRect(qreal(pw+1)/2, qreal(pw+1)/2, borderedRect.width()-(pw+1)/2*2, borderedRect.height()-(pw+1)/2*2); - d->rectTexture = cachedTexture(key, borderedRect); - } - } -} -#endif - - -#if defined(QFX_RENDER_QPAINTER) void QFxRect::paintContents(QPainter &p) { Q_D(QFxRect); @@ -687,258 +604,5 @@ void QFxRect::drawRect(QPainter &p) QRect(d->rectImage.width()-xOffset, d->rectImage.height() - yOffset, xOffset, yOffset)); } } -#endif - -#if defined(QFX_RENDER_OPENGL2) -#include "glbasicshaders.h" - -void QFxRect::paintGLContents(GLPainter &p) -{ - Q_D(QFxRect); - if (d->radius == 0 && (!d->pen || !d->pen->isValid())) { - if (d->gradient) { - float widthV = width(); - float heightV = height(); - - GLfloat vertices[] = { 0, heightV, - widthV, heightV, - 0, 0, - widthV, 0 }; - - int count = d->gradient->stops()->size(); - GLfloat colors[count*8]; - for (int i = 0; i < count; i += 8) { - QFxGradientStop *g = d->gradient->stops()->at(i); - QColor c = g->color(); - colors[i] = c.redF(); colors[i+4] = colors[i]; - colors[i+1] = c.greenF(); colors[i+5] = colors[i+1]; - colors[i+2] = c.blueF(); colors[i+6] = colors[i+2]; - colors[i+3] = c.alphaF() * p.activeOpacity; colors[i+7] = colors[i+3]; - } - - p.invalidate(); - ColorShader *shader = basicShaders()->color(); - shader->enable(); - shader->setTransform(p.activeTransform); - - shader->setAttributeArray(ColorShader::Vertices, vertices, 2); - shader->setAttributeArray(ColorShader::Colors, colors, 4); - glDrawArrays(GL_TRIANGLE_STRIP, 0, count*2); - shader->disableAttributeArray(ColorShader::Vertices); - shader->disableAttributeArray(ColorShader::Colors); - } else { - - p.fillRect(QRectF(0, 0, width(), height()), d->getColor()); - - } - } else { - qreal offset = 0; - qreal pw = d->pen && d->pen->isValid() ? d->pen->width() : 0.0; - - if (d->radius > 0) { - generateRoundedRect(); - offset = d->radius + pw+1.5; - } else { - generateBorderedRect(); - offset = pw+1.5; - } - - QGLShaderProgram *shader = p.useTextureShader(); - - float texWidth = d->rectTexture->width(); - float texHeight = d->rectTexture->height(); - if (!texWidth || !texHeight) - return; - - float widthV = qreal(width())+pw/2; - float heightV = qreal(height())+pw/2; - - float xOffset = offset; - bool xMiddles = true; - if (xOffset*2 > width()+pw) { - xMiddles = false; - xOffset = (width()+pw)/2; - } - float yOffset = offset; - bool yMiddles = true; - if (yOffset*2 > height()+pw) { - yMiddles = false; - yOffset = (height()+pw)/2; - } - - float texleft = xOffset / texWidth; - float imgleft = xOffset-pw/2; - float texright = (texWidth-xOffset) / texWidth; - float imgright = widthV - xOffset; - - float textop = yOffset / texHeight; - float imgtop = yOffset-pw/2; - float texbottom = (texHeight-yOffset) / texHeight; - float imgbottom = heightV - yOffset; - - //Bug 231768: Inappropriate interpolation was occuring on 3x3 textures - if (offset==1) - texleft=texright=textop=texbottom=0.5; - - texleft *= d->rectTexture->glWidth(); - texright *= d->rectTexture->glWidth(); - textop *= d->rectTexture->glHeight(); - texbottom *= d->rectTexture->glHeight(); - - float vert1[] = { -pw/2, -pw/2, - -pw/2, imgtop, - imgleft, -pw/2, - - -pw/2, imgtop, - imgleft, -pw/2, - imgleft, imgtop, - - imgleft, -pw/2, - imgleft, imgtop, - imgright, -pw/2, - - imgleft, imgtop, - imgright, -pw/2, - imgright, imgtop, - - imgright, -pw/2, - imgright, imgtop, - widthV, -pw/2, - - imgright, imgtop, - widthV, -pw/2, - widthV, imgtop, - - -pw/2, heightV, - -pw/2, imgbottom, - imgleft, heightV, - - -pw/2, imgbottom, - imgleft, heightV, - imgleft, imgbottom, - - imgleft, heightV, - imgleft, imgbottom, - imgright, heightV, - - imgleft, imgbottom, - imgright, heightV, - imgright, imgbottom, - - imgright, heightV, - imgright, imgbottom, - widthV, heightV, - - imgright, imgbottom, - widthV, heightV, - widthV, imgbottom, - - -pw/2, imgtop, - -pw/2, imgbottom, - imgleft, imgtop, - - -pw/2, imgbottom, - imgleft, imgtop, - imgleft, imgbottom, - - imgleft, imgtop, - imgleft, imgbottom, - imgright, imgtop, - - imgleft, imgbottom, - imgright, imgtop, - imgright, imgbottom, - - imgright, imgtop, - imgright, imgbottom, - widthV, imgtop, - - imgright, imgbottom, - widthV, imgtop, - widthV, imgbottom }; - - - float tex1[] = { 0, 0, - 0, textop, - texleft, 0, - - 0, textop, - texleft, 0, - texleft, textop, - - texleft, 0, - texleft, textop, - texright, 0, - - texleft, textop, - texright, 0, - texright, textop, - - texright, 0, - texright, textop, - d->rectTexture->glWidth(), 0, - - texright, textop, - d->rectTexture->glWidth(), 0, - d->rectTexture->glWidth(), textop, - - 0, d->rectTexture->glHeight(), - 0, texbottom, - texleft, d->rectTexture->glHeight(), - - 0, texbottom, - texleft, d->rectTexture->glHeight(), - texleft, texbottom, - - texleft, d->rectTexture->glHeight(), - texleft, texbottom, - texright, d->rectTexture->glHeight(), - - texleft, texbottom, - texright, d->rectTexture->glHeight(), - texright, texbottom, - - texright, d->rectTexture->glHeight(), - texright, texbottom, - d->rectTexture->glWidth(), d->rectTexture->glHeight(), - - texright, texbottom, - d->rectTexture->glWidth(), d->rectTexture->glHeight(), - d->rectTexture->glWidth(), texbottom, - - 0, textop, - 0, texbottom, - texleft, textop, - - 0, texbottom, - texleft, textop, - texleft, texbottom, - - texleft, textop, - texleft, texbottom, - texright, textop, - - texleft, texbottom, - texright, textop, - texright, texbottom, - - texright, textop, - texright, texbottom, - d->rectTexture->glWidth(), textop, - - texright, texbottom, - d->rectTexture->glWidth(), textop, - d->rectTexture->glWidth(), texbottom }; - - - - glBindTexture(GL_TEXTURE_2D, d->rectTexture->texture()); - - shader->setAttributeArray(SingleTextureShader::Vertices, vert1, 2); - shader->setAttributeArray(SingleTextureShader::TextureCoords, tex1, 2); - glDrawArrays(GL_TRIANGLES, 0, 36 + (yMiddles?18:0)); - } -} -#endif QT_END_NAMESPACE diff --git a/src/declarative/fx/qfxrect.h b/src/declarative/fx/qfxrect.h index c279a1c..d232328 100644 --- a/src/declarative/fx/qfxrect.h +++ b/src/declarative/fx/qfxrect.h @@ -160,13 +160,7 @@ public: void setRadius(qreal radius); virtual void dump(int depth); -#if defined(QFX_RENDER_QPAINTER) void paintContents(QPainter &painter); -#endif - -#if defined(QFX_RENDER_OPENGL) - void paintGLContents(GLPainter &); -#endif private Q_SLOTS: void doUpdate(); diff --git a/src/declarative/fx/qfxrect_p.h b/src/declarative/fx/qfxrect_p.h index 23bb944..3544d36 100644 --- a/src/declarative/fx/qfxrect_p.h +++ b/src/declarative/fx/qfxrect_p.h @@ -55,10 +55,6 @@ #include "qfxitem_p.h" -#if defined(QFX_RENDER_OPENGL) -#include "gltexture.h" -#endif - QT_BEGIN_NAMESPACE class QFxGradient; @@ -69,9 +65,6 @@ class QFxRectPrivate : public QFxItemPrivate public: QFxRectPrivate() : -#if defined(QFX_RENDER_OPENGL) - rectTexture(0), -#endif //QFX_RENDER_OPENGL color(Qt::white), gradient(0), pen(0), radius(0) { } @@ -85,9 +78,6 @@ public: { } -#if defined(QFX_RENDER_OPENGL) - QSimpleCanvasItem::CachedTexture *rectTexture; -#endif QColor getColor(); QColor color; QFxGradient *gradient; diff --git a/src/declarative/fx/qfxtext.cpp b/src/declarative/fx/qfxtext.cpp index 031c0f8..a5361e1 100644 --- a/src/declarative/fx/qfxtext.cpp +++ b/src/declarative/fx/qfxtext.cpp @@ -44,10 +44,6 @@ #include <private/qtextcontrol_p.h> -#if defined(QFX_RENDER_OPENGL2) -#include "glbasicshaders.h" -#endif - #include <qfxperf.h> #include <QTextLayout> #include <QTextLine> @@ -695,14 +691,9 @@ void QFxTextPrivate::checkImgCache() break; } -#if defined(QFX_RENDER_OPENGL) - tex.setImage(imgCache.toImage(), GLTexture::PowerOfTwo); -#endif - imgDirty = false; } -#if defined(QFX_RENDER_QPAINTER) void QFxText::paintContents(QPainter &p) { Q_D(QFxText); @@ -752,85 +743,6 @@ void QFxText::paintContents(QPainter &p) p.restore(); } -#elif defined(QFX_RENDER_OPENGL2) -void QFxText::paintGLContents(GLPainter &p) -{ - //return; - Q_D(QFxText); - d->checkImgCache(); - if (d->imgCache.isNull()) - return; - - int w = width(); - int h = height(); - - float x = 0; - float y = 0; - - switch (d->hAlign) { - case AlignLeft: - x = 0; - break; - case AlignRight: - x = w - d->imgCache.width(); - break; - case AlignHCenter: - x = (w - d->imgCache.width()) / 2; - break; - } - - switch (d->vAlign) { - case AlignTop: - y = 0; - break; - case AlignBottom: - y = h - d->imgCache.height(); - break; - case AlignVCenter: - y = (h - d->imgCache.height()) / 2; - break; - } - - float widthV = d->imgCache.width(); - float heightV = d->imgCache.height(); - float glWidth = d->tex.glWidth(); - float glHeight = d->tex.glHeight(); - - QGLShaderProgram *shader = p.useTextureShader(); - - float deltaX = 0.5 / qreal(d->tex.glSize().width()); - float deltaY = 0.5 / qreal(d->tex.glSize().height()); - glWidth -= deltaX; - glHeight -= deltaY; - - GLfloat vertices[] = { x, y + heightV, - x + widthV, y + heightV, - x, y, - - x + widthV, y + heightV, - x, y, - x + widthV, y }; - - GLfloat texVertices[] = { deltaX, deltaY, - glWidth, deltaY, - deltaX, glHeight, - - glWidth, deltaY, - deltaX, glHeight, - glWidth, glHeight }; - - shader->setAttributeArray(SingleTextureShader::Vertices, vertices, 2); - shader->setAttributeArray(SingleTextureShader::TextureCoords, texVertices, 2); - - glBindTexture(GL_TEXTURE_2D, d->tex.texture()); - glDrawArrays(GL_TRIANGLES, 0, 6); - - shader->disableAttributeArray(SingleTextureShader::Vertices); - shader->disableAttributeArray(SingleTextureShader::TextureCoords); -} - -#endif - void QFxText::componentComplete() { Q_D(QFxText); diff --git a/src/declarative/fx/qfxtext.h b/src/declarative/fx/qfxtext.h index 99ab2be..35e8b03 100644 --- a/src/declarative/fx/qfxtext.h +++ b/src/declarative/fx/qfxtext.h @@ -117,11 +117,7 @@ public: virtual void dump(int depth); virtual QString propertyInfo() const; -#if defined(QFX_RENDER_QPAINTER) void paintContents(QPainter &p); -#elif defined(QFX_RENDER_OPENGL) - void paintGLContents(GLPainter &); -#endif virtual void componentComplete(); diff --git a/src/declarative/fx/qfxtext_p.h b/src/declarative/fx/qfxtext_p.h index dfaef63..e0b1909 100644 --- a/src/declarative/fx/qfxtext_p.h +++ b/src/declarative/fx/qfxtext_p.h @@ -58,10 +58,6 @@ #include "qml.h" #include <QtGui/qtextlayout.h> -#if defined(QFX_RENDER_OPENGL) -#include "gltexture.h" -#endif - QT_BEGIN_NAMESPACE class QTextLayout; @@ -115,9 +111,6 @@ public: QColor styleColor; QString activeLink; bool imgDirty; -#if defined(QFX_RENDER_OPENGL) - GLTexture tex; -#endif QPixmap imgCache; QPixmap imgStyleCache; QFxText::HAlignment hAlign; diff --git a/src/declarative/fx/qfxtextedit.cpp b/src/declarative/fx/qfxtextedit.cpp index 5f2f36c..3c117ee 100644 --- a/src/declarative/fx/qfxtextedit.cpp +++ b/src/declarative/fx/qfxtextedit.cpp @@ -44,10 +44,6 @@ #include <private/qtextcontrol_p.h> -#if defined(QFX_RENDER_OPENGL2) -#include "glbasicshaders.h" -#endif - #include <qfxperf.h> #include "qfxevents_p.h" #include <QTextLayout> diff --git a/src/declarative/fx/qfxtextedit_p.h b/src/declarative/fx/qfxtextedit_p.h index f733a4c..403bd18 100644 --- a/src/declarative/fx/qfxtextedit_p.h +++ b/src/declarative/fx/qfxtextedit_p.h @@ -86,9 +86,6 @@ public: QString style; QColor styleColor; bool imgDirty; -#if defined(QFX_RENDER_OPENGL) - GLTexture texture; -#endif QPixmap imgCache; QPixmap imgStyleCache; QFxTextEdit::HAlignment hAlign; diff --git a/src/declarative/fx/qfxtransform.cpp b/src/declarative/fx/qfxtransform.cpp index a4c5d22..8d9084f 100644 --- a/src/declarative/fx/qfxtransform.cpp +++ b/src/declarative/fx/qfxtransform.cpp @@ -254,7 +254,6 @@ bool QFxRotation::isIdentity() const return (_angle == 0.); } -#if defined(QFX_RENDER_QPAINTER) QTransform QFxRotation::transform() const { if (_dirty) { @@ -266,19 +265,6 @@ QTransform QFxRotation::transform() const } return _transform; } -#elif defined(QFX_RENDER_OPENGL) -QMatrix4x4 QFxRotation::transform() const -{ - if (_dirty) { - _transform = QMatrix4x4(); - _dirty = false; - _transform.translate(_originX, _originY); - _transform.rotate(_angle, 0, 0, 1); - _transform.translate(-_originX, -_originY); - } - return _transform; -} -#endif void QFxRotation::update() { @@ -351,7 +337,6 @@ bool QFxRotation3D::isIdentity() const return (_angle == 0.) || (_axis.endZ() == 0. && _axis.endY() == _axis.startY() && _axis.endX() == _axis.startX()); } -#if defined(QFX_RENDER_QPAINTER) const qreal inv_dist_to_plane = 1. / 1024.; QTransform QFxRotation3D::transform() const { @@ -396,29 +381,6 @@ QTransform QFxRotation3D::transform() const return _transform; } -#elif defined(QFX_RENDER_OPENGL) -QMatrix4x4 QFxRotation3D::transform() const -{ - if (_dirty) { - _dirty = false; - _transform = QMatrix4x4(); - - if (!isIdentity()) { - if (angle() != 0.) { - qreal x = _axis.endX() - _axis.startX(); - qreal y = _axis.endY() - _axis.startY(); - qreal z = _axis.endZ(); - - _transform.translate(_axis.startX(), _axis.startY(), 0); - _transform.rotate(angle(), x, y, z); - _transform.translate(-_axis.startX(), -_axis.startY(), 0); - } - } - } - - return _transform; -} -#endif void QFxRotation3D::update() { @@ -506,7 +468,6 @@ bool QFxTranslation3D::isIdentity() const return (_distance == 0.) || (_axis.endZ() == 0. && _axis.endY() == _axis.startY() && _axis.endX() == _axis.startX()); } -#if defined(QFX_RENDER_QPAINTER) QTransform QFxTranslation3D::transform() const { if (_dirty) { @@ -526,35 +487,14 @@ QTransform QFxTranslation3D::transform() const return _transform; } -#elif defined(QFX_RENDER_OPENGL) -QMatrix4x4 QFxTranslation3D::transform() const -{ - if (_dirty) { - _dirty = false; - _transform = QMatrix4x4(); - - if (!isIdentity()) { - if (distance() != 0.) - _transform.translate((_axis.endX() - _axis.startX()) * distance(), - (_axis.endY() - _axis.startY()) * distance(), - (_axis.endZ()) * distance()); - - } - } - - return _transform; -} -#endif void QFxTranslation3D::update() { _dirty = true; -#if !defined(QFX_RENDER_OPENGL) if (_axis.endZ() != 0. && distance() != 0.) { qmlInfo(this) << "QTransform cannot translate along Z-axis."; } -#endif QFxTransform::update(); } @@ -579,24 +519,6 @@ QFxPerspective::~QFxPerspective() { } -#if defined(QFX_RENDER_OPENGL) -bool QFxPerspective::isIdentity() const -{ - return false; -} - -QMatrix4x4 QFxPerspective::transform() const -{ - QMatrix4x4 rv; - rv.translate(_x, _y); - rv.perspective(_angle, _aspect, 1, 1024 * 1024); - rv.translate(-_x, -_y, -1); - rv.scale(1, 1, 1. / _scale); - - return rv; -} -#endif - /*! \qmlproperty real Perspective::angle */ @@ -863,7 +785,6 @@ bool QFxSquish::isIdentity() const return false; } -#if defined(QFX_RENDER_QPAINTER) QTransform QFxSquish::transform() const { QPolygonF poly; @@ -875,21 +796,5 @@ QTransform QFxSquish::transform() const QTransform::quadToQuad(poly, poly2, t); return t; } -#elif defined(QFX_RENDER_OPENGL) -QMatrix4x4 QFxSquish::transform() const -{ - QPolygonF poly; - poly << p << QPointF(p.x() + s.width(), p.y()) << QPointF(p.x() + s.width(), p.y() + s.height()) << QPointF(p.x(), p.y() + s.height()); - QPolygonF poly2; - poly2 << p1 << p2 << p4 << p3; - - QTransform t; - QMatrix4x4 rv; - if (QTransform::quadToQuad(poly, poly2, t)) - rv = QMatrix4x4(t); - - return rv; -} -#endif QT_END_NAMESPACE diff --git a/src/declarative/fx/qfxtransform.h b/src/declarative/fx/qfxtransform.h index 7be8adc..0a17917 100644 --- a/src/declarative/fx/qfxtransform.h +++ b/src/declarative/fx/qfxtransform.h @@ -44,9 +44,6 @@ #include <QtCore/QObject> #include <QtGui/QTransform> -#if defined(QFX_RENDER_OPENGL) -#include <QtGui/qmatrix4x4.h> -#endif #include <QtDeclarative/qfxitem.h> QT_BEGIN_HEADER @@ -233,10 +230,6 @@ public: qreal scale() const { return _scale; } void setScale(qreal v) { _scale = v; update(); } -#if defined(QFX_RENDER_OPENGL) - virtual bool isIdentity() const; - virtual QMatrix4x4 transform() const; -#endif private: qreal _scale; qreal _x; diff --git a/src/declarative/fx/qfxwebview.cpp b/src/declarative/fx/qfxwebview.cpp index dc7f60e..91579e9 100644 --- a/src/declarative/fx/qfxwebview.cpp +++ b/src/declarative/fx/qfxwebview.cpp @@ -58,16 +58,7 @@ #include "qsimplecanvas.h" #include "qlistmodelinterface.h" -#if defined(QFX_RENDER_OPENGL2) -#include <QtOpenGL/qglframebufferobject.h> -#include <glsave.h> -#endif -#if defined(QFX_RENDER_OPENGL) -#include <gltexture.h> -#endif - #include "qfxwebview.h" -#include <qsimplecanvasfilter.h> #include <private/qfxpainteditem_p.h> QT_BEGIN_NAMESPACE @@ -160,11 +151,7 @@ public: ~ImageCacheItem() { } int age; QRect area; -#if defined(QFX_RENDER_QPAINTER) QPixmap image; -#else - GLTexture image; -#endif }; QList<ImageCacheItem*> imagecache; void dirtyCache(const QRect& dirt) diff --git a/src/declarative/opengl/glbasicshaders.cpp b/src/declarative/opengl/glbasicshaders.cpp deleted file mode 100644 index 7c1d730..0000000 --- a/src/declarative/opengl/glbasicshaders.cpp +++ /dev/null @@ -1,707 +0,0 @@ -/**************************************************************************** -** -** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies). -** Contact: Qt Software Information (qt-info@nokia.com) -** -** This file is part of the QtDeclarative module of the Qt Toolkit. -** -** $QT_BEGIN_LICENSE:LGPL$ -** No Commercial Usage -** This file contains pre-release code and may not be distributed. -** You may use this file in accordance with the terms and conditions -** contained in the either Technology Preview License Agreement or the -** Beta Release License Agreement. -** -** GNU Lesser General Public License Usage -** Alternatively, this file may be used under the terms of the GNU Lesser -** General Public License version 2.1 as published by the Free Software -** Foundation and appearing in the file LICENSE.LGPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU Lesser General Public License version 2.1 requirements -** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. -** -** In addition, as a special exception, Nokia gives you certain -** additional rights. These rights are described in the Nokia Qt LGPL -** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this -** package. -** -** GNU General Public License Usage -** Alternatively, this file may be used under the terms of the GNU -** General Public License version 3.0 as published by the Free Software -** Foundation and appearing in the file LICENSE.GPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU General Public License version 3.0 requirements will be -** met: http://www.gnu.org/copyleft/gpl.html. -** -** If you are unsure which license is appropriate for your use, please -** contact the sales department at qt-sales@nokia.com. -** $QT_END_LICENSE$ -** -****************************************************************************/ - -#include "glbasicshaders.h" -#include <QDebug> -#include <QColor> - - -QT_BEGIN_NAMESPACE -SingleTextureVertexOpacityShader::SingleTextureVertexOpacityShader() -{ - QGLShader vert(QGLShader::VertexShader); - QGLShader frag(QGLShader::FragmentShader); - - vert.compile("\ - attribute highp vec4 myVertex;\ - attribute lowp float myOpacity;\ - attribute mediump vec4 myUV;\ - uniform mediump mat4 myPMVMatrix;\ - varying mediump vec2 myTexCoord;\ - varying lowp float myFragOpacity;\ - void main(void)\ - {\ - gl_Position = myPMVMatrix * myVertex;\ - myTexCoord = myUV.st;\ - myFragOpacity = myOpacity;\ - }" - ); - - frag.compile("\ - uniform sampler2D sampler2d;\ - varying mediump vec2 myTexCoord;\ - varying lowp float myFragOpacity;\ - void main(void)\ - {\ - mediump vec4 frag = texture2D(sampler2d,myTexCoord);\ - gl_FragColor = vec4(frag.rgb, frag.a * myFragOpacity);\ - }" - ); - - addShader(&vert); - addShader(&frag); - - bindAttributeLocation("myVertex", Vertices); - bindAttributeLocation("myUV", TextureCoords); - bindAttributeLocation("myOpacity", OpacityCoords); -} - -bool SingleTextureVertexOpacityShader::link() -{ - if (!QGLShaderProgram::link()) - return false; - transform = uniformLocation("myPMVMatrix"); - enable(); - setUniformValue("sampler2d", 0); - disable(); - return true; -} - -void SingleTextureVertexOpacityShader::setTransform(const QMatrix4x4 &matrix) -{ - setUniformValue(transform, matrix); -} - -BlurTextureShader::BlurTextureShader() -{ - QGLShader vert(QGLShader::VertexShader); - QGLShader frag(QGLShader::FragmentShader); - - vert.compile("\ - attribute highp vec4 myVertex;\ - attribute mediump vec4 myUV;\ - uniform mediump mat4 myPMVMatrix;\ - varying mediump vec2 myTexCoord;\ - void main(void)\ - {\ - gl_Position = myPMVMatrix * myVertex;\ - myTexCoord = myUV.st;\ - }" - ); - -#if 0 - frag.compile("\ - uniform sampler2D sampler2d;\ - uniform bool horizontal; \ - uniform mediump float blurStep; \ - varying mediump vec2 myTexCoord;\ - void main(void)\ - {\ - mediump vec4 accum = vec4(0, 0, 0, 0); \ - mediump vec2 offset; \ - if (horizontal) \ - offset = vec2(blurStep, 0); \ - else \ - offset = vec2(0, blurStep); \ - accum += texture2D(sampler2d, myTexCoord + 2.0 * offset); \ - accum += 2.0 * texture2D(sampler2d, myTexCoord + 1.0 * offset); \ - accum += 4.0 * texture2D(sampler2d, myTexCoord + 0.0 * offset); \ - accum += 2.0 * texture2D(sampler2d, myTexCoord - 1.0 * offset); \ - accum += texture2D(sampler2d, myTexCoord - 2.0 * offset); \ - gl_FragColor = accum / 10.0; \ - }" - ); -#else - frag.compile("\ - uniform sampler2D sampler2d;\ - uniform bool horizontal; \ - uniform mediump float blurStep; \ - uniform int blurSteps; \ - varying mediump vec2 myTexCoord;\ - void main(void)\ - {\ - mediump vec4 accum = vec4(0, 0, 0, 0); \ - mediump vec2 offset; \ - if (horizontal) \ - offset = vec2(blurStep, 0); \ - else \ - offset = vec2(0, blurStep); \ - mediump float sum = 0.0; \ - for (int ii = 0; ii < blurSteps; ++ii) { \ - mediump float frac = float(blurSteps - ii) / float(blurSteps); \ - mediump vec2 coord = myTexCoord + -float(ii) * offset; \ - if (coord.x >= 0.0 && coord.y >= 0.0 && coord.y <= 1.0 && coord.x <=1.0) \ - accum += texture2D(sampler2d, coord) * frac; \ - sum += frac; \ - } \ - for (int ii = 1; ii < blurSteps; ++ii) { \ - mediump float frac = float(blurSteps - ii) / float(blurSteps); \ - mediump vec2 coord = myTexCoord + float(ii) * offset; \ - if (coord.x <= 1.0 && coord.y <= 1.0 && coord.x >= 0.0 && coord.y >= 0.0) \ - accum += texture2D(sampler2d, coord) * frac; \ - sum += frac; \ - } \ - gl_FragColor = accum / sum; \ - }" - ); -#endif - - addShader(&vert); - addShader(&frag); - - bindAttributeLocation("myVertex", Vertices); - bindAttributeLocation("myUV", TextureCoords); -} - -bool BlurTextureShader::link() -{ - if (!QGLShaderProgram::link()) - return false; - transform = uniformLocation("myPMVMatrix"); - mode = uniformLocation("horizontal"); - step = uniformLocation("blurStep"); - steps = uniformLocation("blurSteps"); - enable(); - setUniformValue("sampler2d", 0); - disable(); - return true; -} - -void BlurTextureShader::setStep(float f) -{ - setUniformValue(step, f); -} - -void BlurTextureShader::setSteps(int s) -{ - setUniformValue(steps, s); -} - -void BlurTextureShader::setMode(Mode m) -{ - if (m == Horizontal) - setUniformValue(mode, 1); - else - setUniformValue(mode, 0); -} - -void BlurTextureShader::setTransform(const QMatrix4x4 &matrix) -{ - setUniformValue(transform, matrix); -} - -DualTextureBlendShader::DualTextureBlendShader() -{ - QGLShader vert(QGLShader::VertexShader); - QGLShader frag(QGLShader::FragmentShader); - - vert.compile("\ - attribute highp vec4 myVertex;\ - attribute mediump vec4 myUV;\ - attribute mediump vec4 myBlendUV;\ - uniform mediump mat4 myPMVMatrix;\ - varying mediump vec2 myTexCoord;\ - varying mediump vec2 myBlendTexCoord;\ - void main(void)\ - {\ - gl_Position = myPMVMatrix * myVertex;\ - myTexCoord = myUV.st;\ - myBlendTexCoord = myBlendUV.st;\ - }" - ); - - frag.compile("\ - uniform sampler2D sampler2d;\ - uniform sampler2D sampler2dBlend;\ - uniform lowp float myOpacity;\ - uniform lowp float myBlend; \ - varying mediump vec2 myTexCoord;\ - varying mediump vec2 myBlendTexCoord;\ - void main(void)\ - {\ - mediump vec4 tex = texture2D(sampler2d,myTexCoord);\ - mediump vec4 blendtex = texture2D(sampler2dBlend, myBlendTexCoord);\ - gl_FragColor = mix(tex, blendtex, myBlend) * myOpacity; \ - }" - ); - - addShader(&vert); - addShader(&frag); - - bindAttributeLocation("myVertex", Vertices); - bindAttributeLocation("myUV", TextureCoords); - bindAttributeLocation("myBlendUV", BlendTextureCoords); -} - -bool DualTextureBlendShader::link() -{ - if (!QGLShaderProgram::link()) - return false; - transform = uniformLocation("myPMVMatrix"); - opacity = uniformLocation("myOpacity"); - blend = uniformLocation("myBlend"); - enable(); - setUniformValue("sampler2d", 0); - setUniformValue("sampler2dBlend", 1); - disable(); - return true; -} - -void DualTextureBlendShader::setOpacity(GLfloat o) -{ - setUniformValue(opacity, o); -} - -void DualTextureBlendShader::setBlend(GLfloat b) -{ - setUniformValue(blend, b); -} - -void DualTextureBlendShader::setTransform(const QMatrix4x4 &matrix) -{ - setUniformValue(transform, matrix); -} - -DualTextureAddShader::DualTextureAddShader() -{ - QGLShader vert(QGLShader::VertexShader); - QGLShader frag(QGLShader::FragmentShader); - - vert.compile("\ - attribute highp vec4 myVertex;\ - attribute mediump vec4 myUV;\ - attribute mediump vec4 myAddUV;\ - uniform mediump mat4 myPMVMatrix;\ - varying mediump vec2 myTexCoord;\ - varying mediump vec2 myAddTexCoord;\ - void main(void)\ - {\ - gl_Position = myPMVMatrix * myVertex;\ - myTexCoord = myUV.st;\ - myAddTexCoord = myAddUV.st;\ - }" - ); - - frag.compile("\ - uniform sampler2D sampler2d;\ - uniform sampler2D sampler2dAdd;\ - uniform lowp float myOpacity;\ - varying mediump vec2 myTexCoord;\ - varying mediump vec2 myAddTexCoord;\ - void main(void)\ - {\ - mediump vec4 tex = texture2D(sampler2d,myTexCoord);\ - mediump vec4 addtex = texture2D(sampler2dAdd, myAddTexCoord);\ - tex = tex + vec4(addtex.rgb * addtex.a * tex.a, 0); \ - tex = min(tex, vec4(1, 1, 1, 1)); \ - gl_FragColor = vec4(tex.rgb, tex.a) * myOpacity;\ - }" - ); - - addShader(&vert); - addShader(&frag); - - bindAttributeLocation("myVertex", Vertices); - bindAttributeLocation("myUV", TextureCoords); - bindAttributeLocation("myAddUV", AddTextureCoords); -} - -void DualTextureAddShader::setOpacity(GLfloat f) -{ - setUniformValue(opacity, f); -} - -void DualTextureAddShader::setTransform(const QMatrix4x4 &matrix) -{ - setUniformValue(transform, matrix); -} - -bool DualTextureAddShader::link() -{ - if (!QGLShaderProgram::link()) - return false; - transform = uniformLocation("myPMVMatrix"); - opacity = uniformLocation("myOpacity"); - enable(); - setUniformValue("sampler2d", 0); - setUniformValue("sampler2dAdd", 1); - disable(); - return true; -} - -SingleTextureShader::SingleTextureShader() -{ - QGLShader vert(QGLShader::VertexShader); - QGLShader frag(QGLShader::FragmentShader); - - vert.compile("\ - attribute highp vec4 myVertex;\ - attribute mediump vec4 myUV;\ - uniform mediump mat4 myPMVMatrix;\ - varying mediump vec2 myTexCoord;\ - void main(void)\ - {\ - gl_Position = myPMVMatrix * myVertex;\ - myTexCoord = myUV.st;\ - }" - ); - - frag.compile("\ - uniform sampler2D sampler2d;\ - varying mediump vec2 myTexCoord;\ - void main(void)\ - {\ - gl_FragColor = texture2D(sampler2d,myTexCoord);\ - }" - ); - - addShader(&vert); - addShader(&frag); - - bindAttributeLocation("myVertex", Vertices); - bindAttributeLocation("myUV", TextureCoords); -} - -bool SingleTextureShader::link() -{ - if (!QGLShaderProgram::link()) - return false; - transform = uniformLocation("myPMVMatrix"); - enable(); - setUniformValue("sampler2d", 0); - disable(); - return true; -} - -void SingleTextureShader::setTransform(const QMatrix4x4 &matrix) -{ - setUniformValue(transform, matrix); -} - -ConstantColorShader::ConstantColorShader() -{ - QGLShader vert(QGLShader::VertexShader); - QGLShader frag(QGLShader::FragmentShader); - - vert.compile("\ - uniform mediump mat4 myPMVMatrix;\ - attribute highp vec4 myVertex;\ - void main(void)\ - {\ - gl_Position = myPMVMatrix * myVertex; \ - }" - ); - - frag.compile("\ - uniform lowp vec4 myColor;\ - void main(void)\ - {\ - gl_FragColor = myColor;\ - }" - ); - - addShader(&vert); - addShader(&frag); - - bindAttributeLocation("myVertex", Vertices); -} - -void ConstantColorShader::setColor(const QColor &c) -{ - setUniformValue(color, c); -} - -void ConstantColorShader::setTransform(const QMatrix4x4 &matrix) -{ - setUniformValue(transform, matrix); -} - -bool ConstantColorShader::link() -{ - if (!QGLShaderProgram::link()) - return false; - transform = uniformLocation("myPMVMatrix"); - color = uniformLocation("myColor"); - return true; -} - -ColorShader::ColorShader() -{ - QGLShader vert(QGLShader::VertexShader); - QGLShader frag(QGLShader::FragmentShader); - - vert.compile("\ - uniform mediump mat4 myPMVMatrix;\ - attribute highp vec4 myVertex;\ - attribute lowp vec4 myColors;\ - varying lowp vec4 myColor;\ - void main(void)\ - {\ - gl_Position = myPMVMatrix * myVertex; \ - myColor = myColors; \ - }" - ); - - frag.compile("\ - varying lowp vec4 myColor;\ - void main(void)\ - {\ - gl_FragColor = myColor;\ - }" - ); - - addShader(&vert); - addShader(&frag); - - bindAttributeLocation("myVertex", Vertices); - bindAttributeLocation("myColors", Colors); -} - -void ColorShader::setTransform(const QMatrix4x4 &matrix) -{ - setUniformValue(transform, matrix); -} - -bool ColorShader::link() -{ - if (!QGLShaderProgram::link()) - return false; - transform = uniformLocation("myPMVMatrix"); - return true; -} - -class GLBasicShadersPrivate -{ -public: - GLBasicShadersPrivate(); - ~GLBasicShadersPrivate(); - - BlurTextureShader *blurTexture; - SingleTextureShader *singleTexture; - SingleTextureOpacityShader *singleTextureOpacity; - DualTextureAddShader *dualTextureAdd; - SingleTextureShadowShader *singleTextureShadow; - SingleTextureVertexOpacityShader *singleTextureVertexOpacity; - ConstantColorShader *constantColor; - ColorShader *color; -}; - -GLBasicShadersPrivate::GLBasicShadersPrivate() -: blurTexture(0), singleTexture(0), singleTextureOpacity(0), - dualTextureAdd(0), singleTextureShadow(0), singleTextureVertexOpacity(0), - constantColor(0), color(0) -{ -} - -GLBasicShadersPrivate::~GLBasicShadersPrivate() -{ - delete blurTexture; - delete singleTexture; - delete singleTextureOpacity; - delete dualTextureAdd; - delete singleTextureVertexOpacity; - delete singleTextureShadow; - delete constantColor; - delete color; -} - -GLBasicShaders::GLBasicShaders() -: d(new GLBasicShadersPrivate) -{ -} - -GLBasicShaders::~GLBasicShaders() -{ - delete d; -} - -BlurTextureShader *GLBasicShaders::blurTexture() -{ - if (!d->blurTexture) d->blurTexture = new BlurTextureShader(); - return d->blurTexture; -} - -SingleTextureShader *GLBasicShaders::singleTexture() -{ - if (!d->singleTexture) d->singleTexture = new SingleTextureShader(); - return d->singleTexture; -} - -SingleTextureOpacityShader *GLBasicShaders::singleTextureOpacity() -{ - if (!d->singleTextureOpacity) d->singleTextureOpacity = new SingleTextureOpacityShader(); - return d->singleTextureOpacity; -} - -DualTextureAddShader *GLBasicShaders::dualTextureAdd() -{ - if (!d->dualTextureAdd) d->dualTextureAdd = new DualTextureAddShader(); - return d->dualTextureAdd; -} - -SingleTextureVertexOpacityShader *GLBasicShaders::singleTextureVertexOpacity() -{ - if (!d->singleTextureVertexOpacity) d->singleTextureVertexOpacity = new SingleTextureVertexOpacityShader(); - return d->singleTextureVertexOpacity; -} - -SingleTextureShadowShader *GLBasicShaders::singleTextureShadow() -{ - if (!d->singleTextureShadow) d->singleTextureShadow = new SingleTextureShadowShader(); - return d->singleTextureShadow; -} - -ConstantColorShader *GLBasicShaders::constantColor() -{ - if (!d->constantColor) d->constantColor = new ConstantColorShader(); - return d->constantColor; -} - -ColorShader *GLBasicShaders::color() -{ - if (!d->color) d->color = new ColorShader(); - return d->color; -} - -SingleTextureOpacityShader::SingleTextureOpacityShader() -{ - QGLShader vert(QGLShader::VertexShader); - QGLShader frag(QGLShader::FragmentShader); - - vert.compile("\ - attribute highp vec4 myVertex;\ - attribute mediump vec4 myUV;\ - uniform mediump mat4 myPMVMatrix;\ - varying mediump vec2 myTexCoord;\ - void main(void)\ - {\ - gl_Position = myPMVMatrix * myVertex;\ - myTexCoord = myUV.st;\ - }" - ); - - frag.compile("\ - uniform sampler2D sampler2d;\ - uniform lowp float myOpacity;\ - varying mediump vec2 myTexCoord;\ - void main(void)\ - {\ - mediump vec4 tex = texture2D(sampler2d,myTexCoord);\ - gl_FragColor = vec4(tex.rgb, myOpacity * tex.a);\ - }" - ); - - addShader(&vert); - addShader(&frag); - - bindAttributeLocation("myVertex", Vertices); - bindAttributeLocation("myUV", TextureCoords); -} - -bool SingleTextureOpacityShader::link() -{ - if (!QGLShaderProgram::link()) - return false; - transform = uniformLocation("myPMVMatrix"); - opacity = uniformLocation("myOpacity"); - enable(); - setUniformValue("sampler2d", 0); - disable(); - return true; -} - -void SingleTextureOpacityShader::setTransform(const QMatrix4x4 &matrix) -{ - setUniformValue(transform, matrix); -} - -void SingleTextureOpacityShader::setOpacity(GLfloat f) -{ - setUniformValue(opacity, f); -} - -SingleTextureShadowShader::SingleTextureShadowShader() -{ - QGLShader vert(QGLShader::VertexShader); - QGLShader frag(QGLShader::FragmentShader); - - vert.compile("\ - attribute highp vec4 myVertex;\ - attribute mediump vec4 myUV;\ - uniform mediump mat4 myPMVMatrix;\ - varying mediump vec2 myTexCoord;\ - void main(void)\ - {\ - gl_Position = myPMVMatrix * myVertex;\ - myTexCoord = myUV.st;\ - }" - ); - - frag.compile("\ - uniform sampler2D sampler2d;\ - uniform lowp float myOpacity;\ - varying mediump vec2 myTexCoord;\ - void main(void)\ - {\ - mediump vec4 tex = texture2D(sampler2d,myTexCoord);\ - gl_FragColor = vec4(0, 0, 0, myOpacity * tex.a * .75);\ - }" - ); - - addShader(&vert); - addShader(&frag); - - bindAttributeLocation("myVertex", Vertices); - bindAttributeLocation("myUV", TextureCoords); -} - -bool SingleTextureShadowShader::link() -{ - if (!QGLShaderProgram::link()) - return false; - transform = uniformLocation("myPMVMatrix"); - opacity = uniformLocation("myOpacity"); - enable(); - setUniformValue("sampler2d", 0); - disable(); - return true; -} - -void SingleTextureShadowShader::setTransform(const QMatrix4x4 &matrix) -{ - setUniformValue(transform, matrix); -} - -void SingleTextureShadowShader::setOpacity(GLfloat f) -{ - setUniformValue(opacity, f); -} -QT_END_NAMESPACE diff --git a/src/declarative/opengl/glbasicshaders.h b/src/declarative/opengl/glbasicshaders.h deleted file mode 100644 index 7d358d8..0000000 --- a/src/declarative/opengl/glbasicshaders.h +++ /dev/null @@ -1,244 +0,0 @@ -/**************************************************************************** -** -** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies). -** Contact: Qt Software Information (qt-info@nokia.com) -** -** This file is part of the QtDeclarative module of the Qt Toolkit. -** -** $QT_BEGIN_LICENSE:LGPL$ -** No Commercial Usage -** This file contains pre-release code and may not be distributed. -** You may use this file in accordance with the terms and conditions -** contained in the either Technology Preview License Agreement or the -** Beta Release License Agreement. -** -** GNU Lesser General Public License Usage -** Alternatively, this file may be used under the terms of the GNU Lesser -** General Public License version 2.1 as published by the Free Software -** Foundation and appearing in the file LICENSE.LGPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU Lesser General Public License version 2.1 requirements -** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. -** -** In addition, as a special exception, Nokia gives you certain -** additional rights. These rights are described in the Nokia Qt LGPL -** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this -** package. -** -** GNU General Public License Usage -** Alternatively, this file may be used under the terms of the GNU -** General Public License version 3.0 as published by the Free Software -** Foundation and appearing in the file LICENSE.GPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU General Public License version 3.0 requirements will be -** met: http://www.gnu.org/copyleft/gpl.html. -** -** If you are unsure which license is appropriate for your use, please -** contact the sales department at qt-sales@nokia.com. -** $QT_END_LICENSE$ -** -****************************************************************************/ - -#ifndef _GLBASICSHADERS_H_ -#define _GLBASICSHADERS_H_ - -#include <QtOpenGL/qglshaderprogram.h> -#include <QtGui/qmatrix4x4.h> - - -QT_BEGIN_HEADER - -QT_BEGIN_NAMESPACE - -QT_MODULE(Declarative) -class BlurTextureShader : public QGLShaderProgram -{ - Q_OBJECT -public: - BlurTextureShader(); - - enum { Vertices = 0, - TextureCoords = 1 }; - - enum Mode { Horizontal, Vertical }; - void setMode(Mode); - void setStep(float); - void setSteps(int); - void setTransform(const QMatrix4x4 &); - virtual bool link(); - -private: - GLint mode; - GLint step; - GLint steps; - GLint transform; -}; - -class SingleTextureShader : public QGLShaderProgram -{ - Q_OBJECT -public: - SingleTextureShader(); - - enum { Vertices = 0, - TextureCoords = 1 }; - - void setTransform(const QMatrix4x4 &); - virtual bool link(); - -private: - GLint transform; -}; - -class DualTextureBlendShader : public QGLShaderProgram -{ - Q_OBJECT -public: - DualTextureBlendShader(); - enum { Vertices = 0, - TextureCoords = 1, - BlendTextureCoords = 2 }; - - void setOpacity(GLfloat); - void setBlend(GLfloat); - void setTransform(const QMatrix4x4 &); - virtual bool link(); - -private: - GLint transform; - GLint opacity; - GLint blend; -}; - -class DualTextureAddShader : public QGLShaderProgram -{ - Q_OBJECT -public: - DualTextureAddShader(); - enum { Vertices = 0, - TextureCoords = 1, - AddTextureCoords = 2 }; - - void setOpacity(GLfloat); - void setTransform(const QMatrix4x4 &); - virtual bool link(); - -private: - GLint transform; - GLint opacity; -}; - -class SingleTextureOpacityShader : public QGLShaderProgram -{ - Q_OBJECT -public: - SingleTextureOpacityShader(); - - enum { Vertices = 0, - TextureCoords = 1 }; - - void setOpacity(GLfloat); - void setTransform(const QMatrix4x4 &); - virtual bool link(); - -private: - GLint transform; - GLint opacity; -}; - -class SingleTextureVertexOpacityShader : public QGLShaderProgram -{ - Q_OBJECT -public: - SingleTextureVertexOpacityShader(); - - enum { Vertices = 0, - TextureCoords = 1, - OpacityCoords = 2 }; - - void setTransform(const QMatrix4x4 &); - virtual bool link(); - -private: - GLint transform; -}; - - -class SingleTextureShadowShader : public QGLShaderProgram -{ - Q_OBJECT -public: - SingleTextureShadowShader(); - - enum { Vertices = 0, - TextureCoords = 1 }; - - void setOpacity(GLfloat); - void setTransform(const QMatrix4x4 &); - virtual bool link(); - -private: - GLint transform; - GLint opacity; -}; - - -class QColor; -class ConstantColorShader : public QGLShaderProgram -{ - Q_OBJECT -public: - ConstantColorShader(); - - enum { Vertices = 0 }; - - void setColor(const QColor &); - void setTransform(const QMatrix4x4 &); - virtual bool link(); - -private: - GLint transform; - GLint color; -}; - -class ColorShader : public QGLShaderProgram -{ - Q_OBJECT -public: - ColorShader(); - - enum { Vertices = 0, Colors = 1 }; - - void setTransform(const QMatrix4x4 &); - virtual bool link(); - -private: - GLint transform; -}; - -class GLBasicShadersPrivate; -class GLBasicShaders -{ -public: - GLBasicShaders(); - virtual ~GLBasicShaders(); - - BlurTextureShader *blurTexture(); - SingleTextureShader *singleTexture(); - SingleTextureOpacityShader *singleTextureOpacity(); - DualTextureAddShader *dualTextureAdd(); - SingleTextureVertexOpacityShader *singleTextureVertexOpacity(); - SingleTextureShadowShader *singleTextureShadow(); - ConstantColorShader *constantColor(); - ColorShader *color(); - -private: - GLBasicShadersPrivate *d; -}; - -#endif // _GLBASICSHADERS_H_ - - -QT_END_NAMESPACE - -QT_END_HEADER diff --git a/src/declarative/opengl/glheaders.h b/src/declarative/opengl/glheaders.h deleted file mode 100644 index fd1da18..0000000 --- a/src/declarative/opengl/glheaders.h +++ /dev/null @@ -1,49 +0,0 @@ -/**************************************************************************** -** -** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies). -** Contact: Qt Software Information (qt-info@nokia.com) -** -** This file is part of the QtDeclarative module of the Qt Toolkit. -** -** $QT_BEGIN_LICENSE:LGPL$ -** No Commercial Usage -** This file contains pre-release code and may not be distributed. -** You may use this file in accordance with the terms and conditions -** contained in the either Technology Preview License Agreement or the -** Beta Release License Agreement. -** -** GNU Lesser General Public License Usage -** Alternatively, this file may be used under the terms of the GNU Lesser -** General Public License version 2.1 as published by the Free Software -** Foundation and appearing in the file LICENSE.LGPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU Lesser General Public License version 2.1 requirements -** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. -** -** In addition, as a special exception, Nokia gives you certain -** additional rights. These rights are described in the Nokia Qt LGPL -** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this -** package. -** -** GNU General Public License Usage -** Alternatively, this file may be used under the terms of the GNU -** General Public License version 3.0 as published by the Free Software -** Foundation and appearing in the file LICENSE.GPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU General Public License version 3.0 requirements will be -** met: http://www.gnu.org/copyleft/gpl.html. -** -** If you are unsure which license is appropriate for your use, please -** contact the sales department at qt-sales@nokia.com. -** $QT_END_LICENSE$ -** -****************************************************************************/ - -#ifndef _GLHEADERS_H_ -#define _GLHEADERS_H_ - -#include <QtDeclarative/qfxglobal.h> -#define GL_GLEXT_PROTOTYPES 1 -#include <QtOpenGL/qgl.h> - -#endif // _GLHEADERS_H_ diff --git a/src/declarative/opengl/glsave.cpp b/src/declarative/opengl/glsave.cpp deleted file mode 100644 index 125e81b..0000000 --- a/src/declarative/opengl/glsave.cpp +++ /dev/null @@ -1 +0,0 @@ -#include "glsave.h" diff --git a/src/declarative/opengl/glsave.h b/src/declarative/opengl/glsave.h deleted file mode 100644 index ad6c0ec..0000000 --- a/src/declarative/opengl/glsave.h +++ /dev/null @@ -1,111 +0,0 @@ -/**************************************************************************** -** -** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies). -** Contact: Qt Software Information (qt-info@nokia.com) -** -** This file is part of the QtDeclarative module of the Qt Toolkit. -** -** $QT_BEGIN_LICENSE:LGPL$ -** No Commercial Usage -** This file contains pre-release code and may not be distributed. -** You may use this file in accordance with the terms and conditions -** contained in the either Technology Preview License Agreement or the -** Beta Release License Agreement. -** -** GNU Lesser General Public License Usage -** Alternatively, this file may be used under the terms of the GNU Lesser -** General Public License version 2.1 as published by the Free Software -** Foundation and appearing in the file LICENSE.LGPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU Lesser General Public License version 2.1 requirements -** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. -** -** In addition, as a special exception, Nokia gives you certain -** additional rights. These rights are described in the Nokia Qt LGPL -** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this -** package. -** -** GNU General Public License Usage -** Alternatively, this file may be used under the terms of the GNU -** General Public License version 3.0 as published by the Free Software -** Foundation and appearing in the file LICENSE.GPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU General Public License version 3.0 requirements will be -** met: http://www.gnu.org/copyleft/gpl.html. -** -** If you are unsure which license is appropriate for your use, please -** contact the sales department at qt-sales@nokia.com. -** $QT_END_LICENSE$ -** -****************************************************************************/ - -#ifndef _GLSAVE_H_ -#define _GLSAVE_H_ - -#include <QtCore/qglobal.h> -#include <QtDeclarative/qfxglobal.h> -#include <QtCore/QRect> -#include "glheaders.h" - - -QT_BEGIN_HEADER - -QT_BEGIN_NAMESPACE - -QT_MODULE(Declarative) -class GLSaveViewport -{ -public: - GLSaveViewport() - { - glGetIntegerv(GL_VIEWPORT, viewport); - } - - ~GLSaveViewport() - { - glViewport(viewport[0], viewport[1], viewport[2], viewport[3]); - } - -private: - Q_DISABLE_COPY(GLSaveViewport) - GLint viewport[4]; -}; - -class GLSaveScissor -{ -public: - GLSaveScissor() - { - enabled = glIsEnabled(GL_SCISSOR_TEST); - glGetIntegerv(GL_SCISSOR_BOX, box); - } - - ~GLSaveScissor() - { - if (enabled) - glEnable(GL_SCISSOR_TEST); - else - glDisable(GL_SCISSOR_TEST); - glScissor(box[0], box[1], box[2], box[3]); - } - - bool wasEnabled() const - { - return enabled == GL_TRUE; - } - - QRect rect() const - { - return QRect(box[0], box[1], box[2], box[3]); - } - -private: - Q_DISABLE_COPY(GLSaveScissor) - GLint box[4]; - GLboolean enabled; -}; - -QT_END_NAMESPACE - -QT_END_HEADER -#endif // _GLSAVE_H_ diff --git a/src/declarative/opengl/gltexture.cpp b/src/declarative/opengl/gltexture.cpp deleted file mode 100644 index c2a02df..0000000 --- a/src/declarative/opengl/gltexture.cpp +++ /dev/null @@ -1,384 +0,0 @@ -/**************************************************************************** -** -** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies). -** Contact: Qt Software Information (qt-info@nokia.com) -** -** This file is part of the QtDeclarative module of the Qt Toolkit. -** -** $QT_BEGIN_LICENSE:LGPL$ -** No Commercial Usage -** This file contains pre-release code and may not be distributed. -** You may use this file in accordance with the terms and conditions -** contained in the either Technology Preview License Agreement or the -** Beta Release License Agreement. -** -** GNU Lesser General Public License Usage -** Alternatively, this file may be used under the terms of the GNU Lesser -** General Public License version 2.1 as published by the Free Software -** Foundation and appearing in the file LICENSE.LGPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU Lesser General Public License version 2.1 requirements -** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. -** -** In addition, as a special exception, Nokia gives you certain -** additional rights. These rights are described in the Nokia Qt LGPL -** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this -** package. -** -** GNU General Public License Usage -** Alternatively, this file may be used under the terms of the GNU -** General Public License version 3.0 as published by the Free Software -** Foundation and appearing in the file LICENSE.GPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU General Public License version 3.0 requirements will be -** met: http://www.gnu.org/copyleft/gpl.html. -** -** If you are unsure which license is appropriate for your use, please -** contact the sales department at qt-sales@nokia.com. -** $QT_END_LICENSE$ -** -****************************************************************************/ - -#include "gltexture.h" -#include <QImage> - - -QT_BEGIN_NAMESPACE -/*! - \internal - \class GLTexture - \brief The GLTexture class simplifies the use of OpenGL textures. -*/ - -// Copied from QGLWidget::convertToGLFormat -static QImage QGLWidget_convertToGLFormat(const QImage& img) -{ - QImage res = img.convertToFormat(QImage::Format_ARGB32); - res = res.mirrored(); - - if (QSysInfo::ByteOrder == QSysInfo::BigEndian) { - // Qt has ARGB; OpenGL wants RGBA - for (int i=0; i < res.height(); i++) { - uint *p = (uint*)res.scanLine(i); - uint *end = p + res.width(); - while (p < end) { - *p = (*p << 8) | ((*p >> 24) & 0xFF); - p++; - } - } - } - else { - // Qt has ARGB; OpenGL wants ABGR (i.e. RGBA backwards) - res = res.rgbSwapped(); - } - return res; -} -class GLTexturePrivate -{ -public: - GLTexturePrivate(GLTexture *_q) - : q(_q), texture(0), width(0), height(0), - horizWrap(GLTexture::Repeat), vertWrap(GLTexture::Repeat), - minFilter(GLTexture::Linear), magFilter(GLTexture::Linear), - glWidth(1.), glHeight(1.) - { - } - - GLTexture *q; - GLuint texture; - int width; - int height; - GLTexture::WrapMode horizWrap; - GLTexture::WrapMode vertWrap; - GLTexture::FilterMode minFilter; - GLTexture::FilterMode magFilter; - - qreal glWidth; - qreal glHeight; - QSize glSize; - - void genTexture(); -}; - -void GLTexturePrivate::genTexture() -{ - if (texture) - return; - - glGenTextures(1, &texture); - glBindTexture(GL_TEXTURE_2D, texture); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, minFilter); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, magFilter); - q->setHorizontalWrap(horizWrap); - q->setVerticalWrap(vertWrap); -} - -GLTexture::GLTexture() -: d(new GLTexturePrivate(this)) -{ -} - -GLTexture::GLTexture(const QString &file) -: d(new GLTexturePrivate(this)) -{ - QImage img(file); - if (!img.isNull()) - setImage(img); -} - -GLTexture::GLTexture(const QImage &img) -: d(new GLTexturePrivate(this)) -{ - setImage(img); -} - -GLTexture::~GLTexture() -{ - if (d->texture) - glDeleteTextures(1, &d->texture); - delete d; - d = 0; -} - -bool GLTexture::isNull() const -{ - return d->texture == 0; -} - -void GLTexture::clear() -{ - if (d->texture) { - glDeleteTextures(1, &d->texture); - d->texture = 0; - d->width = 0; - d->height = 0; - } -} - -static inline int npot(int size) -{ - size--; - size |= size >> 1; - size |= size >> 2; - size |= size >> 4; - size |= size >> 8; - size |= size >> 16; - size++; - return size; -} - -/*! - Set the texture to \a img. If the texture has already been created (either - by explicitly setting the size, or by previously setting an image), it will - be destroyed and a new texture created with \a img's contents and size. - */ -void GLTexture::setImage(const QImage &img, ImageMode mode) -{ - if (img.isNull()) - return; - - d->genTexture(); - - glBindTexture(GL_TEXTURE_2D, d->texture); - - if (mode == NonPowerOfTwo) { - - if (img.format() == QImage::Format_RGB16) { - QImage dataImage = img.mirrored(); - - glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, dataImage.width(), - dataImage.height(), 0, - GL_RGB, - GL_UNSIGNED_SHORT_5_6_5, dataImage.bits()); - } else { - QImage dataImage = QGLWidget_convertToGLFormat(img); - - glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, dataImage.width(), - dataImage.height(), 0, - (dataImage.format() == QImage::Format_ARGB32)?GL_RGBA:GL_RGB, - GL_UNSIGNED_BYTE, dataImage.bits()); - } - d->glWidth = 1.; - d->glHeight = 1.; - d->glSize = img.size(); - - } else { - // mode == PowerOfTwo - int max = (img.width() > img.height())?img.width():img.height(); - max = npot(max); - - if (img.format() == QImage::Format_RGB16) { - QImage dataImage = img.mirrored(); - - glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, max, - max, 0, - GL_RGB, - GL_UNSIGNED_SHORT_5_6_5, 0); - - glTexSubImage2D(GL_TEXTURE_2D, 0, 0, 0, dataImage.width(), - dataImage.height(), GL_RGB, GL_UNSIGNED_SHORT_5_6_5, - dataImage.bits()); - - } else { - QImage dataImage = QGLWidget_convertToGLFormat(img); - - glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, max, - max, 0, - (dataImage.format() == QImage::Format_ARGB32)?GL_RGBA:GL_RGB, - GL_UNSIGNED_BYTE, 0); - - glTexSubImage2D(GL_TEXTURE_2D, 0, 0, 0, dataImage.width(), - dataImage.height(), - (dataImage.format() == QImage::Format_ARGB32)?GL_RGBA:GL_RGB, - GL_UNSIGNED_BYTE, dataImage.bits()); - } - - d->glWidth = qreal(img.width()) / qreal(max); - d->glHeight = qreal(img.height()) / qreal(max); - d->glSize = QSize(max, max); - } - - d->width = img.width(); - d->height = img.height(); -} - -void GLTexture::copyImage(const QImage &img, const QPoint &point, - const QRect &srcRect) -{ - qFatal("Not implemented"); - Q_UNUSED(img); - Q_UNUSED(point); - Q_UNUSED(srcRect); -} - -QSize GLTexture::size() const -{ - return QSize(d->width, d->height); -} - -int GLTexture::width() const -{ - return d->width; -} - -int GLTexture::height() const -{ - return d->height; -} - -qreal GLTexture::glWidth() const -{ - return d->glWidth; -} - -qreal GLTexture::glHeight() const -{ - return d->glHeight; -} - -QSize GLTexture::glSize() const -{ - return d->glSize; -} - -/*! - Sets the \a size of the texture. This will destroy the current contents of - the texture. If an image has been assigned, it will need to be reassigned - using either setImage() or copyImage(). - - If size is invalid (width or height is less than or equal to 0) the texture - will be destroyed. This is equivalent to calling clear(). -*/ -void GLTexture::setSize(const QSize &size) -{ - if (size.width() <= 0 || size.height() <= 0) { - clear(); - return; - } - - d->genTexture(); - glBindTexture(GL_TEXTURE_2D, d->texture); - glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, size.width(), size.height(), 0, GL_RGBA, GL_UNSIGNED_BYTE, 0); - d->width = size.width(); - d->height = size.height(); -} - -GLTexture::WrapMode GLTexture::horizontalWrap() const -{ - return d->horizWrap; -} - -GLTexture::WrapMode GLTexture::verticalWrap() const -{ - return d->vertWrap; -} - -void GLTexture::setHorizontalWrap(WrapMode mode) -{ - d->horizWrap = mode; - if (d->texture) { - GLint last; - glGetIntegerv(GL_TEXTURE_BINDING_2D, &last); - if (GLuint(last) != d->texture) - glBindTexture(GL_TEXTURE_2D, d->texture); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, mode); - if (GLuint(last) != d->texture) - glBindTexture(GL_TEXTURE_2D, last); - } -} - -/*! - Set the veritcal wrap mode to \a mode. - */ -void GLTexture::setVerticalWrap(WrapMode mode) -{ - d->vertWrap = mode; - if (d->texture) { - GLint last; - glGetIntegerv(GL_TEXTURE_BINDING_2D, &last); - if (GLuint(last) != d->texture) - glBindTexture(GL_TEXTURE_2D, d->texture); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, mode); - if (GLuint(last) != d->texture) - glBindTexture(GL_TEXTURE_2D, last); - } -} - -GLTexture::FilterMode GLTexture::minFilter() const -{ - return d->minFilter; -} - -GLTexture::FilterMode GLTexture::magFilter() const -{ - return d->magFilter; -} - -void GLTexture::setMinFilter(FilterMode f) -{ - if (d->minFilter == f) - return; - d->minFilter = f; - if (d->texture) { - glBindTexture(GL_TEXTURE_2D, d->texture); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, d->minFilter); - } -} - -void GLTexture::setMagFilter(FilterMode f) -{ - if (d->magFilter == f) - return; - d->magFilter = f; - if (d->texture) { - glBindTexture(GL_TEXTURE_2D, d->texture); - glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, d->magFilter); - } -} - -GLuint GLTexture::texture() const -{ - return d->texture; -} - -QT_END_NAMESPACE diff --git a/src/declarative/opengl/gltexture.h b/src/declarative/opengl/gltexture.h deleted file mode 100644 index c08d68f..0000000 --- a/src/declarative/opengl/gltexture.h +++ /dev/null @@ -1,120 +0,0 @@ -/**************************************************************************** -** -** Copyright (C) 2009 Nokia Corporation and/or its subsidiary(-ies). -** Contact: Qt Software Information (qt-info@nokia.com) -** -** This file is part of the QtDeclarative module of the Qt Toolkit. -** -** $QT_BEGIN_LICENSE:LGPL$ -** No Commercial Usage -** This file contains pre-release code and may not be distributed. -** You may use this file in accordance with the terms and conditions -** contained in the either Technology Preview License Agreement or the -** Beta Release License Agreement. -** -** GNU Lesser General Public License Usage -** Alternatively, this file may be used under the terms of the GNU Lesser -** General Public License version 2.1 as published by the Free Software -** Foundation and appearing in the file LICENSE.LGPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU Lesser General Public License version 2.1 requirements -** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. -** -** In addition, as a special exception, Nokia gives you certain -** additional rights. These rights are described in the Nokia Qt LGPL -** Exception version 1.0, included in the file LGPL_EXCEPTION.txt in this -** package. -** -** GNU General Public License Usage -** Alternatively, this file may be used under the terms of the GNU -** General Public License version 3.0 as published by the Free Software -** Foundation and appearing in the file LICENSE.GPL included in the -** packaging of this file. Please review the following information to -** ensure the GNU General Public License version 3.0 requirements will be -** met: http://www.gnu.org/copyleft/gpl.html. -** -** If you are unsure which license is appropriate for your use, please -** contact the sales department at qt-sales@nokia.com. -** $QT_END_LICENSE$ -** -****************************************************************************/ - -#ifndef _GLTEXTURE_H_ -#define _GLTEXTURE_H_ - -#include <QtDeclarative/qfxglobal.h> - -#include <QtCore/QRect> -#include <QtCore/QPoint> -#include "glheaders.h" - - -QT_BEGIN_HEADER - -QT_BEGIN_NAMESPACE - -QT_MODULE(Declarative) - -class QString; -class QImage; -class GLTexturePrivate; -class Q_DECLARATIVE_EXPORT GLTexture -{ -public: - GLTexture(); - GLTexture(const QString &file); - GLTexture(const QImage &img); - virtual ~GLTexture(); - - bool isNull() const; - void clear(); - - enum ImageMode { NonPowerOfTwo, PowerOfTwo }; - void setImage(const QImage &, ImageMode = NonPowerOfTwo); - void copyImage(const QImage &, const QPoint & = QPoint(0, 0), const QRect & = QRect()); - - int width() const; - int height() const; - qreal glWidth() const; - qreal glHeight() const; - QSize glSize() const; - QSize size() const; - void setSize(const QSize &); - - enum WrapMode { - Repeat = GL_REPEAT, - ClampToEdge = GL_CLAMP_TO_EDGE, -#if defined(QFX_RENDER_OPENGL2) - MirroredRepeat = GL_MIRRORED_REPEAT, -#else - MirroredRepeat = Repeat -#endif - }; - - WrapMode horizontalWrap() const; - WrapMode verticalWrap() const; - void setHorizontalWrap(WrapMode); - void setVerticalWrap(WrapMode); - - enum FilterMode { - Nearest = GL_NEAREST, - Linear = GL_LINEAR, - MipmapLinear = GL_LINEAR_MIPMAP_LINEAR - }; - - FilterMode minFilter() const; - FilterMode magFilter() const; - void setMinFilter(FilterMode); - void setMagFilter(FilterMode); - - GLuint texture() const; -private: - Q_DISABLE_COPY(GLTexture) - GLTexturePrivate *d; -}; - - -QT_END_NAMESPACE - -QT_END_HEADER -#endif // _GLTEXTURE_H_ diff --git a/src/declarative/opengl/opengl.pri b/src/declarative/opengl/opengl.pri deleted file mode 100644 index c9ccefb..0000000 --- a/src/declarative/opengl/opengl.pri +++ /dev/null @@ -1,20 +0,0 @@ -DEPENDPATH += opengl -INCLUDEPATH += opengl -INCLUDEPATH += $$QMAKE_INCDIR_OPENGL -QT += opengl - -contains(QT_CONFIG, opengles1) { - SOURCES += gltexture.cpp \ - glsave.cpp - - HEADERS += gltexture.h \ - glsave.h -} else:contains(QT_CONFIG, opengles2) { - SOURCES += gltexture.cpp \ - glbasicshaders.cpp \ - glsave.cpp - - HEADERS += gltexture.h \ - glbasicshaders.h \ - glsave.h -} diff --git a/src/declarative/util/qfxglobal.h b/src/declarative/util/qfxglobal.h index 6ba9409..1f3d561f 100644 --- a/src/declarative/util/qfxglobal.h +++ b/src/declarative/util/qfxglobal.h @@ -51,39 +51,10 @@ QT_BEGIN_HEADER QT_BEGIN_NAMESPACE QT_MODULE(Declarative) -#if defined(QT_OPENGL_ES_1) -#define QFX_CONFIGURATION_OPENGL1 -#elif defined(QT_OPENGL_ES_2) -#define QFX_CONFIGURATION_OPENGL2 -#else -#define QFX_CONFIGURATION_SOFTWARE -#endif - -/* - The choices of renderer are: - QFX_RENDER_QPAINTER - QFX_RENDER_OPENGL1 - QFX_RENDER_OPENGL2 - To simplify code, if either of the OpenGL renderers are used, - QFX_RENDER_OPENGL is also defined. -*/ - -#if defined(QFX_CONFIGURATION_OPENGL2) - -#define QFX_RENDER_OPENGL -#define QFX_RENDER_OPENGL2 - -#elif defined(QFX_CONFIGURATION_OPENGL1) - -#define QFX_RENDER_OPENGL -#define QFX_RENDER_OPENGL1 - -#elif defined(QFX_CONFIGURATION_SOFTWARE) +#define QFX_CONFIGURATION_SOFTWARE #define QFX_RENDER_QPAINTER -#endif - #define DEFINE_BOOL_CONFIG_OPTION(name, var) \ static bool name() \ { \ |