1

コードで何度も呼び出しdef balloon_tip(title, msg)ています。この定義は、systray 通知バルーンを表示します。この定義を呼び出すときはいつでも、この定義を別のプロセスまたはスレッドで処理する必要があります。この定義をスレッド化しようとしましたが、WindowsBalloonTip のクラスの登録と登録解除が含まれているため機能しませんでした。

 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)
4

1 に答える 1

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 にのみ展開しているため、すべての .NET UI フレームワークに完全にアクセスできるIronPythonの使用を検討することもできます。
  • f.close()ファイルを開くためにすでに with を使用している場合は、呼び出すべきではありません。ファイルは自動的に閉じられます。
  • かっこはすでに十分であるため、使用した場所にバックスラッシュを使用する必要はありません。

    some_function_call(arg1, arg,    # <-- no `\`; expression wrapped in `()`
                       arg3, arg4)
    
  • Python 2.xからクラスを継承する必要objectがあります。そうしないと、あまり良くない古いスタイルのクラスが得られます。

    class WindowsBalloonTip(object):
        ...
    

    Python 3.x では、これが既にデフォルトになっています。

于 2013-10-03T11:13:06.860 に答える