summaryrefslogtreecommitdiffstats
path: root/src/declarative/fx/qfxtextedit.cpp
diff options
context:
space:
mode:
authorWarwick Allison <warwick.allison@nokia.com>2009-05-08 02:26:58 (GMT)
committerWarwick Allison <warwick.allison@nokia.com>2009-05-08 02:26:58 (GMT)
commit1829f66c1564be7934aa400b78006a5f6ffc8dc9 (patch)
tree593ccb014a4a31a47824b082a1af0033b1722b28 /src/declarative/fx/qfxtextedit.cpp
parent43cf59754a08594157cf307d8e30405a795fa7aa (diff)
downloadQt-1829f66c1564be7934aa400b78006a5f6ffc8dc9.zip
Qt-1829f66c1564be7934aa400b78006a5f6ffc8dc9.tar.gz
Qt-1829f66c1564be7934aa400b78006a5f6ffc8dc9.tar.bz2
Allow control of cursor and of selection.
This allows components to implement look&feel such as select-all-on-focus, and to blink the cursor even when it is a proxy that actually has focus.
Diffstat (limited to 'src/declarative/fx/qfxtextedit.cpp')
-rw-r--r--src/declarative/fx/qfxtextedit.cpp42
1 files changed, 36 insertions, 6 deletions
diff --git a/src/declarative/fx/qfxtextedit.cpp b/src/declarative/fx/qfxtextedit.cpp
index bf7a16d..3bc9696 100644
--- a/src/declarative/fx/qfxtextedit.cpp
+++ b/src/declarative/fx/qfxtextedit.cpp
@@ -377,6 +377,28 @@ void QFxTextEdit::setWrap(bool w)
updateSize();
}
+/*!
+ \property QFxTextEdit::cursorVisible
+ \brief If true the text edit shows a cursor.
+
+ This property is set and unset when the text edit gets focus, but it can also
+ be set directly (useful, for example, if a KeyProxy might forward keys to it).
+*/
+bool QFxTextEdit::isCursorVisible() const
+{
+ Q_D(const QFxTextEdit);
+ return d->cursorVisible;
+}
+
+void QFxTextEdit::setCursorVisible(bool on)
+{
+ Q_D(QFxTextEdit);
+ if (d->cursorVisible == on)
+ return;
+ d->cursorVisible = on;
+ QFocusEvent focusEvent(on ? QEvent::FocusIn : QEvent::FocusOut);
+ d->control->processEvent(&focusEvent, QPointF(0, 0));
+}
void QFxTextEdit::geometryChanged(const QRectF &newGeometry,
const QRectF &oldGeometry)
@@ -591,8 +613,15 @@ void QFxTextEdit::keyReleaseEvent(QKeyEvent *event)
void QFxTextEdit::focusChanged(bool hasFocus)
{
Q_D(QFxTextEdit);
- QFocusEvent focusEvent(hasFocus ? QEvent::FocusIn : QEvent::FocusOut);
- d->control->processEvent(&focusEvent, QPointF(0, 0));
+}
+
+/*!
+ Causes all text to be selected.
+*/
+void QFxTextEdit::selectAll()
+{
+ Q_D(QFxTextEdit);
+ d->control->selectAll();
}
static QMouseEvent *sceneMouseEventToMouseEvent(QGraphicsSceneMouseEvent *e)
@@ -737,6 +766,7 @@ void QFxTextEditPrivate::init()
document->setDocumentMargin(0);
document->setUndoRedoEnabled(false); // flush undo buffer.
document->setUndoRedoEnabled(true);
+ updateDefaultTextOption();
}
void QFxTextEdit::q_textChanged()
@@ -785,14 +815,13 @@ void QFxTextEdit::updateSize()
void QFxTextEditPrivate::updateDefaultTextOption()
{
- QTextDocument *doc = control->document();
-
- QTextOption opt = doc->defaultTextOption();
+ QTextOption opt = document->defaultTextOption();
int oldAlignment = opt.alignment();
opt.setAlignment((Qt::Alignment)(int)(hAlign | vAlign));
QTextOption::WrapMode oldWrapMode = opt.wrapMode();
+qDebug() << "wrap mode is" << opt.wrapMode();
if (wrap)
opt.setWrapMode(QTextOption::WordWrap);
else
@@ -800,7 +829,8 @@ void QFxTextEditPrivate::updateDefaultTextOption()
if (oldWrapMode == opt.wrapMode() && oldAlignment == opt.alignment())
return;
- doc->setDefaultTextOption(opt);
+qDebug() << "wrap mode set to" << opt.wrapMode();
+ document->setDefaultTextOption(opt);
}
QT_END_NAMESPACE