mirror of
https://github.com/qTox/qTox.git
synced 2024-03-22 14:00:36 +08:00
Text: extractSanitizedText, hookup double-click selection
This commit is contained in:
parent
1fd456833c
commit
b5b6ae99c0
@ -77,36 +77,7 @@ void Text::selectionMouseMove(QPointF scenePos)
|
|||||||
if(cur >= 0)
|
if(cur >= 0)
|
||||||
{
|
{
|
||||||
selectionEnd = cur;
|
selectionEnd = cur;
|
||||||
selectedText.clear();
|
selectedText = extractSanitizedText(getSelectionStart(), getSelectionEnd());
|
||||||
|
|
||||||
QTextBlock block = doc->firstBlock();
|
|
||||||
for(QTextBlock::Iterator itr = block.begin(); itr!=block.end(); ++itr)
|
|
||||||
{
|
|
||||||
int pos = itr.fragment().position(); //fragment position -> position of the first character in the fragment
|
|
||||||
|
|
||||||
if(itr.fragment().charFormat().isImageFormat())
|
|
||||||
{
|
|
||||||
QTextImageFormat imgFmt = itr.fragment().charFormat().toImageFormat();
|
|
||||||
QString key = imgFmt.name(); //img key (eg. key::D for :D)
|
|
||||||
QString rune = key.mid(4);
|
|
||||||
|
|
||||||
if(pos >= getSelectionStart() && pos < getSelectionEnd())
|
|
||||||
{
|
|
||||||
selectedText += rune;
|
|
||||||
pos++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
for(QChar c : itr.fragment().text())
|
|
||||||
{
|
|
||||||
if(pos >= getSelectionStart() && pos < getSelectionEnd())
|
|
||||||
selectedText += c;
|
|
||||||
|
|
||||||
pos++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
update();
|
update();
|
||||||
@ -148,6 +119,8 @@ void Text::selectionDoubleClick(QPointF scenePos)
|
|||||||
|
|
||||||
selectionAnchor = cursor.selectionStart();
|
selectionAnchor = cursor.selectionStart();
|
||||||
selectionEnd = cursor.selectionEnd();
|
selectionEnd = cursor.selectionEnd();
|
||||||
|
|
||||||
|
selectedText = extractSanitizedText(getSelectionStart(), getSelectionEnd());
|
||||||
}
|
}
|
||||||
|
|
||||||
update();
|
update();
|
||||||
@ -322,3 +295,42 @@ bool Text::hasSelection() const
|
|||||||
{
|
{
|
||||||
return selectionEnd >= 0;
|
return selectionEnd >= 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QString Text::extractSanitizedText(int from, int to) const
|
||||||
|
{
|
||||||
|
if(!doc)
|
||||||
|
return "";
|
||||||
|
|
||||||
|
QString txt;
|
||||||
|
QTextBlock block = doc->firstBlock();
|
||||||
|
|
||||||
|
for(QTextBlock::Iterator itr = block.begin(); itr!=block.end(); ++itr)
|
||||||
|
{
|
||||||
|
int pos = itr.fragment().position(); //fragment position -> position of the first character in the fragment
|
||||||
|
|
||||||
|
if(itr.fragment().charFormat().isImageFormat())
|
||||||
|
{
|
||||||
|
QTextImageFormat imgFmt = itr.fragment().charFormat().toImageFormat();
|
||||||
|
QString key = imgFmt.name(); //img key (eg. key::D for :D)
|
||||||
|
QString rune = key.mid(4);
|
||||||
|
|
||||||
|
if(pos >= from && pos < to)
|
||||||
|
{
|
||||||
|
txt += rune;
|
||||||
|
pos++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
for(QChar c : itr.fragment().text())
|
||||||
|
{
|
||||||
|
if(pos >= from && pos < to)
|
||||||
|
txt += c;
|
||||||
|
|
||||||
|
pos++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return txt;
|
||||||
|
}
|
||||||
|
@ -65,6 +65,7 @@ protected:
|
|||||||
int getSelectionEnd() const;
|
int getSelectionEnd() const;
|
||||||
int getSelectionStart() const;
|
int getSelectionStart() const;
|
||||||
bool hasSelection() const;
|
bool hasSelection() const;
|
||||||
|
QString extractSanitizedText(int from, int to) const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
CustomTextDocument* doc = nullptr;
|
CustomTextDocument* doc = nullptr;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user