python使用tkinter實(shí)現(xiàn)透明窗體
from tkinter import *if __name__ == ’__main__’: tk = Tk() tk.geometry(’500x400+500+150’) tk.title(’有趣的透明窗體-開篇了!!!’) canvas = Canvas(tk) canvas.pack(fill=BOTH, expand=Y) tk.mainloop()
太簡單了,不詳細(xì)說了,相信大家都看得懂。效果:
感覺空寥寥的,什么都沒有,好無聊啊。
二、好戲開始了也許最有趣的透明窗體就是從這么簡單的代碼開始。
我們可以設(shè)置一個(gè)叫做透明色的顏色,然后讓窗體canvas畫一個(gè)矩形框,然后將這個(gè)矩形框的內(nèi)色設(shè)置成透明色,那這個(gè)窗體不就透明了嗎?
呵呵,是不是太簡單了。那我們就開始設(shè)置一下。
(一)把灰色設(shè)置成透明色TRANSCOLOUR = ’gray’tk.wm_attributes(’-transparentcolor’, TRANSCOLOUR)(二)放置一個(gè)矩形框在canvas上。
canvas.create_rectangle(0, 0, canvas.winfo_width(), canvas.winfo_height(), fill=TRANSCOLOUR, outline=TRANSCOLOUR)(三)大家有發(fā)現(xiàn)變化嗎?
from tkinter import *if __name__ == ’__main__’: TRANSCOLOUR = ’gray’ tk = Tk() tk.geometry(’500x400+500+150’) tk.title(’有趣的透明窗體-開篇了!!!’) 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ā)現(xiàn),程序完全不鳥我的代碼,還是原來的老樣子。
但是邏輯沒有錯(cuò)誤啊,代碼也沒有報(bào)錯(cuò)啊,那到底哪里錯(cuò)了呢?
三、成功的背后總有殘缺不斷摸索后,原來思路是對(duì)的,但是窗體很努力,它會(huì)不斷的重復(fù)調(diào)用重畫窗體的操作,也就是說在后面自動(dòng)重畫的過程中,程序調(diào)用默認(rèn)的代碼,把我設(shè)置的透明窗體覆蓋了,所以,透明窗體不見了。
(一)讓透明窗體不斷重畫的onsize函數(shù)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函數(shù)
tk.bind(’<Configure>’, on_resize)(三)最終的效果
哈哈,效果出來了,真的透明了,開心、高興。
好吧,寫完,完整的代碼就先不發(fā)了,大家有興趣可以看上面的過程,自己整合就可以湊成完整的代碼,自己動(dòng)動(dòng)手,也許比我直接分享最終代碼的效果更好。
將一件事情做到極致,也許你會(huì)得到更大的快樂!比心!
以上就是python使用tkinter實(shí)現(xiàn)透明窗體的詳細(xì)內(nèi)容,更多關(guān)于python tkinter實(shí)現(xiàn)透明窗體的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. ASP常用日期格式化函數(shù) FormatDate()2. html中的form不提交(排除)某些input 原創(chuàng)3. bootstrap select2 動(dòng)態(tài)從后臺(tái)Ajax動(dòng)態(tài)獲取數(shù)據(jù)的代碼4. 網(wǎng)頁中img圖片使用css實(shí)現(xiàn)等比例自動(dòng)縮放不變形(代碼已測試)5. CSS3中Transition屬性詳解以及示例分享6. python 如何在 Matplotlib 中繪制垂直線7. vue使用moment如何將時(shí)間戳轉(zhuǎn)為標(biāo)準(zhǔn)日期時(shí)間格式8. js select支持手動(dòng)輸入功能實(shí)現(xiàn)代碼9. jsp文件下載功能實(shí)現(xiàn)代碼10. 開發(fā)效率翻倍的Web API使用技巧
