日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

qtextedit 默认文案_QTextEdit的paste

發布時間:2024/9/27 c/c++ 46 豆豆
生活随笔 收集整理的這篇文章主要介紹了 qtextedit 默认文案_QTextEdit的paste 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

背景

QTextEdit中粘貼一大段文字時,EasyDraft中粘貼進去的文字們的格式就亂了,處于無格式。還有在EasyDraft中選中一些文字進行拖放動作時,格式也會混亂。

解決

這兩種都牽涉到QTextEdit粘貼行為,我們可以截獲剪切板(clipboard)的內容,然后自行修改調整格式,再手動插入到QTextEdit中。正好,QTextEdit提供了對應的保護成員函數:insertMimeData()

virtual void insertFromMimeData( const QMimeData * source)

于是我們重現實現該函數

void EDTextEdit::insertFromMimeData( const QMimeData *source) {

if (source->hasText() ) {

QString context = source->text();

QStringList conList = context.split("\n");

QTextCursor cursor = this->textCursor();

int origState = cursor.block().userState();

for (int i = 0; i < conList.length(); ++i) {

cursor.insertBlock(/* 格式設置在此 */);

cursor.insertText(conList[i]); //插入文本內容

cursor.block().setUserState(origState);

}

}

}

20130118補充:

這樣在編輯框中復制粘貼本身的內容,原有的劇本元素格式也全部被弄成了光標處的格式了,所以我們應該判斷一下,如果內容包含了劇本格式,那么就執行默認粘貼行為。

怎樣判斷該內容包含了劇本格式呢,我們使用source->formats()函數,打印出了當這種情況時,格式列表,放回內容為("text/html", "application/vnd.oasis.opendocument.text", "text/plain"),這里的"application/vnd.oasis.opendocument.text"應該就是我們的格式,所有若source的格式包含了該格式,就執行默認行為

void EDTextEdit::insertFromMimeData( const QMimeData *source) {

if (source->hasText() && !source->hasFormat("application/vnd.oasis.opendocument.text")) {

// 修改格式并插入到文檔中,代碼同上

} else {

// 默認行為

QTextEdit::insertFromMimeData(source);

}

}

說一下這個QMimeData的hasFormat()函數,給它一個Qt識別的格式的字符串,比如"text/plain","text/html","text/uri-list", "application/x-qt-image"等等,你可以使用QMimeData::formats()函數來查看。

Qt文檔中的說明

Drag and Drop

QTextEdit支持用戶自定義的drag和drop行為.

默認情況下,當用戶drop一些純文本,HTML,富文本這種MIME數據時,QTextEdit會直接插入到文檔中。

你可以通過重新實現 canInsertFromMimeData() 和 insertFromMimeData() 來支持額外的MIME數據類型

例如,允許用戶拖拽圖片到QTextEdit里,你可以這么實現:

bool TextEdit::canInsertFromMimeData( const QMimeData *source ) const {

if (source->hasImage())

return true;

else

return QTextEdit::canInsertFromMimeData(source);

}

這樣,使其返回true,我們就增加支持了image MIME types. 其他的MIME類型,我們使用默認的實現.

void TextEdit::insertFromMimeData( const QMimeData *source ) {

if (source->hasImage()) {

QImage image = qvariant_cast(source->imageData());

QTextCursor cursor = this->textCursor();

QTextDocument *document = this->document();

document->addResource(QTextDocument::ImageResource, QUrl("image"), image);

cursor.insertImage("image");

}

}

我們從QVariant中解包圖像數據,并把它作為一個resource插入到文檔中。

Powered by Sublog

總結

以上是生活随笔為你收集整理的qtextedit 默认文案_QTextEdit的paste的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。