1

Windows 7 マシンで Python 2.7 を使用しています。通知は正常に機能しています。しかし、アラート ボックス/ダイアログ ボックスを含めると、プロセスはアラート ボックスのコードを無視し、ダイアログ ボックスはポップアップしません。私の通知コードは次のとおりです。

class WindowsBalloonTip:
    def __init__(self, title, msg):
        message_map = {
                win32con.WM_DESTROY: self.OnDestroy,
        }
        # Register the Window class.
        iconPathName= "D:\icon.ico"

        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)

私の警告ボックスのコードは次のとおりです。

import win32api
a=0       
a=win32api.MessageBox(0, 'message', 'title',0)

まず、通知を使用してからダイアログ ボックスを使用しています。デバッグすると、見つかった問題はUnregisterClass(wc.lpszClassName, hinst). 私はそれを試してみましたが、次のようなエラーが表示されました。

classAtom = RegisterClass(wc)
pywintypes.error: (1410, 'RegisterClass', 'Class already exists.')

私の要件は、さまざまな関数から通知コードを呼び出してから、単一のプロセスで他の関数からダイログ ボックスを呼び出すことです。

4

1 に答える 1

1

私は非常によく似た問題を抱えています: Python スレッドからの Windows バルーン ヒントの更新

これを確認してください: 複数の WindowsBaloonTip / TrayTip 通知?

上記の修正により、ウィンドウを削除して登録を解除できましたが、1 つのスレッドからのみでした。別のスレッドは同じウィンドウを処理できません。それが関数にも当てはまるかどうかはわかりません..

これはコメントであり、回答ではありません..しかし、私は今のところ50歳未満です。

于 2014-06-12T15:10:36.117 に答える