- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我们在 Mac OSX 10.8.5 上使用 WxPython 2.9 的 TaskBarIcon,目前我们需要在用户点击时抓取所有左键、右键和双击事件我们应用程序的 TaskBarIcon。我们遇到的问题是这些事件没有被触发。在这方面的任何帮助将不胜感激。
这是我们正在使用的代码
import os
import sys
import wx
__author__ = 'Ammar Hasan'
CURRENT_ABSOLUTE_PATH = os.path.dirname(sys.argv[0])
TRAY_ICON = CURRENT_ABSOLUTE_PATH + "/resources/task_icon.ico"
TRAY_ICON_TOOLTIP = "UI Application"
ID_SHOW_OPTION = wx.NewId()
ID_EDIT_OPTION = wx.NewId()
ID_EXIT_OPTION = wx.ID_EXIT
class Icon(wx.TaskBarIcon):
def __init__(self, parent, icon, tooltip):
super(Icon, self).__init__(iconType=wx.TBI_CUSTOM_STATUSITEM)
self.set_icon(icon, tooltip)
self.parent = parent
self.Bind(wx.EVT_TASKBAR_LEFT_DOWN, self.on_icon_click)
self.Bind(wx.EVT_TASKBAR_RIGHT_DOWN, self.on_icon_click)
self.Bind(wx.EVT_MENU, self.menu_item_click)
def get_menu(self):
menu = wx.Menu()
menu.Append(ID_SHOW_OPTION, "&Show Option 1")
menu.Append(ID_EDIT_OPTION, "&Edit Option 2")
menu.AppendSeparator()
menu.Append(ID_EXIT_OPTION, "E&xit")
return menu
def on_icon_click(self, event):
if event:
print "Event Triggered."
menu = self.get_menu()
self.PopupMenu(menu)
def menu_item_click(self, event):
if event.Id == ID_SHOW_OPTION:
pass
elif event.Id == ID_EDIT_OPTION:
pass
else:
self.parent.quit()
def make_icon(self, img):
"""
The various platforms have different requirements for the
icon size...
"""
if "wxMSW" in wx.PlatformInfo:
img = img.Scale(16, 16)
elif "wxGTK" in wx.PlatformInfo:
img = img.Scale(22, 22)
# wxMac can be any size upto 128x128, so leave the source img alone....
icon = wx.IconFromBitmap(img.ConvertToBitmap())
return icon
def set_icon(self, path, tool_tip):
image = wx.Image(path)
icon = self.make_icon(image)
self.SetIcon(icon, tool_tip)
# def CreatePopupMenu(self, event=None):
# self.on_icon_click(event)
class Frame(wx.Frame):
def __init__(self, *args, **kwargs):
super(Frame, self).__init__(*args, **kwargs)
self.app = wx.GetApp()
self.icon = Icon(self, TRAY_ICON, TRAY_ICON_TOOLTIP)
def quit(self):
self.app.ExitMainLoop()
if __name__ == "__main__":
app = wx.App()
frame = Frame(None)
frame.Show(False)
app.SetTopWindow(frame)
app.MainLoop()
注意我们不想使用 CreatePopupMenu(因为它只在左键单击时触发),而是想抓取所有三个指定的鼠标事件。
最佳答案
任务栏图标的实现取决于操作系统。以下应用程序绑定(bind)了 wxPython 中提供的所有事件,因此您可以使用它进行测试。
import wx
from wx.lib.embeddedimage import PyEmbeddedImage
task = PyEmbeddedImage(
"iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAABHNCSVQICAgIfAhkiAAAArxJ"
"REFUWIXl1z9oJGUYx/HPrvvP3SVmZYkkatYmJ1wTUmhp5YFFQC3kCq8RbAXBTrCxMoXClVdc"
"JwtiZxfRQgsRRNJsSBMxiPljdkl2WZPMMtmsxb17SfbmcicIjvg0v3mf9/fOvO+X531nhv97"
"ZCYTq6urc9BsNm/DxsbGq9Dtdqfg7OwsG1SSDofDK/ODwWAA/X6/BNl/fEl/My4SmIKlpaWf"
"oFarXYM4jnG+gkk9PT29sn+svV4PtNvtS8/+1wnkxhf5fP5D2NvbG0Kr1foE4jg+gVwudxNq"
"tVoe2u325xP3WoC5ublbsLOz823Ifx90THt4cVAqCOQgjuOXYXd396XQd3TRODU1dQNGo9FW"
"SH08ca93IYqiW6H9ZdA7V00gFQTOwvXbQY+SjMVi8Xk4ODj48SH9Dc6rHp3HmUCqCOw+xPME"
"HB8fPwuDweCPJFO5XJ6FQqEAeuON/4hIBYFHxRyUSqUc9Hq9RFKVSuUZyGTuH66JtTQZ/wkC"
"81Aul8ftnSRTtVp9mvN3A6LHmUD6CVQqlRc4r278nuQrFAoVyGbvr2mY5JuM9BNoNBqvQxRF"
"4/PityRfPp/PcmkXVJN8y8vLL8Lm5uavpJnAwsLCezAajd4KqfHKB0n+TCZzCMViEdTr9Teh"
"0+n8HCwjaLVad2Fra+sN0khgcXHxHTg8PLzN+TdhJpP5JViKQS+RyOfz69Dv91+B+fn5D2Bl"
"ZeUaNJvNJ2Ftbe25MOSMFBB44L+g0WisQ7vdvg6zs7Nge3v7DkRR9H6wXjrpZmZmbkC9Xv8a"
"Op17nwNRdM82ro1ut/spxHH8ESkg8EANlEqlH2B6evo6HB0ddSCKomawJO6C/f39b6BarX4B"
"xWLxJmSz2RGcnJx8BXEcfxaGnJACAg/UAOpBl4OuB10LeurqeCroa0H/DPrdRBspIPAXawn9"
"rf2GhSwAAAAASUVORK5CYII=")
class MainWindow(wx.Frame):
def __init__(self, *args, **kwargs):
wx.Frame.__init__(self, *args, **kwargs)
self.panel = wx.Panel(self)
self.tbicon = wx.TaskBarIcon()
self.tbicon.SetIcon(task.GetIcon(), "Test")
self.tbicon.Bind(wx.EVT_TASKBAR_LEFT_DOWN, self.LD)
self.tbicon.Bind(wx.EVT_TASKBAR_LEFT_UP, self.LU)
self.tbicon.Bind(wx.EVT_TASKBAR_RIGHT_DOWN, self.RD)
self.tbicon.Bind(wx.EVT_TASKBAR_RIGHT_UP, self.RU)
self.tbicon.Bind(wx.EVT_TASKBAR_LEFT_DCLICK, self.LDC)
self.tbicon.Bind(wx.EVT_TASKBAR_RIGHT_DCLICK, self.LDC)
# This is a synonym for either wx.EVT_TASKBAR_RIGHT_DOWN
# or UP depending on the platform, use this event macro
# to catch the event which should result in the menu being
# displayed on the current platform.
self.tbicon.Bind(wx.EVT_TASKBAR_CLICK, self.Click)
self.Bind(wx.EVT_CLOSE, self.Cleanup)
self.Show()
def Click(self, e):
print("Click")
e.Skip()
def LD(self, e):
print("LD")
e.Skip()
def LU(self, e):
print("LU")
e.Skip()
def RD(self, e):
print("RD")
e.Skip()
def RU(self, e):
print("RU")
e.Skip()
def LDC(self, e):
print("L-DClick")
e.Skip()
def RDC(self, e):
print("R-DClick")
e.Skip()
def Cleanup(self, e):
self.tbicon.Destroy()
wx.Exit()
app = wx.App(False)
win = MainWindow(None)
app.MainLoop()
例如,在 Windows 7 上:
如果它在 OS X 上不工作,或者你得到的行为对于你的平台来说似乎是错误的,请考虑在 http://trac.wxwidgets.org/ 报告错误。 .
关于python - Mac OSX 上 WxPython TaskBarIcon 的鼠标事件未触发,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20884467/
我找到了 this excellent question and answer它以 x/y(加上 center x/y 和 degrees/radians)开始并计算旋转- 到 x'/y'。这个计算很
全部: 我已经创建了一个 Windows 窗体和一个按钮。在另一个线程中,我试图更改按钮的文本,但它崩溃了;但是如果我尝试更改按钮的颜色,它肯定会成功。我认为如果您更改任何 Windows 窗体控件属
本网站的另一个问题已证实,C 中没有缩写的字面后缀,并且可以执行以下操作: short Number = (short)1; 但是转换它和不这样做有什么区别: short Number = 1; 您使
我有下表: ID (int) EMAIL (varchar(50)) CAMPAIGNID (int) isSubscribe (bit) isActionByUser (bit) 此表存储了用户对事
也就是说,无需触发Javascript事件即可改变的属性,如何保留我手动选中或取消选中的复选框的状态,然后复制到另一个地方? 运行下面的代码片段并选中或取消选中其中的一些,然后点击“复制”: $('#
我在网上找到的所有关于递增指针导致段错误的示例都涉及指针的取消引用 - 如果我只想递增它(例如在 for 循环的末尾)并且我不在乎它是否最终进入无效内存,因为我不会再使用它。例如,在这个程序中,每次迭
我有一个 Spring MVC REST 服务,它使用 XStream 将消息与 XML 相互转换。 有什么方法可以将请求和响应中的 xml(即正文)打印到普通的 log4j 记录器? 在 Contr
做我的任务有一个很大的挑战,那就是做相互依赖的任务我在这张照片中说的。假设我们有两个任务 A 和 B,执行子任务 A1、A2 和 B1、B2,假设任务 B 依赖于 A。 要理想地执行任务 B,您应该执
通过阅读该网站上的几个答案,我了解到 CoInitialize(Ex) should be called by the creator of a thread 。然后,在该线程中运行的任何代码都可以使
这个问题已经困扰我一段时间了。我以前从未真正使用过 ListViews,也没有使用过 FirebaseListAdapters。我想做的就是通过显示 id 和用户位置来启动列表的基础,但由于某种原因,
我很难解释这两个(看似简单)句子的含义: “受检异常由编译器在编译时检查” 这是什么意思?编译器检查是否捕获了所有已检查的异常(在代码中抛出)? “未经检查的异常在运行时检查,而不是编译时” 这句话中
我有一个包含排除子字符串的文本文件,我想迭代该文件以检查并返回不带排除子字符串的输入项。 这里我使用 python 2.4,因此下面的代码可以实现此目的,因为 with open 和 any 不起作用
Spring 的缓存框架能否了解请求上下文的身份验证状态,或者更容易推出自己的缓存解决方案? 最佳答案 尽管我发现这个用例 super 奇怪,但您可以为几乎任何与 SpEL 配合使用的内容设置缓存条件
我有以下函数模板: template HeldAs* duplicate(MostDerived *original, HeldAs *held) { // error checking omi
如果我的应用程序具有设备管理员/设备所有者权限(未获得 root 权限),我如何才能从我的应用程序中终止(或阻止启动)另一个应用程序? 最佳答案 设备所有者可以阻止应用程序: DevicePolicy
非常简单的问题,但我似乎无法让它正常工作。 我有一个组件,其中有一些 XSLT(用于导航)。它通过 XSLT TBB 使用 XSLT Mediator 发布。 发布后
我正在将一个对象拖动到一个可拖放的对象内,该对象也是可拖动的。放置对象后,它会嵌套在可放置对象内。同样,如果我将对象拖到可放置的外部,它就不再嵌套。 但是,如果我经常拖入和拖出可放置对象,则可拖动对象
我正在尝试为按钮和弹出窗口等多个指令实现“取消选择”功能。也就是说,我希望当用户单击不属于指令模板一部分的元素时触发我的函数。目前,我正在使用以下 JQuery 代码: $('body').click
我从 this question 得到了下面的代码,该脚本用于在 Google tasks 上更改 iframe[src="about:blank"] 内的 CSS使用 Chrome 扩展 Tempe
我有一些 @Mock 对象,但没有指定在该对象上调用方法的返回值。该方法返回 int (不是 Integer)。我很惊讶地发现 Mockito 没有抛出 NPE 并返回 0。这是预期的行为吗? 例如:
我是一名优秀的程序员,十分优秀!