Хорошо, это будет шаг за шагом:
- Наш виджет будет назван
AwesomeTextView
, будет вызван модуль, в котором он находится awesome_text_view
. Это единственные имена, которые нам нужны.
Виджет поляны состоит из двух частей: модуля и каталога.
Мы создаем каталог awesome_text_view.xml
и сохраняем его как root/usr/share/glade3/catalogs/
Вот как это выглядит:
<glade-catalog name="awesome_text_view"
library="gladepython"
domain="glade-3"
depends="gtk+">
<init-function>glade_python_init</init-function>
<glade-widget-classes>
<glade-widget-class title="Awesome TextView"
name="AwesomeTextView"
generic-name="awesome_text_view"/>
</glade-widget-classes>
<glade-widget-group name="python" title="Python">
<glade-widget-class-ref name="AwesomeTextView"/>
</glade-widget-group>
</glade-catalog>
Вам следует скопировать и адаптировать этот шаблон, так как он работает . :-)
Мы создаем модуль awesome_text_view.py
и сохраняем его (снова как root) в/usr/lib/glade3/modules/
Вот как это выглядит:
import gobject
import gtk
import pango
class AwesomeTextView (gtk.TextView):
__gtype_name__ = 'AwesomeTextView'
def __init__(self):
gtk.TextView.__init__(self)
def set_font(self, font_description):
self.modify_font(pango.FontDescription(font_description))
Теперь он отображается в Glade, и вы можете добавить его в свое приложение.
Наконец, вам просто нужно
export PYTHONPATH="$PYTHONPATH:/usr/lib/glade3/modules/"
Это оно!
Вот небольшое тестовое приложение, показывающее, как использовать ваш виджет:
import gtk
import awesome_text_view
class App (object):
builder = gtk.Builder()
def __init__(self):
self.builder.add_from_file("test.glade")
self.builder.connect_signals(self)
self.builder.get_object("awesome_text_view1").set_font("mono")
gtk.main()
def on_window1_destroy(self, widget):
gtk.main_quit()
App()