2013-10-03 66 views
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) 
+0

這是一個函數,而不是「def」。 –

+0

好的,但如何解決它,是真實的東西 –

+2

你應該使用一些更高級別的窗口工具包不是原始的WIN32API。此外,還有3件事:** 1)**當您已經使用'with'打開文件時,您不應該調用'f.close()',它會自動關閉它,並且** 2)**你不需要在你已經使用過的地方使用反斜槓,因爲括號已經足夠了,並且** 3)**你應該從Python 2.x中的'object'繼承你的類,否則你會得到一箇舊的 - 風格不是很好。 –

回答

1

我不正是知道你是問什麼,但如果你只是想運行在一個線程的功能,這裏是如何做到這一點:

import threading 

thread = threading.Thread(target=your_function, args=(1, 2, 3)) # args is optional 
thread.start() 

# thread.join() # if needed 
# thread.join(timeout=2.0) # if needed 

此外:

  • 你應該真的使用一些更高級別的開窗工具包而不是原始的WIN32API;另外,由於您顯然只在Windows上進行部署,因此您甚至可以考慮使用IronPython來完全訪問所有.NET UI框架。
  • 如果你已經用打開你不應該叫f.close()文件,它會自動將其關閉
  • 因爲括號已經足夠你不需要使用反斜槓,你用他們:

    some_function_call(arg1, arg, # <-- no `\`; expression wrapped in `()` 
            arg3, arg4) 
    
  • 你應該繼承object你的類在Python 2.x中,否則你會得到一箇舊式類,這是不那麼好:

    class WindowsBalloonTip(object): 
        ... 
    

    在Python 3.x中,這已經是默認設置。