Как получить позицию / диапазон прокрутки из элемента управления wx.TextCtrl в wxPython - PullRequest
1 голос
/ 30 сентября 2008

У меня есть небольшое приложение для ведения журналов (написанное на wxPython), которое получает данные от небольшого набора, который мы разрабатываем, и я хочу отобразить текст в окне прокрутки. В настоящее время я использую wx.TextCtrl для отображения текста, но у меня возникают некоторые проблемы с прокруткой.

По сути, мне бы хотелось, чтобы, если полоса прокрутки находится в нижней части окна (то есть в конце входящих данных), добавление дополнительных данных должно прокручивать представление вперед. Если, однако, представление было немного прокручено (то есть пользователь просматривает что-то интересное, например, сообщение об ошибке), приложение должно просто добавить текст в конце, не прокручивая больше.

У меня сейчас две проблемы:

  1. Я не могу понять, как извлечь текущую позицию прокрутки (кажется, что вызовы GetScrollPos () не работают - они просто возвращают 0).
  2. Я не могу понять, как получить текущий диапазон полосы прокрутки (вызов GetScrollRange () просто возвращает 1).

Я немного погуглил, и, кажется, есть несколько подсказок, которые предполагают, что GetScrollPos и ​​GetScrollRange не будут работать для wx.TextCtrl? Кто-нибудь еще имел опыт в этой области? Есть хороший простой способ решить проблему, или мне придется свернуть свой собственный wx.TextCtrl?

Ответы [ 2 ]

4 голосов
/ 01 октября 2008

Хорошо, вот где я должен:

import wx
from threading import Timer
import time

class Form1(wx.Panel):
    def __init__(self, parent):
        wx.Panel.__init__(self, parent)

        self.logger = wx.TextCtrl(self,5, "",wx.Point(20,20), wx.Size(200,200), \
                wx.TE_MULTILINE |  wx.TE_READONLY)# |  wx.TE_RICH2)

        t = Timer(0.1, self.AddText)
        t.start()

    def AddText(self):
        # Resart the timer
        t = Timer(0.25, self.AddText)
        t.start() 

        # Work out if we're at the end of the file
        currentCaretPosition = self.logger.GetInsertionPoint()
        currentLengthOfText = self.logger.GetLastPosition()
        if currentCaretPosition != currentLengthOfText:
            self.holdingBack = True
        else:
            self.holdingBack = False

        timeStamp = str(time.time())

        # If we're not at the end of the file, we're holding back
        if self.holdingBack:
            print "%s FROZEN"%(timeStamp)
            self.logger.Freeze()
            (currentSelectionStart, currentSelectionEnd) = self.logger.GetSelection()
            self.logger.AppendText(timeStamp+"\n")
            self.logger.SetInsertionPoint(currentCaretPosition)
            self.logger.SetSelection(currentSelectionStart, currentSelectionEnd)
            self.logger.Thaw()
        else:
            print "%s THAWED"%(timeStamp)
            self.logger.AppendText(timeStamp+"\n")

app = wx.PySimpleApp()
frame = wx.Frame(None, size=(550,425))
Form1(frame)
frame.Show(1)
app.MainLoop()

Это простое демо-приложение работает практически идеально. Он аккуратно прокручивается, если пользователь не щелкает строку, которая находится не в конце текста. После этого он остается красивым и тем не менее, так что вы можете выбрать текст (примечание: там все еще есть ошибка в том, что если вы выбираете вверх, а не вниз, это очищает ваш выбор).

Самое большое раздражение в том, что, если я попытаюсь включить опцию "| wx.TE_RICH2", все будет немного грушевидно. Мне действительно нужно это для подсветки синтаксиса ошибок, но если я не могу включить эту опцию, я обречен на монохромный - boo!

Есть еще идеи о том, как отложить прокрутку в элементе управления rich edit?

1 голос
/ 30 сентября 2008

Я только что протестировал простой пример (проверяя GetScrollPos(0) и GetScrollRange(0) в EVT_TEXT обработчике события для wx.TextCtrl), и он отлично работает для меня - они возвращают индекс отображаемой в данный момент строки и общее количество строк соответственно .

Может, проблема в вашей версии wxPython? Я использовал:

>>> import wx
>>> wx.version()
'2.8.9.1 (msw-unicode)'
...