虽然接受的答案适用于默认字体大小,但当我更改字体大小或垂直边距时它会中断(请参阅 cmets)。对于我测试过的所有字体大小和垂直边距,下面的文本行编辑类将文本垂直居中。
它使用QTextDocument 设置编辑器,然后将其分配给QTextEdit 实例。无论如何,QTextDocuments 为QTextEdits 提供了后端容器,并具有处理字体大小和边距的内置功能,并为编辑器提供了额外的控制层。
在实践中,我发现使用 QTextDocument 可以让我以更直观的方式解决问题,而无需深入研究帧宽度、字体度量等的细节机制,这我们在仅使用原生 QTextEdit 方法工作时做到了。
注意它使用setViewportMargins() 而不是setContentMargins()(这是您可能期望它使用的),因为后者用于为插入布局中的内容设置边距。下面的编辑器是一个独立的小部件,没有放入任何布局中,所以setContentMargins() 不会做任何事情。
import sys
from PySide import QtGui, QtCore
class TextLineEdit(QtGui.QTextEdit):
topMarginCorrection = -4 #not sure why needed
returnPressed = QtCore.Signal()
def __init__(self, fontSize = 10, verticalMargin = 2, parent = None):
QtGui.QTextEdit.__init__(self, parent)
self.setAttribute(QtCore.Qt.WA_DeleteOnClose)
self.setLineWrapMode(QtGui.QTextEdit.NoWrap)
self.setVerticalScrollBarPolicy(QtCore.Qt.ScrollBarAlwaysOff)
self.setHorizontalScrollBarPolicy(QtCore.Qt.ScrollBarAlwaysOff)
self.setFontPointSize(fontSize)
self.setViewportMargins(-verticalMargin, self.topMarginCorrection , 0, 0) #left, top, right, bottom
#Set up document with appropriate margins and font
document = QtGui.QTextDocument()
currentFont = self.currentFont()
currentFont.setPointSize(fontSize)
document.setDefaultFont(currentFont)
document.setDocumentMargin(verticalMargin)
self.setFixedHeight(document.size().height())
self.setDocument(document)
def keyPressEvent(self, event):
'''stops retun from returning newline'''
if event.key() in (QtCore.Qt.Key_Enter, QtCore.Qt.Key_Return):
self.returnPressed.emit()
event.accept()
else:
QtGui.QTextEdit.keyPressEvent(self, event)
def main():
app = QtGui.QApplication(sys.argv)
myLine = TextLineEdit(fontSize = 15, verticalMargin = 8)
myLine.show()
sys.exit(app.exec_())
if __name__ == "__main__":
main()