Diffstat (limited to 'core/launcher/inputmethods.cpp') (more/less context) (show whitespace changes)
-rw-r--r-- | core/launcher/inputmethods.cpp | 76 |
1 files changed, 68 insertions, 8 deletions
diff --git a/core/launcher/inputmethods.cpp b/core/launcher/inputmethods.cpp index d89a366..8f3e812 100644 --- a/core/launcher/inputmethods.cpp +++ b/core/launcher/inputmethods.cpp @@ -79,50 +79,50 @@ int InputMethod::operator >(const InputMethod& o) const int InputMethod::operator <=(const InputMethod& o) const { return name() <= o.name(); } /* Slightly hacky: We use WStyle_Tool as a flag to say "this widget belongs to the IM system, so clicking it should not cause a reset". */ class IMToolButton : public QToolButton { public: IMToolButton::IMToolButton( QWidget *parent ) : QToolButton( parent ) { setWFlags( WStyle_Tool ); } }; InputMethods::InputMethods( QWidget *parent ) : QWidget( parent, "InputMethods", WStyle_Tool | WStyle_Customize ), mkeyboard(0), imethod(0) { Config cfg( "Launcher" ); cfg.setGroup( "InputMethods" ); - inputWidgetStyle = QWidget::WStyle_Customize | QWidget::WStyle_StaysOnTop | QWidget::WGroupLeader; - inputWidgetStyle |= cfg.readBoolEntry( "Float", false ) ? QWidget::WStyle_DialogBorder : QWidget::WStyle_Tool; + inputWidgetStyle = QWidget::WStyle_Customize | QWidget::WStyle_StaysOnTop | QWidget::WGroupLeader | QWidget::WStyle_Tool; + inputWidgetStyle |= cfg.readBoolEntry( "Float", false ) ? QWidget::WStyle_DialogBorder : 0; inputWidgetWidth = cfg.readNumEntry( "Width", 100 ); setBackgroundMode( PaletteBackground ); QHBoxLayout *hbox = new QHBoxLayout( this ); kbdButton = new IMToolButton( this); kbdButton->setFocusPolicy(NoFocus); kbdButton->setToggleButton( TRUE ); if (parent->sizeHint().height() > 0) kbdButton->setFixedHeight( parent->sizeHint().height() ); kbdButton->setFixedWidth( 32 ); kbdButton->setAutoRaise( TRUE ); kbdButton->setUsesBigPixmap( TRUE ); hbox->addWidget( kbdButton ); connect( kbdButton, SIGNAL(toggled(bool)), this, SLOT(showKbd(bool)) ); kbdChoice = new IMToolButton( this ); kbdChoice->setFocusPolicy(NoFocus); kbdChoice->setPixmap( QPixmap( (const char **)tri_xpm ) ); if (parent->sizeHint().height() > 0) kbdChoice->setFixedHeight( parent->sizeHint().height() ); kbdChoice->setFixedWidth( 13 ); kbdChoice->setAutoRaise( TRUE ); hbox->addWidget( kbdChoice ); @@ -511,56 +511,116 @@ void InputMethods::chooseMethod(InputMethod* im) if ( imethod && imethod->newIM ) QWSServer::setCurrentInputMethod( imethod->extInterface->inputMethod() ); else QWSServer::setCurrentInputMethod( 0 ); if ( im ) imButton->raiseWidget(im->widget); else imButton->hide(); //### good UI? make sure it is shown again! } } void InputMethods::qcopReceive( const QCString &msg, const QByteArray &data ) { if ( imethod && imethod->newIM ) imethod->extInterface->qcopReceive( msg, data ); } void InputMethods::showKbd( bool on ) { if ( !mkeyboard ) return; - if ( on ) { + if ( on ) + { mkeyboard->resetState(); - // HACK... Make the texteditor fit with all input methods - // Input methods should also never use more than about 40% of the screen + int height = QMIN( mkeyboard->widget->sizeHint().height(), 134 ); - mkeyboard->widget->resize( qApp->desktop()->width() * (inputWidgetWidth*0.01), height ); - mkeyboard->widget->move( 0, mapToGlobal( QPoint() ).y() - height ); + int width = qApp->desktop()->width() * (inputWidgetWidth*0.01); + int left = 0; + int top = mapToGlobal( QPoint() ).y() - height; + + if ( inputWidgetStyle & QWidget::WStyle_DialogBorder ) + { + qDebug( "InputMethods: reading geometry." ); + Config cfg( "Launcher" ); + cfg.setGroup( "InputMethods" ); + int l = cfg.readNumEntry( "absX", -1 ); + int t = cfg.readNumEntry( "absY", -1 ); + int w = cfg.readNumEntry( "absWidth", -1 ); + int h = cfg.readNumEntry( "absHeight", -1 ); + + if ( l > -1 && t > -1 && w > -1 && h > -1 ) + { + qDebug( "InputMethods: config values ( %d, %d, %d, %d ) are ok.", l, t, w, h ); + left = l; + top = t; + width = w; + height = h; + } + else + { + qDebug( "InputMethods: config values are new or not ok." ); + } + } + else + { + qDebug( "InputMethods: no floating selected." ); + } + mkeyboard->widget->resize( width, height ); + mkeyboard->widget->move( left, top ); mkeyboard->widget->show(); - } else { + mkeyboard->widget->installEventFilter( this ); + } + else + { + if ( inputWidgetStyle & QWidget::WStyle_DialogBorder ) + { + QPoint pos = mkeyboard->widget->pos(); + QSize siz = mkeyboard->widget->size(); + qDebug( "InputMethods: saving geometry." ); + Config cfg( "Launcher" ); + cfg.setGroup( "InputMethods" ); + cfg.writeEntry( "absX", pos.x() ); + cfg.writeEntry( "absY", pos.y() ); + cfg.writeEntry( "absWidth", siz.width() ); + cfg.writeEntry( "absHeight", siz.height() ); + cfg.write(); mkeyboard->widget->hide(); + mkeyboard->widget->removeEventFilter( this ); + } } emit inputToggled( on ); } bool InputMethods::shown() const { return mkeyboard && mkeyboard->widget->isVisible(); } QString InputMethods::currentShown() const { return mkeyboard && mkeyboard->widget->isVisible() ? mkeyboard->name() : QString::null; } void InputMethods::sendKey( ushort unicode, ushort scancode, ushort mod, bool press, bool repeat ) { #if defined(Q_WS_QWS) QWSServer::sendKeyEvent( unicode, scancode, mod, press, repeat ); #endif } + +bool InputMethods::eventFilter( QObject* o, QEvent* e ) +{ + if ( e->type() == QEvent::Close ) + { + ( (QCloseEvent*) e )->ignore(); + showKbd( false ); + kbdButton->setOn( false ); + return true; + } + return false; +} |