0

コードの最初のセクションは、投稿された元のコードです。2番目のコードは、ボブの答えを修正したもので、私を正しい方向に導いてくれました。

ユーザーが gtk.TextBuffer の特定の行 (これは新しい行で、もちろん空の行です) に達したときに、太字のフォントで入力する必要があります。

可能であれば、ユーザーが入力を開始する場所からフォントを太字にするために、以下のコードでどのような変更が必要ですか?

import gtk, pango

class BoldTestWindow(gtk.Window):

    def __init__(self):
        gtk.Window.__init__(self)
        self.connect( "destroy", lambda *w: gtk.main_quit() )

        self.set_default_size(280, 80)

        # Create a text view and get it's buffer.
        self.tv = gtk.TextView()
        buffer = self.tv.get_buffer()

        # Create the Tags and add them to the Tag Table.
        tags = [["weight", pango.WEIGHT_BOLD], ]
        for tag in tags:
            newTag = gtk.TextTag(name=tag[0])
            newTag.set_property(tag[0], tag[1])
            textTable = buffer.get_tag_table()
            textTable.add(newTag)

        # Grab an Iter to insert text.
        startIter = buffer.get_start_iter()

        # Insert some text in which to apply the bold attribute.
        buffer.insert(startIter, "A Bold Statement.")

        # startIter must be asked for again, because text was inserted.
        startIter = buffer.get_start_iter()
        endIter = buffer.get_end_iter()

        # Apply the tags to entire range of TextBuffer
        tags = ["weight",]
        for tag in tags:
            buffer.apply_tag_by_name(tag, startIter, endIter)

        # Let's see what happens.
        self.add(self.tv)
        self.tv.grab_focus()
        self.set_position(gtk.WIN_POS_CENTER)
        self.show_all()

if __name__ == "__main__":
    bww = BoldTestWindow()
    gtk.main()

ボブの答えはエクスポーズ イベントでした。属性を変更するための何千もの呼び出しでエクスポーズ イベントが殺到し、追加された文字ごとに 1 つの呼び出しのみが必要です。

イベントの氾濫を止めるために、キーイベントを実験しました。

key-press-event を使用してみましたが、文字は次のイベント ラウンドまで変更されず、最後に押された文字のスタイルは変更されませんでした。

key-release-event を試したところうまくいきましたが、属性の追加に少し時間がかかりました。その文字は一瞬属性がなくなり、太字属性が追加されます。

最後に、key-press-event とエクスポーズ イベントを組み合わせてみましたが、ボトルネックがいくつかあり、irc #pygtk の Juhaz がイベントの変更を推奨しました。anser は近いと思います。完了したら、次のセクションを使用して投稿します。私はまだ行揃えプロパティを解決する必要があります.それらはまだバグがあります.

import gtk, pango

# TaggedCursorTextView attempts to only add one feature to gtk.TextView: make the cursor dynamically settable
# to a list of tags.  This forces the current text being typed to the set of tags set.

class TaggedCursorTextView(gtk.TextView):
    def __init__(self):
        gtk.TextView.__init__(self)

        # Create buffer variable that point to it's internal TextBuffer.
        self.buffer = self.get_buffer()

        # Listen for the changed event. (User types, deletes or pastes text, etc.)
        self.connect("key-press-event", self.on_key_press_event)

        # What ever tags are place in here determines the text attributes (font type, bold, etc.)
        # That is being typed by the user at any given moment.
        # Default should be kept empty, no styles.
        self.cursorTags = []

        self.handlerID = None

    def addTags(self, tagList):
        # Create the Tags and add them to the Tag Table.  Ignores duplicate tag names.
        for tag in tagList:
            newTag = gtk.TextTag(name=tag[0])
            textTable = self.buffer.get_tag_table()
            tagNameFound = textTable.lookup(tag[0])
            if not tagNameFound:
                newTag.set_property(tag[1], tag[2])
                textTable.add(newTag)

    def removeTags(self, tagNameList):
        pass

    def setCursorTags(self, tagList):
        self.cursorTags = tagList

    def on_key_press_event(self, widget, event):
        self.handlerID = self.buffer.connect("changed", self.on_changed_event)

    def on_changed_event(self, widget):
        """This method updates the last character type to the cursor style."""
        self.buffer.disconnect(self.handlerID)

        # Get the iter that falls before and after the last char typed.
        endIter = self.buffer.get_end_iter()
        offset = endIter.get_offset() - 1
        startIter = self.buffer.get_iter_at_offset(offset)

        # Apply the tags to the newly typed char
        for tag in self.cursorTags:
            self.buffer.apply_tag_by_name(tag, startIter, endIter)

