summaryrefslogtreecommitdiff
path: root/noncore/graphics/opie-eye/gui/mainwindow.cpp
authoralwin <alwin>2004-04-20 22:58:27 (UTC)
committer alwin <alwin>2004-04-20 22:58:27 (UTC)
commitc61b410ba0051c266501933f7f675291684613f8 (patch) (side-by-side diff)
tree2bdb8278bb271bcb305652dea528709735b0a08d /noncore/graphics/opie-eye/gui/mainwindow.cpp
parent4348554f74290f477af9a338cdabf363883c9472 (diff)
downloadopie-c61b410ba0051c266501933f7f675291684613f8.zip
opie-c61b410ba0051c266501933f7f675291684613f8.tar.gz
opie-c61b410ba0051c266501933f7f675291684613f8.tar.bz2
some gui stuff - fullscreen now works better on smallscreen, bigscreen
has some more problems...
Diffstat (limited to 'noncore/graphics/opie-eye/gui/mainwindow.cpp') (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/graphics/opie-eye/gui/mainwindow.cpp63
1 files changed, 49 insertions, 14 deletions
diff --git a/noncore/graphics/opie-eye/gui/mainwindow.cpp b/noncore/graphics/opie-eye/gui/mainwindow.cpp
index 0484f73..a784f5b 100644
--- a/noncore/graphics/opie-eye/gui/mainwindow.cpp
+++ b/noncore/graphics/opie-eye/gui/mainwindow.cpp
@@ -30,7 +30,7 @@
#include <qdialog.h>
#include <qmap.h>
#include <qtimer.h>
-
+#include <qframe.h>
@@ -42,6 +42,7 @@ PMainWindow::PMainWindow(QWidget* wid, const char* name, WFlags style)
setCaption( QObject::tr("Opie Eye Caramba" ) );
m_cfg = new Opie::Core::OConfig("phunkview");
m_cfg->setGroup("Zecke_view" );
+ tFrame = 0;
// qDebug( "Process-wide OApplication object @ %0x", oApp );
/*
* Initialize ToolBar and IconView
@@ -128,11 +129,11 @@ PMainWindow::PMainWindow(QWidget* wid, const char* name, WFlags style)
connect(rotateButton,SIGNAL(toggled(bool)),this,SLOT(slotRotateToggled(bool)));
- btn = new QToolButton(bar);
- btn->setIconSet( Resource::loadIconSet( "1to1" ) );
- btn->setToggleButton(true);
- btn->setOn(false);
- connect(btn,SIGNAL(toggled(bool)),this,SLOT(slotScaleToggled(bool)));
+ scaleButton = new QToolButton(bar);
+ scaleButton->setIconSet( Resource::loadIconSet( "1to1" ) );
+ scaleButton->setToggleButton(true);
+ scaleButton->setOn(false);
+ connect(scaleButton,SIGNAL(toggled(bool)),this,SLOT(slotScaleToggled(bool)));
autoScale = true;
zoomButton = new QToolButton(bar);
@@ -145,6 +146,8 @@ PMainWindow::PMainWindow(QWidget* wid, const char* name, WFlags style)
PMainWindow::~PMainWindow() {
odebug << "Shutting down" << oendl;
+ if (tFrame) delete tFrame;
+ odebug << "Shutting down done" << oendl;
}
void PMainWindow::slotToggleZoomer()
@@ -162,6 +165,21 @@ void PMainWindow::slotZoomerToggled(bool how)
}
}
+void PMainWindow::slotToggleAutorotate()
+{
+ if (!m_disp) return;
+ if (!rotateButton->isEnabled()) return;
+ bool cur = rotateButton->isOn();
+ rotateButton->setOn(!cur);
+}
+
+void PMainWindow::slotToggleAutoscale()
+{
+ if (!m_disp) return;
+ bool cur = scaleButton->isOn();
+ scaleButton->setOn(!cur);
+}
+
void PMainWindow::slotRotateToggled(bool how)
{
autoRotate = how;
@@ -295,6 +313,8 @@ void PMainWindow::initDisp() {
connect(m_disp,SIGNAL(toggleFullScreen()),this,SLOT(slotToggleFullScreen()));
connect(m_disp,SIGNAL(hideMe()),this,SLOT(raiseIconView()));
connect(m_disp,SIGNAL(toggleZoomer()),this,SLOT(slotToggleZoomer()));
+ connect(m_disp,SIGNAL(toggleAutoscale()),this,SLOT(slotToggleAutoscale()));
+ connect(m_disp,SIGNAL(toggleAutorotate()),this,SLOT(slotToggleAutorotate()));
}
}
@@ -308,13 +328,22 @@ void PMainWindow::slotToggleFullScreen()
if (current) {
odebug << "full" << oendl;
m_disp->setBackgroundColor(black);
- m_disp->reparent(0,QPoint(0,0));
+ if (!tFrame) {
+ tFrame = new QWidget(0,0,WType_TopLevel|WStyle_NoBorder|WStyle_StaysOnTop);
+ tFrame->resize(qApp->desktop()->width(), qApp->desktop()->height());
+ tFrame->setMinimumSize(qApp->desktop()->width(), qApp->desktop()->height());
+ }
+ m_disp->reparent(tFrame,QPoint(0,0));
m_disp->setVScrollBarMode(QScrollView::AlwaysOff);
m_disp->setHScrollBarMode(QScrollView::AlwaysOff);
m_disp->resize(qApp->desktop()->width(), qApp->desktop()->height());
- m_disp->showFullScreen();
+ tFrame->showFullScreen();
} else {
odebug << "window" << oendl;
+ m_disp->reparent(0,QPoint(0,0));
+ m_disp->showNormal();
+ /* don't forget it! */
+ tFrame->hide();
m_disp->setBackgroundColor(white);
m_stack->addWidget(m_disp,ImageDisplay);
m_disp->setVScrollBarMode(QScrollView::Auto);
@@ -335,6 +364,9 @@ void PMainWindow::slotToggleFullScreen()
* ### FIXME and talk to alwin
*/
void PMainWindow::slotShowInfo( const QString& inf ) {
+ if (m_disp && m_disp->fullScreen() && m_disp->isVisible()) {
+ return;
+ }
if ( !m_info ) {
initInfo();
}
@@ -346,9 +378,6 @@ void PMainWindow::slotShowInfo( const QString& inf ) {
fsButton->hide();
viewModeButton->hide();
}
- if (m_disp && m_disp->fullScreen() && m_disp->isVisible()) {
- m_disp->hide();
- }
m_stack->raiseWidget( ImageInfo );
}
@@ -365,7 +394,8 @@ void PMainWindow::slotDisplay( const QString& inf ) {
viewModeButton->hide();
}
if (m_disp->fullScreen()) {
- m_disp->show();
+ tFrame->setActiveWindow();
+ tFrame->showFullScreen();
} else {
m_stack->raiseWidget( ImageDisplay );
}
@@ -383,10 +413,15 @@ void PMainWindow::closeEvent( QCloseEvent* ev ) {
*/
if ( m_stack->visibleWidget() == m_info ||
m_stack->visibleWidget() == m_disp ) {
- raiseIconView();
ev->ignore();
+ raiseIconView();
return;
}
+ if (m_disp && m_disp->fullScreen()) {
+ /* otherwise opie-eye crashes in bigscreen mode! */
+ m_disp->reparent(0,QPoint(0,0));
+ m_stack->addWidget(m_disp,ImageDisplay);
+ }
ev->accept();
QTimer::singleShot(0, qApp, SLOT(closeAllWindows()));
}
@@ -400,7 +435,7 @@ void PMainWindow::raiseIconView() {
viewModeButton->show();
}
if (m_disp && m_disp->fullScreen() && m_disp->isVisible()) {
- m_disp->hide();
+ tFrame->hide();
}
m_stack->raiseWidget( IconView );
}