python使用tkinter實(shí)現(xiàn)透明窗體
一、基礎(chǔ)說(shuō)起
(一)實(shí)現(xiàn)最簡(jiǎn)單的窗體
from tkinter import * if __name__ == '__main__': tk = Tk() tk.geometry('500x400+500+150') tk.title('有趣的透明窗體-開(kāi)篇了?。?!') canvas = Canvas(tk) canvas.pack(fill=BOTH, expand=Y) tk.mainloop()
太簡(jiǎn)單了,不詳細(xì)說(shuō)了,相信大家都看得懂。
效果:
感覺(jué)空寥寥的,什么都沒(méi)有,好無(wú)聊啊。
二、好戲開(kāi)始了
也許最有趣的透明窗體就是從這么簡(jiǎn)單的代碼開(kāi)始。
我們可以設(shè)置一個(gè)叫做透明色的顏色,然后讓窗體canvas畫(huà)一個(gè)矩形框,然后將這個(gè)矩形框的內(nèi)色設(shè)置成透明色,那這個(gè)窗體不就透明了嗎?
呵呵,是不是太簡(jiǎn)單了。
那我們就開(kāi)始設(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('有趣的透明窗體-開(kāi)篇了!?。?) 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),程序完全不鳥(niǎo)我的代碼,還是原來(lái)的老樣子。
但是邏輯沒(méi)有錯(cuò)誤啊,代碼也沒(méi)有報(bào)錯(cuò)啊,那到底哪里錯(cuò)了呢?
三、成功的背后總有殘缺
不斷摸索后,原來(lái)思路是對(duì)的,但是窗體很努力,它會(huì)不斷的重復(fù)調(diào)用重畫(huà)窗體的操作,也就是說(shuō)在后面自動(dòng)重畫(huà)的過(guò)程中,程序調(diào)用默認(rèn)的代碼,把我設(shè)置的透明窗體覆蓋了,所以,透明窗體不見(jiàn)了。
(一)讓透明窗體不斷重畫(huà)的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)
(三)最終的效果
哈哈,效果出來(lái)了,真的透明了,開(kāi)心、高興。
(四)錄制了個(gè)動(dòng)態(tài)看看
好吧,寫(xiě)完,完整的代碼就先不發(fā)了,大家有興趣可以看上面的過(guò)程,自己整合就可以湊成完整的代碼,自己動(dòng)動(dòng)手,也許比我直接分享最終代碼的效果更好。
將一件事情做到極致,也許你會(huì)得到更大的快樂(lè)!
比心!
以上就是python使用tkinter實(shí)現(xiàn)透明窗體的詳細(xì)內(nèi)容,更多關(guān)于python tkinter實(shí)現(xiàn)透明窗體的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
python默認(rèn)參數(shù)調(diào)用方法解析
這篇文章主要介紹了python默認(rèn)參數(shù)調(diào)用方法解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-02-02教你pycharm運(yùn)行Django第一個(gè)項(xiàng)目
本文主要介紹了教你pycharm運(yùn)行Django第一個(gè)項(xiàng)目的實(shí)現(xiàn),文中通過(guò)圖文示例介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-08-08Python 中將秒轉(zhuǎn)換為小時(shí)、分鐘和秒的示例代碼
這篇文章主要介紹了在 Python 中將秒轉(zhuǎn)換為小時(shí)、分鐘和秒,本篇文章將討論使用 Python 中的四種不同方法來(lái)使用、管理秒并將其轉(zhuǎn)換為天、小時(shí)、分鐘和秒,需要的朋友可以參考下2023-05-05BP神經(jīng)網(wǎng)絡(luò)原理及Python實(shí)現(xiàn)代碼
這篇文章主要為大家詳細(xì)介紹了BP神經(jīng)網(wǎng)絡(luò)原理,以及Python實(shí)現(xiàn)BP神經(jīng)網(wǎng)絡(luò),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12python ForMaiR實(shí)現(xiàn)自定義規(guī)則的郵件自動(dòng)轉(zhuǎn)發(fā)工具
這篇文章主要為大家介紹了python ForMaiR實(shí)現(xiàn)自定義規(guī)則的郵件自動(dòng)轉(zhuǎn)發(fā)工具示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12PyCharm內(nèi)存占用過(guò)高問(wèn)題分析與優(yōu)化指南
PyCharm作為Python開(kāi)發(fā)領(lǐng)域最受歡迎的集成開(kāi)發(fā)環(huán)境(IDE)之一,以其強(qiáng)大的功能和智能化的開(kāi)發(fā)體驗(yàn)贏得了全球開(kāi)發(fā)者的青睞,然而,許多用戶(hù)在使用過(guò)程中都遇到了一個(gè)共同的問(wèn)題PyCharm的內(nèi)存占用率異常高企,所以本文介紹了PyCharm內(nèi)存占用過(guò)高問(wèn)題分析與優(yōu)化指南2025-05-05pandas中read_csv、rolling、expanding用法詳解
這篇文章主要介紹了pandas中read_csv、rolling、expanding用法詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-04-04Python基礎(chǔ)學(xué)習(xí)之函數(shù)方法實(shí)例詳解
這篇文章主要介紹了Python基礎(chǔ)學(xué)習(xí)之函數(shù)方法,結(jié)合實(shí)例形式分析了Python函數(shù)方法的定義、參數(shù)、復(fù)用和繼承相關(guān)操作技巧,需要的朋友可以參考下2019-06-06windows下cx_Freeze生成Python可執(zhí)行程序的詳細(xì)步驟
這篇文章主要介紹了windows下cx_Freeze生成Python可執(zhí)行程序的詳細(xì)步驟,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-10-10