class TaggedCurserTextViewTestWindow(gtk.Window):

    def __init__(self):
        gtk.Window.__init__(self)
        self.connect( "destroy", lambda *w: gtk.main_quit() )

        self.set_default_size(280, 80)

        # Create a TaggedCursorTextView.
        tctv = TaggedCursorTextView()

        # Add some cursors tags that will be used at some point later in the app.
        # Each tag element list is: [tag name, tag property, tag value]
        tagList = [["Italic", "style", pango.STYLE_ITALIC], ["Bold", "weight", pango.WEIGHT_BOLD], ["Center", "justification", gtk.JUSTIFY_CENTER]]
        tctv.addTags(tagList)

        # Use the names of the tags in a list to set the cursor tags.
        tctv.setCursorTags(["Italic", "Bold", "Center"]) # Comment out this line for no style.

        # Let's see what happens.
        self.add(tctv)
        tctv.grab_focus()
        self.set_position(gtk.WIN_POS_CENTER)
        self.show_all()

if __name__ == "__main__":
    TaggedCurserTextViewTestWindow()
    gtk.main()
4

1 に答える 1

0

これは、コードのかなり大雑把な変更です。expose-eventテキストビューのハンドラーを作成しました。expose-event呼び出されるたびに (つまり、textview再描画の要求があったとき)、すべてが太字で再描画されます。

これがあなたが望んでいたものかどうかはわかりません。そうでない場合は、目的を詳しく説明してください (私は IRC にいます)。

import gtk, pango

class BoldTestWindow(gtk.Window):

    def __init__(self):
        gtk.Window.__init__(self)
        self.connect( "destroy", lambda *w: gtk.main_quit() )

        self.set_default_size(280, 80)

        # Create a text view and get it's buffer.
        self.tv = gtk.TextView()
        buffer = self.tv.get_buffer()

        # Create the Tags and add them to the Tag Table.
        tags = [["weight", pango.WEIGHT_BOLD], ]
        for tag in tags:
            newTag = gtk.TextTag(name=tag[0])
            newTag.set_property(tag[0], tag[1])
            textTable = buffer.get_tag_table()
            textTable.add(newTag)

        # Grab an Iter to insert text.
        startIter = buffer.get_start_iter()

        # Insert some text in which to apply the bold attribute.
        buffer.insert(startIter, "A Bold Statement.")

        # startIter must be asked for again, because text was inserted.
        startIter = buffer.get_start_iter()
        endIter = buffer.get_end_iter()

        # Apply the tags to entire range of TextBuffer
        tags = ["weight",]
        for tag in tags:
            buffer.apply_tag_by_name(tag, startIter, endIter)

        # Let's see what happens.
        self.add(self.tv)
        self.tv.grab_focus()
        self.set_position(gtk.WIN_POS_CENTER)
        self.show_all()

    def on_expose_event(self, widget, event, data=None):
        buffer = self.tv.get_buffer()
        startIter = buffer.get_start_iter()
        endIter = buffer.get_end_iter()

        # Apply the tags to entire range of TextBuffer
        tags = ["weight",]
        for tag in tags:
            buffer.apply_tag_by_name(tag, startIter, endIter)



if __name__ == "__main__":
    bww = BoldTestWindow()
    bww.tv.connect("expose-event", bww.on_expose_event)
    gtk.main()
于 2013-10-01T12:11:59.650 に答える