Страницы

Поиск по вопросам

понедельник, 11 марта 2019 г.

Нумерация строк в QTextEdit

Как реализовать нумерацию строк в QTextEdit, что то как на примере Excel или Notepad++

import sys from PyQt5.QtWidgets import QTextEdit, QWidget, QApplication, QVBoxLayout
class Text(QWidget):
def __init__(self, **kwargs): super().__init__(**kwargs) text_edit = QTextEdit('Какой то текст') layout = QVBoxLayout() layout.addWidget(text_edit) self.setLayout(layout)
if __name__ == "__main__": app = QApplication(sys.argv) main = Text() main.show() sys.exit(app.exec_())


Ответ

Вот небольшой пример:
import sys import numpy as np
from PyQt5 import Qt
class LineNumberArea(Qt.QWidget): def __init__(self, editor): super().__init__(editor) self.myeditor = editor
def sizeHint(self): return Qt.Qsize(self.editor.lineNumberAreaWidth(), 0)
def paintEvent(self, event): self.myeditor.lineNumberAreaPaintEvent(event)
class CodeEditor(Qt.QPlainTextEdit): def __init__(self): super().__init__()
self.lineNumberArea = LineNumberArea(self)
self.blockCountChanged[int].connect(self.updateLineNumberAreaWidth) self.updateRequest[Qt.QRect,int].connect(self.updateLineNumberArea) self.cursorPositionChanged.connect(self.highlightCurrentLine)
self.updateLineNumberAreaWidth(0)
self.setPlainText(""" Класс QPlainTextEdit предоставляет виджет, который используется для редактирования и отображения обычного текста. """)
def lineNumberAreaWidth(self): digits = 1 count = max(1, self.blockCount()) while count >= 10: count /= 10 digits += 1 space = 3 + self.fontMetrics().width('9') * digits return space
def updateLineNumberAreaWidth(self, _): self.setViewportMargins(self.lineNumberAreaWidth(), 0, 0, 0)
def updateLineNumberArea(self, rect, dy):
if dy: self.lineNumberArea.scroll(0, dy) else: self.lineNumberArea.update(0, rect.y(), self.lineNumberArea.width(), rect.height())
if rect.contains(self.viewport().rect()): self.updateLineNumberAreaWidth(0)
def resizeEvent(self, event): super().resizeEvent(event)
cr = self.contentsRect(); self.lineNumberArea.setGeometry(Qt.QRect(cr.left(), cr.top(), self.lineNumberAreaWidth(), cr.height()))
def lineNumberAreaPaintEvent(self, event): mypainter = Qt.QPainter(self.lineNumberArea)
mypainter.fillRect(event.rect(), Qt.Qt.lightGray)
block = self.firstVisibleBlock() blockNumber = block.blockNumber() top = self.blockBoundingGeometry(block).translated(self.contentOffset()).top() bottom = top + self.blockBoundingRect(block).height()
height = self.fontMetrics().height() while block.isValid() and (top <= event.rect().bottom()): if block.isVisible() and (bottom >= event.rect().top()): number = str(blockNumber + 1) mypainter.setPen(Qt.Qt.black) mypainter.drawText(0, top, self.lineNumberArea.width(), height, Qt.Qt.AlignRight, number)
block = block.next() top = bottom bottom = top + self.blockBoundingRect(block).height() blockNumber += 1
def highlightCurrentLine(self): extraSelections = []
if not self.isReadOnly(): selection = Qt.QTextEdit.ExtraSelection()
lineColor = Qt.QColor(Qt.Qt.yellow).lighter(160)
selection.format.setBackground(lineColor) selection.format.setProperty(Qt.QTextFormat.FullWidthSelection, True) selection.cursor = self.textCursor() selection.cursor.clearSelection() extraSelections.append(selection) self.setExtraSelections(extraSelections)
if __name__ == "__main__": app = Qt.QApplication(sys.argv)
txt = CodeEditor() txt.setStyleSheet("""QPlainTextEdit{ font-family:'Consolas'; color: #ccc; font-size: 20px; background-color: #2b2b2b;}""") txt.setGeometry(400, 100, 600, 400) txt.show()
sys.exit(app.exec_())

Комментариев нет:

Отправить комментарий