のGtk + 3.xのスタイルにCSSを使用し、テーマのウィジェット。 CSSの構造スタイルクラスは、3.0から3.26に変更されました。つまり、使用しているバージョンを知ることが重要です。
あなたはCSSを使用できるのGtk + 3.22で
:その後からこの適応例を使用し、test.cssと呼ばれるファイルに
.entry {
border-color: Red;
}
コピーし、このCSSコードを:のGtk + 3.18を使用して
entry {
border-color: Red;
}
をpython gt3 tutorial:
import gi
gi.require_version('Gtk', '3.0')
from gi.repository import Gtk, Gdk, GObject
class EntryWindow(Gtk.Window):
def __init__(self):
Gtk.Window.__init__(self, title="Entry Demo")
self.set_size_request(200, 100)
self.timeout_id = None
vbox = Gtk.Box(orientation=Gtk.Orientation.VERTICAL, spacing=6)
self.add(vbox)
self.entry = Gtk.Entry()
self.entry.set_text("Hello World")
vbox.pack_start(self.entry, True, True, 0)
hbox = Gtk.Box(spacing=6)
vbox.pack_start(hbox, True, True, 0)
self.check_editable = Gtk.CheckButton("Editable")
self.check_editable.connect("toggled", self.on_editable_toggled)
self.check_editable.set_active(True)
hbox.pack_start(self.check_editable, True, True, 0)
self.check_visible = Gtk.CheckButton("Visible")
self.check_visible.connect("toggled", self.on_visible_toggled)
self.check_visible.set_active(True)
hbox.pack_start(self.check_visible, True, True, 0)
self.pulse = Gtk.CheckButton("Pulse")
self.pulse.connect("toggled", self.on_pulse_toggled)
self.pulse.set_active(False)
hbox.pack_start(self.pulse, True, True, 0)
self.icon = Gtk.CheckButton("Icon")
self.icon.connect("toggled", self.on_icon_toggled)
self.icon.set_active(False)
hbox.pack_start(self.icon, True, True, 0)
def on_editable_toggled(self, button):
value = button.get_active()
self.entry.set_editable(value)
def on_visible_toggled(self, button):
value = button.get_active()
self.entry.set_visibility(value)
def on_pulse_toggled(self, button):
if button.get_active():
self.entry.set_progress_pulse_step(0.2)
# Call self.do_pulse every 100 ms
self.timeout_id = GObject.timeout_add(100, self.do_pulse, None)
else:
# Don't call self.do_pulse anymore
GObject.source_remove(self.timeout_id)
self.timeout_id = None
self.entry.set_progress_pulse_step(0)
def do_pulse(self, user_data):
self.entry.progress_pulse()
return True
def on_icon_toggled(self, button):
if button.get_active():
icon_name = "system-search-symbolic"
else:
icon_name = None
self.entry.set_icon_from_icon_name(Gtk.EntryIconPosition.PRIMARY,
icon_name)
win = EntryWindow()
style_provider = Gtk.CssProvider()
style_provider.load_from_path("test.css")
Gtk.StyleContext.add_provider_for_screen(
Gdk.Screen.get_default(),
style_provider,
Gtk.STYLE_PROVIDER_PRIORITY_APPLICATION
)
win.connect("delete-event", Gtk.main_quit)
win.show_all()
Gtk.main()
結果はこのようになります。
EDIT:Fedoraの23の
結果(のGtk + 3.18.9):私は、マシンを持っていない
実行しているのGtk + 3.18しかし、月曜日、私は持っていますそれを確認することができます。もう1つのオプションは、[GTK Inspector](https://wiki.gnome.org/Projects/GTK+/Inspector)を実行し、どのCSSスタイルクラスが使用されているかを確認することです。試してみる。 –
私はこのデバッガーについて知りませんでした。かっこいいね。その2つのボタンのクラスは、私が指定したものです。私は色を見たいと思う、私はheheをアップグレードしたい – deko
こんにちは私の編集を確認してください。 Gtk + 3.18では、エントリの前にドットを追加するだけです。 '.entry' –