Isenção de responsabilidade: eu não sabia nada rapidamente até ler sua postagem ou sobre programação de GUI em geral para esse assunto. Portanto, sinceramente, não tenho negócios tentando responder a essa pergunta :)
Dito isto, rapidamente é um projeto interessante. Examinei brevemente a fonte do padrão e identifiquei as seguintes abordagens em potencial para adicionar uma preferência de estilo de lista suportada pelo ListStore:
- 'Monkey-patch' obtém e define widget_methods em um widget TreeView de estoque (com modelo ListStore) conforme definido em data / ui / Preferences $ PROJECTNAME $ Dialog.ui com glade.
- Implemente
set_widget_from_preference
e set_preference
na subclasse de PreferencesDialog do projeto (a subclasse é Preferences $ PROJECTNAME $ Dialog) e faça algo diferente quando key
ou widget
for o widget TreeView suportado pelo ListStore.
- Escreva uma subclasse personalizada de gtk.TreeView com um widget personalizado correspondente para glade .
Para testá-las, eu implementei todas essas três idéias - cada uma funcionou como pretendido e a AFAICT, de forma idêntica. No final, o terceiro (em particular) me pareceu o mais limpo e mais próximo das convenções usadas em todo o painel, apesar de inicialmente esperar o contrário.
Aqui estão os passos que eu segui para o número três ...
Usando o glade via quickly design
(rapidamente 11.10, btw) e seguindo este tutorial (parte 2) , adicione um widget ScrolledWindow ao Preferences $ PROJECTNAME $ Dialog.ui, solte um TreeView nele e nomeie o TreeView language_treeview
. Crie um novo modelo ListStore para o TreeView quando solicitado e nomeie-o language_liststore, etc ... eventualmente, acabei com algo assim:
Em seguida, adicione um catálogo glade (data / ui / preferências_ $ PROJECTNAME $ _treeview.xml) com o seguinte conteúdo:
<glade-catalog name="preferences_$PROJECTNAME$_treeview" domain="glade-3"
depends="gtk+" version="1.0">
<glade-widget-classes>
<glade-widget-class title="$PROJECTNAME$ Preferences TreeView" name="Preferences$PROJECTNAME$TreeView"
generic-name="Preference$PROJECTNAME$TreeView" parent="GtkTreeView"
icon-name="widget-gtk-treeview"/>
</glade-widget-classes>
</glade-catalog>
Em seguida, edite as Preferências $ PROJECTNAME $ Dialog.ui, adicionando ...
<!-- interface-requires preferences_$PROJECTNAME$_treeview 1.0 -->
... para o topo, abaixo da marca requer. E altere o atributo de classe de language_treeview para Preferences $ PROJECTNAME $ TreeView, em preparação para uma etapa posterior.
Por fim, adicione o seguinte elemento à lista widget_methods em Preferences $ PROJECTNAME $ Dialog.py
'language_treeview': ['get_languages', 'set_languages', 'button-release-event']
E no final do mesmo arquivo (Preferências $ PROJECTNAME $ Dialog.py), adicione
import gtk
ALL_LANGUAGES = [
'en', 'uk', 'de', 'fr', # ... much longer list
]
class Preferences$PROJECTNAME$TreeView(gtk.TreeView):
__gtype_name__ = "Preferences$PROJECTNAME$TreeView"
def __init__(self, *args):
super(Preferences$PROJECTNAME$TreeView, self).__init__(*args)
self.get_selection().set_mode(gtk.SELECTION_MULTIPLE)
# loads the liststore with all languages,
# selecting/highlighting in the treeview those
# already retrieved from previously saved preferences
def set_languages(self, preferred_languages):
model = self.get_model()
for row, lang in enumerate(ALL_LANGUAGES):
model.append([lang])
if lang in preferred_languages:
self.get_selection().select_iter(model.get_iter(row))
# collects only the selected languages in the treeview
# to save in the preferences database
def get_languages(self):
model, rows = self.get_selection().get_selected_rows()
result = [model.get_value(model.get_iter(row), 0) for row in rows]
return result
Se você estiver interessado em ver minhas tentativas de uma e duas, fico feliz em agradecer.
Editar: para o leitor casual, substitua qualquer ocorrência de $ PROJECTNAME $ pelo nome real do seu projeto rápido (conforme especificado em quickly create
).
HTH!