我有一个弹出式菜单托盘图标。 我想设置在这个弹出的菜单项的背景颜色。 我能够设置文本颜色,但没有菜单项的背景颜色。
出现的背景是Ubuntu默认的橙色,我不能覆盖它。
我创建演示此问题的一个示例应用程序。 只需将它复制粘贴到一个.py文件,它应该运行。
from gi.repository import Gtk, Gdk
import sys
class TrayIcon:
def __init__(self):
self.statusicon = Gtk.StatusIcon()
self.statusicon.set_from_stock(Gtk.STOCK_MEDIA_PLAY)
self.statusicon.connect("popup-menu", self.OnShowPopupMenu)
window = Gtk.Window()
def OnShowPopupMenu(self, icon, button, time):
menu = Gtk.Menu()
first = self.GetMenuItem("First")
second = self.GetMenuItem("Second")
menu.append(first)
menu.append(second)
menu.show_all()
menu.popup(None, None, lambda w,x: self.statusicon.position_menu(menu, self.statusicon), self.statusicon, 3, time)
def GetMenuItem(self, txt):
menuItem = Gtk.MenuItem(txt)
screen = Gdk.Screen.get_default()
css_provider = Gtk.CssProvider()
#css_provider.load_from_data("GtkWidget { color:white; background-color: green; } GtkWidget:hover,GtkWidget:selected { color:white; background-color:pink;}")
css_provider.load_from_data("GtkMenuItem { color:#0f0; background-color: #f00; } GtkMenuItem:hover,GtkMenuItem:selected { color:#00f; background-color:#f00; font-weight:bold;}")
context = Gtk.StyleContext()
context.add_provider_for_screen(screen, css_provider, Gtk.STYLE_PROVIDER_PRIORITY_APPLICATION)
menuItem.connect("button_press_event", self.exit)
return menuItem
def exit(self, a,b):
sys.exit()
TrayIcon()
Gtk.main()
对于GtkMenuItem正常的背景和:悬停背景被忽略。 对于GtkWidget的了:悬停背景被忽略。 我的目的是防止Ubuntu的橘子从显示出来,而无需禁用的菜单项。
有没有一种方法来设置GtkMenuItem的背景和悬停/鼠标悬停颜色? (不使用“进口GTK”)
我使用Ubuntu 12.04,默认主题。
EDIT1:增添几分清晰的,这就是我想要做的,但没有“进口GTK”。
#Prevent background color when mouse hovers
style = menuItem.get_style().copy()
style.bg[gtk.STATE_SELECTED] = style.bg[gtk.STATE_NORMAL]
menuItem.set_style(style)
EDIT2:我也试过override_background_color()和modify_bg,并再次,橙色仍显示悬停。 下面是我曾尝试变种。
menuItem.override_background_color(Gtk.StateFlags.NORMAL,Gdk.RGBA(1.0,0.0,0.0,1))
menuItem.modify_bg(Gtk.StateFlags.NORMAL,Gdk.color_parse("red"))
menuItem.override_background_color(Gtk.StateFlags.NORMAL, Gdk.RGBA(1.0, 1.0, 1.0, 1.0))
menuItem.override_background_color(Gtk.StateFlags.SELECTED, Gdk.RGBA(1.0, 1.0, 1.0, 1.0))
menuItem.override_background_color(Gtk.StateFlags.FOCUSED, Gdk.RGBA(1.0, 1.0, 1.0, 1.0))
EDIT3:已提供答案,看到这个帖子 。
大量挖掘后,得到的答复竟然是有些模糊。
-
background-color
不起作用。 我不得不使用background
- 我也不得不使用
-unico-inner-stroke-width
我结束了在为Ubuntu的主题本身,看看发生了什么事,设在这里一个GTK3 CSS文件:
/usr/share/themes/Ambiance/gtk-3.0/gtk-widgets.css
我得到了-unico-inner-stroke-width
从上面的CSS文件属性。 我不能确定为什么background-color
在我的剧本被忽略,但它是,至少在Ubuntu 12.04。
我也不得不“重新设定”我在改变,因为他们本来挺奇怪的元素的背景和边框颜色。 这是起码的CSS我不得不使用
GtkMenuItem
{
border:@bg_color;
background:@bg_color;
}
GtkMenuItem:hover
{
background:@selected_bg_color;
}
GtkWidget
{
border: @bg_color;
}
#mymenu:hover
{
color:@fg_color;
background: @bg_color;
-unico-inner-stroke-width: 0;
}
在这个例子中,我设置一个GtkMenuItem的悬停颜色是一样的背景颜色,但如果你想设置颜色为别的东西,你必须改变background
属性,按您的需求。
因此,在没有悬停颜色的菜单项工作
以下是完整的Python代码:
from gi.repository import Gtk, Gdk
import sys
class TrayIcon:
def __init__(self):
self.statusicon = Gtk.StatusIcon()
self.statusicon.set_from_stock(Gtk.STOCK_MEDIA_PLAY)
self.statusicon.connect("popup-menu", self.OnShowPopupMenu)
self.statusicon.set_tooltip_text("HELLO")
window = Gtk.Window()
def OnShowPopupMenu(self, icon, button, time):
display = Gdk.Display.get_default()
screen = display.get_default_screen()
css_provider = Gtk.CssProvider()
gtk3Css = """GtkMenuItem {
border:@bg_color;
background:@bg_color;
}
GtkMenuItem:hover
{
background:@selected_bg_color;
}
GtkWidget
{
border: @bg_color;
}
#mymenu:hover
{
color:@fg_color;
background: @bg_color;
-unico-inner-stroke-width: 0;
}"""
css_provider.load_from_data(gtk3Css)
context = Gtk.StyleContext()
context.add_provider_for_screen(screen, css_provider, Gtk.STYLE_PROVIDER_PRIORITY_APPLICATION)
menu = Gtk.Menu()
#menu.set_name('mymenu')
first = self.GetMenuItem("First")
first.set_name('mymenu')
second = self.GetMenuItem("Second")
menu.append(first)
menu.append(second)
menu.show_all()
menu.popup(None, None, lambda w,x: self.statusicon.position_menu(menu, self.statusicon), self.statusicon, 3, time)
def GetMenuItem(self, txt):
menuItem = Gtk.MenuItem()
menuItem.set_label(txt)
menuItem.connect("button_press_event", self.exit)
return menuItem
def exit(self, a,b):
sys.exit()
TrayIcon()
Gtk.main()
如果你想设置另一种背景颜色,你可以在CSS做以上
GtkMenuItem:hover
{
background:purple;
-unico-inner-stroke-width: 0;
}
(或做它#mymenu:悬停)
最后,我想这可能是限制到Ubuntu 12.04或GTK 3.4.2一个问题,我通过运行来确定,
pkg-config --modversion gtk+-3.0
但我不具备专业知识,以确定这个问题的根源。
那么它的C未蟒蛇,但是这对我的作品。 我命名菜单“的MyMenu”这样你可以风格它不使用GtkLabel的会影响应用程序中的任何其他标签。
/* COMPILE WITH: gcc -Wall -o icon3 `pkg-config --cflags --libs gtk+-3.0` icon3.c */
#include <gtk/gtk.h>
#include <string.h> /* for CSS */
static void cb_left_click(GtkStatusIcon *icon, gpointer data)
{
static GtkWidget *window = NULL;
if (window == NULL) {
window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
gtk_window_set_title(GTK_WINDOW(window), "Status Icon");
g_signal_connect( window, "delete-event", G_CALLBACK(gtk_main_quit), NULL );
gtk_widget_show(window);
}
}
static void cb_right_click(GtkStatusIcon *icon, int button, int time, gpointer data)
{
GtkWidget *menu;
menu = gtk_menu_new ();
gtk_widget_set_name(GTK_WIDGET(menu),"mymenu");
GtkWidget *item1 = gtk_menu_item_new_with_label("First");
GtkWidget *item2 = gtk_menu_item_new_with_label("Second");
gtk_menu_shell_append(GTK_MENU_SHELL(menu), item1);
gtk_menu_shell_append(GTK_MENU_SHELL(menu), item2);
gtk_widget_show_all(menu);
gtk_menu_popup(GTK_MENU(menu),
NULL,
NULL,
gtk_status_icon_position_menu,
icon,
button,
time);
}
int main(int argc, char *argv[])
{
GtkStatusIcon *icon;
/*-- CSS ------------------*/
GtkCssProvider *provider;
GdkDisplay *display;
GdkScreen *screen;
/*---------------------------*/
gtk_init(&argc, &argv);
icon = gtk_status_icon_new_from_stock (GTK_STOCK_MEDIA_PLAY);
g_signal_connect (G_OBJECT(icon), "activate", G_CALLBACK(cb_left_click), NULL);
g_signal_connect (G_OBJECT(icon), "popup-menu", G_CALLBACK(cb_right_click), NULL);
/*---------------- CSS ----------------------------------------------------------------------------------------------------*/
provider = gtk_css_provider_new ();
display = gdk_display_get_default ();
screen = gdk_display_get_default_screen (display);
gtk_style_context_add_provider_for_screen (screen, GTK_STYLE_PROVIDER (provider), GTK_STYLE_PROVIDER_PRIORITY_APPLICATION);
gsize bytes_written, bytes_read;
const gchar* home = "/home/mike/icon3.css";
GError *error = 0;
gtk_css_provider_load_from_path (provider,
g_filename_to_utf8(home, strlen(home),
&bytes_read, &bytes_written, &error),
NULL);
g_object_unref (provider);
/*-------------------------------------------------------------------------------------------------------------------------*/
gtk_main();
return 0;
}
CSS文件:
#mymenu {
background-color: white;
color: green;
font-weight:bold;
}
#mymenu :hover {
background-color: red;
color: blue;
font-weight:bold;
}