用過gifcam的小伙伴應該對那個透明的窗口留下深刻印象。透明窗體的實現實際上并不是很復雜。以python tkinter庫為例,python實現透明窗體只需要三步。接下來這篇文章就帶你實現一個透明窗體的效果。
一、基礎說起
(一)實現最簡單的窗體
from tkinter import *
if __name__ == '__main__':
tk = Tk()
tk.geometry('500x400+500+150')
tk.title('有趣的透明窗體-開篇了?。。?#39;)
canvas = Canvas(tk)
canvas.pack(fill=BOTH, expand=Y)
tk.mainloop()
太簡單了,不詳細說了,相信大家都看得懂。
效果:
感覺空寥寥的,什么都沒有,好無聊啊。
二、好戲開始了
也許最有趣的透明窗體就是從這么簡單的代碼開始。
我們可以設置一個叫做透明色的顏色,然后讓窗體canvas畫一個矩形框,然后將這個矩形框的內色設置成透明色,那這個窗體不就透明了嗎?
呵呵,是不是太簡單了。
那我們就開始設置一下。
(一)把灰色設置成透明色
TRANSCOLOUR = 'gray'
tk.wm_attributes('-transparentcolor', TRANSCOLOUR)
(二)放置一個矩形框在canvas上。
canvas.create_rectangle(0, 0, canvas.winfo_width(), canvas.winfo_height(), fill=TRANSCOLOUR, outline=TRANSCOLOUR)
(三)大家有發(fā)現變化嗎?
from tkinter import *
if __name__ == '__main__':
TRANSCOLOUR = 'gray'
tk = Tk()
tk.geometry('500x400+500+150')
tk.title('有趣的透明窗體-開篇了!?。?#39;)
canvas = Canvas(tk)
canvas.pack(fill=BOTH, expand=Y)
canvas.create_rectangle(0, 0, canvas.winfo_width(), canvas.winfo_height(), fill=TRANSCOLOUR, outline=TRANSCOLOUR)
tk.mainloop()
發(fā)現,程序完全不鳥我的代碼,還是原來的老樣子。
但是邏輯沒有錯誤啊,代碼也沒有報錯啊,那到底哪里錯了呢?
三、成功的背后總有殘缺
不斷摸索后,原來思路是對的,但是窗體很努力,它會不斷的重復調用重畫窗體的操作,也就是說在后面自動重畫的過程中,程序調用默認的代碼,把我設置的透明窗體覆蓋了,所以,透明窗體不見了。
(一)讓透明窗體不斷重畫的onsize函數
def on_resize(evt):
tk.configure(width=evt.width,height=evt.height)
canvas.create_rectangle(0, 0, canvas.winfo_width(), canvas.winfo_height(), fill=TRANSCOLOUR, outline=TRANSCOLOUR)
print(canvas.winfo_width())
(二)綁定onsize函數
tk.bind('<Configure>', on_resize)
(三)最終的效果
哈哈,效果出來了,真的透明了,開心、高興。
(四)錄制了個動態(tài)看看
好吧,寫完,完整的代碼就先不發(fā)了,大家有興趣可以看上面的過程,自己整合就可以湊成完整的代碼,自己動動手,也許比我直接分享最終代碼的效果更好。
將一件事情做到極致,也許你會得到更大的快樂!
比心!
以上就是python實現透明窗體的詳細內容,更多python的tkinter學習資料請關注W3Cschool其它相關文章!