1
我在代碼中多次呼叫def balloon_tip(title, msg)
。此def顯示系統托盤通知氣球。我希望在任何時候我調用這個def,它應該在單獨的進程或線程中處理這個def。我嘗試將這個def作爲線程,但是它不起作用,因爲它包含了註冊和註銷WindowsBalloonTip的類。如何在Python中編寫函數
class WindowsBalloonTip:
def __init__(self, title, msg):
message_map = {
win32con.WM_DESTROY: self.OnDestroy,
}
# Register the Window class.
iconPathName= rootLocation + os.sep + d['iconPathName']
wc = WNDCLASS()
hinst = wc.hInstance = GetModuleHandle(None)
wc.lpszClassName = "PythonTaskbar"
wc.lpfnWndProc = message_map # could also specify a wndproc.
classAtom = RegisterClass(wc)
# Create the Window.
style = win32con.WS_OVERLAPPED | win32con.WS_SYSMENU
self.hwnd = CreateWindow(classAtom, "Taskbar", style, \
0, 0, win32con.CW_USEDEFAULT, win32con.CW_USEDEFAULT, \
0, 0, hinst, None)
UpdateWindow(self.hwnd)
print iconPathName
icon_flags = win32con.LR_LOADFROMFILE | win32con.LR_DEFAULTSIZE
try:
hicon = LoadImage(hinst,iconPathName, win32con.IMAGE_ICON, 16, 16,icon_flags)
except:
hicon = LoadIcon(0, win32con.IDI_APPLICATION)
logging.debug("Image adding fail")
flags = NIF_ICON | NIF_MESSAGE | NIF_TIP
nid = (self.hwnd, 0, flags, win32con.WM_USER+20, hicon, "TITLE")
Shell_NotifyIcon(NIM_ADD, nid)
Shell_NotifyIcon(NIM_MODIFY, \
(self.hwnd, 0, NIF_INFO, win32con.WM_USER+20,\
hicon, "Balloon tooltip",msg,200,title))
# self.show_balloon(title, msg)
global sleep
time.sleep(sleep)
DestroyWindow(self.hwnd)
UnregisterClass(wc.lpszClassName, None)
def OnDestroy(self, hwnd, msg, wparam, lparam):
nid = (self.hwnd, 0)
Shell_NotifyIcon(NIM_DELETE, nid)
PostQuitMessage(0)
# Terminate the app.
def balloon_tip(title, msg):
w=WindowsBalloonTip(title, msg)
這是一個函數,而不是「def」。 –
好的,但如何解決它,是真實的東西 –
你應該使用一些更高級別的窗口工具包不是原始的WIN32API。此外,還有3件事:** 1)**當您已經使用'with'打開文件時,您不應該調用'f.close()',它會自動關閉它,並且** 2)**你不需要在你已經使用過的地方使用反斜槓,因爲括號已經足夠了,並且** 3)**你應該從Python 2.x中的'object'繼承你的類,否則你會得到一箇舊的 - 風格不是很好。 –