Python+PYGObject/PYGtk+CSS样式--2024python示例

隔久点不用老是会忘,留个笔记。。

Python+PYGObject/PYGtk,加载 CSS 样式的演示代码

demo 运行的效果截图:

python 复制代码
#!/usr/bin/env python3
import sys
import gi

gi.require_version("Gtk", "3.0")
from gi.repository import GLib, Gtk, Gio


class MyApplication(Gtk.Application):
	def __init__(self):
		super().__init__(application_id="com.example.MyGtkApplication")
		GLib.set_application_name('My Gtk Application')

	def do_activate(self):
		window = Gtk.ApplicationWindow(application=self, title="Hello World")
		window.present()
		button = Gtk.Button(label="Python+PyGObject+CSS修改背景色")
		button.set_name("bricks-button")
		button.set_halign(Gtk.Align.CENTER)
		button.set_valign(Gtk.Align.CENTER)
		button.set_size_request(250, 84)
		window.add(button)
		window.show_all()

		strcss="""
			#bricks-button {
				color: #F55;
				background-color: #eef;
				background-image: -gtk-scaled(url('resource://css/brick.png'), url('resource://css/brick2.png'));
				background-repeat: no-repeat;
				background-position: center;
				/* 测试 */
			}
		"""
		
		strpath="./play.css"
		fp = open(strpath, 'w')
		fp.write(strcss)
		fp.close()

		provider = Gtk.CssProvider()
		provider.connect("parsing-error", self.show_css_parsing_error)
		# fname = Gio.file_new_for_path('play.css')
		# provider.load_from_file(fname)
		# https://docs.gtk.org/gtk4/method.CssProvider.load_from_file.html
		# load_from_path, load_from_file, load_from_string
		provider.load_from_path(strpath)
		self.apply_css(window, provider)

	def show_css_parsing_error(self, provider, section, error):
		print(error.message)

	def apply_css(self, widget, provider):
		Gtk.StyleContext.add_provider(widget.get_style_context(), provider, Gtk.STYLE_PROVIDER_PRIORITY_APPLICATION)

		if isinstance(widget, Gtk.Container):
			widget.forall(self.apply_css, provider)


app = MyApplication()
exit_status = app.run(sys.argv)
sys.exit(exit_status)

官方文档:CssProvider --- GNOME Python API

Deprecated since version 4.12: Use load_from_string or load_from_bytes instead

Styling GTK3 in Python with CSS (Shallow Thoughts)

控件对应的CSS选择器名称(Built-in Class Names)

复制代码
css = 'button { background-color: #f00; }'

CSS选择器名称可以改(User-set Class Names)

复制代码
    button_context = button.get_style_context()
    button_context.add_class("whitebutton")

控件名称,映射为 HTML 标签的ID,在CSS中使用井号选择器

(Widget Names, like CSS ID)

复制代码
    label = gtk.Label()
    label.set_use_markup(True)
    label.set_line_wrap(True)
    label.set_name("red_label")
    mainbox.pack_start(label, False, False, 0)
    css = '#red_label { background-color: #f00; }'

dflabel = gtk.Label() 
相关推荐
斯凯利.瑞恩1 分钟前
Python决策树、随机森林、朴素贝叶斯、KNN(K-最近邻居)分类分析银行拉新活动挖掘潜在贷款客户附数据代码
python·决策树·随机森林
阳光开朗大男孩 = ̄ω ̄=13 分钟前
CSS——选择器、PxCook软件、盒子模型
前端·javascript·css
yannan2019031322 分钟前
【算法】(Python)动态规划
python·算法·动态规划
蒙娜丽宁32 分钟前
《Python OpenCV从菜鸟到高手》——零基础进阶,开启图像处理与计算机视觉的大门!
python·opencv·计算机视觉
光芒再现dev34 分钟前
已解决,部署GPTSoVITS报错‘AsyncRequest‘ object has no attribute ‘_json_response_data‘
运维·python·gpt·语言模型·自然语言处理
好喜欢吃红柚子1 小时前
万字长文解读空间、通道注意力机制机制和超详细代码逐行分析(SE,CBAM,SGE,CA,ECA,TA)
人工智能·pytorch·python·计算机视觉·cnn
小馒头学python1 小时前
机器学习是什么?AIGC又是什么?机器学习与AIGC未来科技的双引擎
人工智能·python·机器学习
神奇夜光杯1 小时前
Python酷库之旅-第三方库Pandas(202)
开发语言·人工智能·python·excel·pandas·标准库及第三方库·学习与成长
千天夜1 小时前
使用UDP协议传输视频流!(分片、缓存)
python·网络协议·udp·视频流
测试界的酸菜鱼1 小时前
Python 大数据展示屏实例
大数据·开发语言·python