summaryrefslogtreecommitdiff
Side-by-side diff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/applets/rotateapplet/rotate.cpp38
-rw-r--r--core/applets/rotateapplet/rotate.h2
2 files changed, 29 insertions, 11 deletions
diff --git a/core/applets/rotateapplet/rotate.cpp b/core/applets/rotateapplet/rotate.cpp
index e236cd1..4743388 100644
--- a/core/applets/rotateapplet/rotate.cpp
+++ b/core/applets/rotateapplet/rotate.cpp
@@ -28,22 +28,23 @@
#include <qpe/resource.h>
#include <qpe/qcopenvelope_qws.h>
#include <qpe/qpeapplication.h>
+#include <qpe/config.h>
#include <qiconset.h>
#include <qpopupmenu.h>
#include "rotate.h"
RotateApplet::RotateApplet ( )
: QObject ( 0, "RotateApplet" ), ref ( 0 )
{
- m_native = true;
+ m_flipped = false;
}
RotateApplet::~RotateApplet ( )
{
}
@@ -89,31 +90,48 @@ QPopupMenu *RotateApplet::popup ( QWidget * ) const
void RotateApplet::activated ( )
{
int currentRotation = QPEApplication::defaultRotation();
int newRotation;
- if ( m_native == true ) {
- newRotation = currentRotation + 90;
- if(newRotation >= 360) newRotation = 0; //ipaqs like the 36xx have the display
- //rotated to 270 as default, so 360 does nothing => handle this here
+ Config cfg( "qpe" );
+ cfg.setGroup( "Appearance" );
- } else {
- newRotation = currentRotation - 90;
- if (newRotation <=0) newRotation = 270;
+ // 0 -> 90° clockwise, 1 -> 90° counterclockwise
+ bool rotDirection = cfg.readBoolEntry( "rotatedir" );
+
+ // hide inputs methods before rotation
+ QCopEnvelope en( "QPE/TaskBar", "hideInputMethod()" );
+
+ if ( m_flipped ) {
+ if ( rotDirection ) {
+ newRotation = currentRotation - 90;
+ if (newRotation <=0) newRotation = 270;
//ipaqs like the 36xx have the display rotated
// to 270 as default, and -90 is invalid => handle this here
+ } else {
+ newRotation = currentRotation + 90;
+ if(newRotation >= 360) newRotation = 0; //ipaqs like the 36xx have the display
+ //rotated to 270 as default, so 360 does nothing => handle this here
+ }
+ } else {
+ if ( rotDirection ) {
+ newRotation = currentRotation + 90;
+ if(newRotation >= 360) newRotation = 0;
+ } else {
+ newRotation = currentRotation - 90;
+ if (newRotation <=0) newRotation = 270;
+ }
}
QCopEnvelope env( "QPE/System", "setCurrentRotation(int)" );
env << newRotation;
QCopEnvelope env2( "QPE/System", "setDefaultRotation(int)" );
env2 << newRotation;
- m_native = !m_native;
-
+ m_flipped = !m_flipped;
}
QRESULT RotateApplet::queryInterface ( const QUuid &uuid, QUnknownInterface **iface )
{
*iface = 0;
diff --git a/core/applets/rotateapplet/rotate.h b/core/applets/rotateapplet/rotate.h
index c4087f9..57f9040 100644
--- a/core/applets/rotateapplet/rotate.h
+++ b/core/applets/rotateapplet/rotate.h
@@ -51,11 +51,11 @@ public:
virtual QString tr( const char*, const char* ) const;
virtual QPopupMenu *popup ( QWidget *parent ) const;
virtual void activated ( );
private:
- bool m_native;
+ bool m_flipped;
ulong ref;
};
#endif