summaryrefslogtreecommitdiffstats
path: root/src/plugins/platforms/directfb
diff options
context:
space:
mode:
authorHolger Hans Peter Freyther <holger@moiji-mobile.com>2011-11-18 21:09:03 +0100
committerQt by Nokia <qt-info@nokia.com>2011-11-24 08:31:02 +0100
commit6b22448fa3e27bb50ae8d9ee527ce262752c7874 (patch)
tree7288af482dd4fb2d8cf6edeca774bbe50b663341 /src/plugins/platforms/directfb
parent0948237d7f110876e143a49ebc196b69c1f5a7b2 (diff)
directfb: Access the screen layer through QWindow::screen()
Instead of assuming which layer was assigned to Qt, resolve the to be used layer via QWindow::screen()->handle(). Add a method to the DirectFB QPlatformScreen to provide a pointer to the IDirectFBDisplayLayer Change-Id: Iaea9466ca84daff752a4932deafbe38f48123715 Reviewed-by: Jørgen Lind <jorgen.lind@nokia.com>
Diffstat (limited to 'src/plugins/platforms/directfb')
-rw-r--r--src/plugins/platforms/directfb/qdirectfbconvenience.cpp9
-rw-r--r--src/plugins/platforms/directfb/qdirectfbconvenience.h6
-rw-r--r--src/plugins/platforms/directfb/qdirectfbscreen.cpp5
-rw-r--r--src/plugins/platforms/directfb/qdirectfbscreen.h3
-rw-r--r--src/plugins/platforms/directfb/qdirectfbwindow.cpp11
5 files changed, 30 insertions, 4 deletions
diff --git a/src/plugins/platforms/directfb/qdirectfbconvenience.cpp b/src/plugins/platforms/directfb/qdirectfbconvenience.cpp
index 440e9b00bc..61b20185c8 100644
--- a/src/plugins/platforms/directfb/qdirectfbconvenience.cpp
+++ b/src/plugins/platforms/directfb/qdirectfbconvenience.cpp
@@ -41,9 +41,13 @@
#include "qdirectfbconvenience.h"
#include "qdirectfbblitter.h"
+#include "qdirectfbscreen.h"
#include <private/qpixmap_blitter_p.h>
+#include <QtGui/QWindow>
+#include <QtGui/QScreen>
+
IDirectFB *QDirectFbConvenience::dfbInterface()
{
static IDirectFB *dfb = 0;
@@ -378,3 +382,8 @@ QDirectFbKeyMap::QDirectFbKeyMap()
insert(DIKS_CURLY_BRACKET_RIGHT , Qt::Key_BraceRight);
insert(DIKS_TILDE , Qt::Key_AsciiTilde);
}
+
+QDirectFbScreen *toDfbScreen(QWindow *window)
+{
+ return static_cast<QDirectFbScreen*>(window->screen()->handle());
+}
diff --git a/src/plugins/platforms/directfb/qdirectfbconvenience.h b/src/plugins/platforms/directfb/qdirectfbconvenience.h
index e7c9378ece..39409ac6bd 100644
--- a/src/plugins/platforms/directfb/qdirectfbconvenience.h
+++ b/src/plugins/platforms/directfb/qdirectfbconvenience.h
@@ -49,6 +49,9 @@
#include <directfb.h>
+
+class QDirectFbScreen;
+
class QDirectFbKeyMap: public QHash<DFBInputDeviceKeySymbol, Qt::Key>
{
public:
@@ -106,4 +109,7 @@ public:
}
};
+// Helper conversions from internal to DFB types
+QDirectFbScreen *toDfbScreen(QWindow *window);
+
#endif // QDIRECTFBCONVENIENCE_H
diff --git a/src/plugins/platforms/directfb/qdirectfbscreen.cpp b/src/plugins/platforms/directfb/qdirectfbscreen.cpp
index fbc3349581..c903a2995c 100644
--- a/src/plugins/platforms/directfb/qdirectfbscreen.cpp
+++ b/src/plugins/platforms/directfb/qdirectfbscreen.cpp
@@ -63,5 +63,10 @@ QDirectFbScreen::QDirectFbScreen(int display)
m_cursor.reset(new QDirectFBCursor(this));
}
+IDirectFBDisplayLayer *QDirectFbScreen::dfbLayer() const
+{
+ return m_layer.data();
+}
+
QT_END_NAMESPACE
diff --git a/src/plugins/platforms/directfb/qdirectfbscreen.h b/src/plugins/platforms/directfb/qdirectfbscreen.h
index 2b2f8d1d89..b719146c90 100644
--- a/src/plugins/platforms/directfb/qdirectfbscreen.h
+++ b/src/plugins/platforms/directfb/qdirectfbscreen.h
@@ -62,6 +62,9 @@ public:
QImage::Format format() const { return m_format; }
QSizeF physicalSize() const { return m_physicalSize; }
+ // DirectFb helpers
+ IDirectFBDisplayLayer *dfbLayer() const;
+
public:
QRect m_geometry;
int m_depth;
diff --git a/src/plugins/platforms/directfb/qdirectfbwindow.cpp b/src/plugins/platforms/directfb/qdirectfbwindow.cpp
index 0d32596631..4dd968ee60 100644
--- a/src/plugins/platforms/directfb/qdirectfbwindow.cpp
+++ b/src/plugins/platforms/directfb/qdirectfbwindow.cpp
@@ -40,18 +40,21 @@
****************************************************************************/
#include "qdirectfbwindow.h"
+#include "qdirectfbbackingstore.h"
#include "qdirectfbinput.h"
+#include "qdirectfbscreen.h"
-#include "qdirectfbbackingstore.h"
#include <directfb.h>
QDirectFbWindow::QDirectFbWindow(QWindow *tlw, QDirectFbInput *inputhandler)
: QPlatformWindow(tlw), m_inputHandler(inputhandler)
{
- QDirectFBPointer<IDirectFBDisplayLayer> layer(QDirectFbConvenience::dfbDisplayLayer());
DFBDisplayLayerConfig layerConfig;
- layer->GetConfiguration(layer.data(), &layerConfig);
+ IDirectFBDisplayLayer *layer;
+
+ layer = toDfbScreen(tlw)->dfbLayer();
+ toDfbScreen(tlw)->dfbLayer()->GetConfiguration(layer, &layerConfig);
DFBWindowDescription description;
memset(&description,0,sizeof(DFBWindowDescription));
@@ -75,7 +78,7 @@ QDirectFbWindow::QDirectFbWindow(QWindow *tlw, QDirectFbInput *inputhandler)
description.caps = DFBWindowCapabilities(DWCAPS_DOUBLEBUFFER|DWCAPS_ALPHACHANNEL);
description.surface_caps = DSCAPS_PREMULTIPLIED;
- DFBResult result = layer->CreateWindow(layer.data(), &description, m_dfbWindow.outPtr());
+ DFBResult result = layer->CreateWindow(layer, &description, m_dfbWindow.outPtr());
if (result != DFB_OK) {
DirectFBError("QDirectFbGraphicsSystemScreen: failed to create window",result);
}