想實現用win32 API在tkinter窗口上畫圖,那么應該先獲得tkinter窗口的句柄hwnd,然后再獲得tkinter的設備hdc。嘗試了FindWindow(),GetActiveWindow(),GetForegroundWindow()這幾個函數貌似都不能正確獲得tkinter的句柄
后來在stackoverflow上看到一個列子,使用pywintypes.HANDLE(int(root.frame(), 16))才成功。
原例:https://stackoverflow.com/questions/25602986/using-python-tkinter-how-to-smoothly-move-and-resize-the-non-focusable-window
這里我把原例中創建一個non focusable window的tkinter窗口,修改為把窗口設置樣式設置為WS_POPUP
import tkinter as tk import win32api import win32con import pywintypes root = tk.Tk() root.geometry("+0+0") root.lift() hWindow = pywintypes.HANDLE(int(root.frame(), 16)) win32api.SetWindowLong(hWindow,win32con.GWL_STYLE,win32con.WS_POPUP) root.mainloop()

這個窗口風格,類似overrideredirect(1)
我想實現的功能是在tkinter窗口上繪畫,那么似乎要考慮在哪里開始使用繪制代碼,以及窗口重繪的問題。事實上,我只有把畫圖代碼定義成一個事件的回調函數時,圖形才繪制出來。而對窗口重繪沒有找到辦法
from win32gui import * import win32con import pywintypes from tkinter import * root=Tk() root.title("tkinterApp") hwnd = pywintypes.HANDLE(int(root.frame(), 16)) print(hwnd) hdc=GetDC(hwnd) def callback(): hbrush=GetStockObject(win32con.NULL_BRUSH) oldbrush=SelectObject(hdc,hbrush) Rectangle(hdc,50,50,100,100) Button(root,text="顯示畫圖",command=callback).pack() # #ReleaseDC(hwnd,hdc) root.geometry("400x400") #root.mainloop()

解決方法
from win32gui import * import win32con import pywintypes from tkinter import * root=Tk() hwnd = pywintypes.HANDLE(int(root.frame(), 16)) hdc=GetDC(hwnd) def callback(event): root.update() hbrush=GetStockObject(win32con.NULL_BRUSH) oldbrush=SelectObject(hdc,hbrush) Rectangle(hdc,50,50,100,100) root.geometry("400x400") root.bind("<Configure>",callback) root.mainloop()
