#include "fullscreenwindow.h"
#include "translucentbutton.h"
+#include "trace.h"
-FullScreenWindow::FullScreenWindow(QWidget *parent): QMainWindow(parent), child(0)
+FullScreenWindow::FullScreenWindow(QWidget *parent): AdopterWindow(parent)
{
Q_ASSERT(parent);
#ifdef Q_WS_MAEMO_5
setAttribute(Qt::WA_Maemo5StackedWindow, true);
setAttribute(Qt::WA_Maemo5NonComposited, true);
#endif // Q_WS_MAEMO_5
+#ifndef Q_OS_SYMBIAN
+ toolBar->hide();
+#endif
QFrame *frame = new QFrame(this);
QVBoxLayout *layout = new QVBoxLayout(frame);
layout->setMargin(0);
frame->setLayout(layout);
setCentralWidget(frame);
- restoreButton = new TranslucentButton("view-fullscreen", this);
+ restoreButton = new TranslucentButton("view-normal", this);
+ QRect screen = QApplication::desktop()->screenGeometry();
+ restoreButton->setGeometry((screen.width() - TranslucentButton::pixels) / 2,
+ screen.height() - TranslucentButton::pixels - 9,
+ TranslucentButton::pixels, TranslucentButton::pixels);
+ connect(restoreButton, SIGNAL(triggered()), this, SIGNAL(restore()));
}
void FullScreenWindow::showFullScreen()
testAttribute(Qt::WA_Maemo5LandscapeOrientation));
#endif // Q_WS_MAEMO_5
QWidget::showFullScreen();
- restoreButton->flash();
-}
-
-void FullScreenWindow::MOUSE_ACTIVATE_EVENT(QMouseEvent *event)
-{
- if (fullScreenZone().contains(event->x(), event->y())) {
- emit restore();
- }
- QMainWindow::MOUSE_ACTIVATE_EVENT(event);
-}
-
-QRect FullScreenWindow::fullScreenZone() const
-{
- return QRect(width() / 2 - 45, height() - 104, 95, 95);
+ restoreButton->flash(3000);
}
void FullScreenWindow::resizeEvent(QResizeEvent *e)
{
- restoreButton->setGeometry(fullScreenZone());
- QMainWindow::resizeEvent(e);
-}
-
-void FullScreenWindow::takeChild(QWidget *c)
-{
- leaveChild();
- if (c) {
- child = c;
- child->setParent(centralWidget());
- centralWidget()->layout()->addWidget(child);
- }
-}
-
-void FullScreenWindow::leaveChild()
-{
- if (child) {
- centralWidget()->layout()->removeWidget(child);
- child = 0;
- }
+ Q_UNUSED(e);
+ QRect screen = QApplication::desktop()->screenGeometry();
+ restoreButton->setGeometry(screen.width() - TranslucentButton::pixels - 9,
+ screen.height() - TranslucentButton::pixels - 9,
+ TranslucentButton::pixels, TranslucentButton::pixels);
}