如何使用 QPlainTextEdit 编辑器结束编辑会话?

Posted

技术标签:

【中文标题】如何使用 QPlainTextEdit 编辑器结束编辑会话?【英文标题】:How to end an edit session with QPlainTextEdit editor? 【发布时间】:2020-11-07 10:39:27 【问题描述】:

这是一个 MRE:

from PyQt5.QtCore import QRect, Qt, QAbstractTableModel
from PyQt5.QtWidgets import QApplication, QMainWindow, QTableView, QWidget, QVBoxLayout, QStyledItemDelegate, QPlainTextEdit, QShortcut
import sys, types
from PyQt5.QtGui import QFont

class HistoryTableViewDelegate( QStyledItemDelegate ):
    def __init__( self, history_table_view ):
        super().__init__( history_table_view )
    
    def createEditor(self, parent, option, index):
        editor = QPlainTextEdit( parent )
        editor.setSizeAdjustPolicy( QPlainTextEdit.SizeAdjustPolicy.AdjustToContents )
        self.model = index.model()
        column = index.column()
        row = index.row()
        parent.parent().verticalHeader().resizeSection( row, 150 )
        parent_font = QFont( self.parent().font() )
        parent_font.setPointSize( self.parent().font().pointSize() )
        editor.setFont( parent_font )
        def end_edit():
            print( f'end edit...')
            self.setModelData( editor, self.model, index )
            # how to end the edit session programmatically at this point?
            # self.destroyEditor( editor, index ) 
            
        end_edit_shortcut = QShortcut(  'Alt+E', editor, context = Qt.ShortcutContext.WidgetShortcut )
        end_edit_shortcut.activated.connect( end_edit )
        return editor
    
    def setEditorData(self, editor, index ):
        # NB superclass method sets the editor's text to empty string...
        self.original_text = index.model().data( index, Qt.DisplayRole )
        editor.insertPlainText( str( self.original_text ) )     
        
class HistoryTableModel( QAbstractTableModel ):
    def __init__( self ):
        super(HistoryTableModel, self).__init__()
        data = [
              [4, 9, 2],
              [1, 0, 0],
              [3, 5, 0],
        ]
        self._data = data

    def data(self, index, role):
        if role == Qt.DisplayRole:
            return self._data[index.row()][index.column()]

    def rowCount(self, index):
        return len(self._data)

    def columnCount(self, index):
        return len(self._data[0])
    
    def flags(self, index):
        return Qt.ItemIsEnabled | Qt.ItemIsSelectable | Qt.ItemIsEditable
    
    def setData(self, index, value, role ):
        if role == Qt.EditRole:
            self._data[ index.row() ][ index.column() ] = value  
        return True  

class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
        MainWindow.resize(600, 700 )
        self.centralwidget = QWidget(MainWindow)
        self.verticalLayoutWidget = QWidget(self.centralwidget)
        self.verticalLayoutWidget.setGeometry( QRect(20, 20, 500, 500))
        self.verticalLayout = QVBoxLayout(self.verticalLayoutWidget)
        self.comps = []
        self.table_view = QTableView(self.verticalLayoutWidget)
        self.comps.append( self.table_view )
        self.table_view.setGeometry(QRect(20, 20, 200, 200))
        self.verticalLayout.addWidget(self.table_view)
        self.table_view.setModel( HistoryTableModel() )
        self.table_view.setTabKeyNavigation(False)
        self.table_view.setItemDelegate( HistoryTableViewDelegate( self.table_view ))
        MainWindow.setCentralWidget(self.centralwidget)

class MainWindow(QMainWindow):
    def __init__(self):
        super(MainWindow, self).__init__()
        self.ui = Ui_MainWindow()
        self.ui.setupUi(self)

app = QApplication(sys.argv)
application = MainWindow()
application.show()
sys.exit(app.exec())

我想要一个多行编辑器,所以我想我已经明白要走的路是QPlainTextEdit。尽管在上述情况下,按 Alt-E 会将数据提交给模型,但它实际上并没有结束会话。例如,如果您在另一个单元格上单击鼠标,您会看到已编辑的多行数据仍保留在已编辑的单元格中,并且这样做也会以某种方式结束编辑会话。

如何以编程方式结束会话?

NB 在按 Alt-E 后按 Escape 是一种执行此操作的方法(两次击键)...但我本质上想使用 QLineEdit 编辑器执行按 Enter 所做的任何编程操作。

【问题讨论】:

【参考方案1】:

知道了……

def end_edit():
    self.setModelData( editor, self.model, index )
    self.closeEditor.emit( editor )

【讨论】:

以上是关于如何使用 QPlainTextEdit 编辑器结束编辑会话?的主要内容,如果未能解决你的问题,请参考以下文章

Qt中的QLineEdit,QTextEdit和QPlainTextEdit的区别

如何从 QPlainTextEdit 正确获取 Unicode 文本输入? [复制]

Qt QPlainTextEdit 背景

第四十一课编辑交互功能的实现

在 QPlainTextEdit 中突出显示部分文本

如何知道 QPlainTextEdit 继承类中是不是显示水平滚动条?