Home | All Classes | Main Classes | Annotated | Grouped Classes | Functions | ![]() |
The QIMEvent class provides parameters for input method events. More...
#include <QIMEvent>
Inherits QInputEvent.
The QIMEvent class provides parameters for input method events.
Input method events are sent to widgets when an input method is used to enter text into a widget. Input methods are widely used to enter text for languages with non-Latin alphabets.
The events are of interest to authors of keyboard entry widgets who want to be able to correctly handle languages with complex character input. Text input in such languages is usually a three step process.
These three stages are represented by three different types of events: IMStartEvent, IMComposeEvent, and IMEndEvent. When a new input context is created, an IMStartEvent will be sent to the widget and delivered to the QWidget::imStartEvent() function. The widget can then update internal data structures to reflect this.
After this, an IMComposeEvent will be sent to the widget for every key the user presses. It will contain the current composition string the widget has to show and the current cursor position within the composition string. This string is temporary and can change with every key the user types, so the widget will need to store the state before the composition started (the state it had when it received the IMStartEvent). IMComposeEvents will be delivered to the QWidget::imComposeEvent() function.
Usually, widgets try to mark the part of the text that is part of the current composition in a way that is visible to the user. A commonly used visual cue is to use a dotted underline.
After the user has selected the final string, an IMEndEvent will be sent to the widget. The event contains the final string the user selected, and could be empty if they canceled the composition. This string should be accepted as the final text the user entered, and the intermediate composition string should be cleared. These events are delivered to QWidget::imEndEvent().
If the user clicks another widget, taking the focus out of the widget where the composition is taking place, the IMEndEvent will be sent and the string it holds will be the result of the composition up to that point (which may be an empty string).
Constructs a new QIMEvent with the accept flag set to false. The event type can be QEvent::IMStartEvent, QEvent::IMComposeEvent, or QEvent::IMEndEvent. The text contains the current compostion string, and cursorPosition is the current position of the cursor inside the text. selLength characters are selected (default is 0).
Returns the current cursor position inside the composition string. Will return -1 for IMStartEvent and IMEndEvent.
Returns the number of characters in the composition string, starting at cursorPos(), that should be marked as selected by the input widget receiving the event. Will return 0 for IMStartEvent and IMEndEvent.
Returns the composition text. This is a null string for an IMStartEvent, and contains the final accepted string (which may be empty) in the IMEndEvent.
Copyright © 2004 Trolltech. | Trademarks | Qt 4.0.0-tp1 |