Python Tkinter GUI編程實(shí)現(xiàn)Frame切換
Frame切換
在本文中,將介紹如何使用 Frame tkraise() 方法在 Tkinter 應(yīng)用程序中的Frame之間切換。
1、Frame的tkraise() 方法介紹
通常,一個(gè) Tkinter 應(yīng)用程序由多個(gè)Frame組成。 而且您經(jīng)常需要在Frame之間切換以顯示與用戶選擇相關(guān)的Frame。
Tkinter 允許將Frame堆疊在一起。 要顯示特定Frame,只需按堆疊順序?qū)⒁粋€(gè)放在另一個(gè)之上。 頂部Frame將可見。
要將Frame置于頂部,可以使用 Frame 小部件的 tkraise() 方法,如下所示:
frame.tkraise()
2、tkraise用法示例
下面將實(shí)現(xiàn)一個(gè)溫度轉(zhuǎn)換小應(yīng)用,華氏溫度和攝氏溫度分別使用兩個(gè)不同的Frame,UI窗口組成如下:
ConverterFrame 將有兩個(gè)實(shí)例,一個(gè)將溫度從華氏溫度轉(zhuǎn)換為攝氏溫度,另一個(gè)將溫度從攝氏溫度轉(zhuǎn)換為華氏溫度:
第一步,定義一個(gè)具有兩個(gè)靜態(tài)方法的 TemperatureConverter 類:fahrenheit_to_celsius 和 celsius_to_fahrenheit。
class TemperatureConverter: @staticmethod def fahrenheit_to_celsius(f, format=True): result = (f - 32) * 5/9 if format: return f'{f} Fahrenheit = {result:.2f} Celsius' return result @staticmethod def celsius_to_fahrenheit(c, format=True): result = c * 9/5 + 32 if format: return f'{c} Celsius = {result:.2f} Fahrenheit' return result
如果忽略第二個(gè)參數(shù)或?qū)?True 傳遞給它們,那么 fahrenheit_to_celsius 和 celsius_to_fahrenheit 方法將返回一個(gè)格式化字符串。 否則,他們會將結(jié)果作為數(shù)字返回。
第二步,定義將顯示用于將溫度從華氏溫度轉(zhuǎn)換為攝氏溫度的 UI 的 ConverterFrame,反之亦然。
為此,需要通過將以下參數(shù)添加到 __init__()
方法來使 ConverterFrame 更加靈活:
- 將顯示為華氏溫度和攝氏度的字符串
- 用于轉(zhuǎn)換溫度的回調(diào)函數(shù)。
class ConverterFrame(ttk.Frame): def __init__(self, container, unit_from, converter): super().__init__(container) self.unit_from = unit_from self.converter = converter # field options options = {'padx': 5, 'pady': 0} # temperature label self.temperature_label = ttk.Label(self, text=self.unit_from) self.temperature_label.grid(column=0, row=0, sticky='w', **options) # temperature entry self.temperature = tk.StringVar() self.temperature_entry = ttk.Entry(self, textvariable=self.temperature) self.temperature_entry.grid(column=1, row=0, sticky='w', **options) self.temperature_entry.focus() # button self.convert_button = ttk.Button(self, text='Convert') self.convert_button.grid(column=2, row=0, sticky='w', **options) self.convert_button.configure(command=self.convert) # result label self.result_label = ttk.Label(self) self.result_label.grid(row=1, columnspan=3, **options) # add padding to the frame and show it self.grid(column=0, row=0, padx=5, pady=5, sticky="nsew") def convert(self, event=None): """ Handle button click event """ try: input_value = float(self.temperature.get()) result = self.converter(input_value) self.result_label.config(text=result) except ValueError as error: showerror(title='Error', message=error) def reset(self): self.temperature_entry.delete(0, "end") self.result_label.text = ''
上面代碼如何工作?
- 1)使用 unit_from 參數(shù)顯示溫度標(biāo)簽。
- 2)在 convert() 方法中調(diào)用 self.convert 回調(diào)將溫度從一個(gè)單位轉(zhuǎn)換為另一個(gè)單位。
- 3)定義 reset() 方法以在Frame從一個(gè)切換到另一個(gè)時(shí)清除條目小部件和結(jié)果標(biāo)簽。
第三,定義一個(gè) ControlFrame 類,該類顯示用于選擇要顯示的Frame的單選按鈕。 ControFrame 類繼承自 ttk.LabelFrame。
class ControlFrame(ttk.LabelFrame): def __init__(self, container): super().__init__(container) self['text'] = 'Options' # radio buttons self.selected_value = tk.IntVar() ttk.Radiobutton( self, text='F to C', value=0, variable=self.selected_value, command=self.change_frame).grid(column=0, row=0, padx=5, pady=5) ttk.Radiobutton( self, text='C to F', value=1, variable=self.selected_value, command=self.change_frame).grid(column=1, row=0, padx=5, pady=5) self.grid(column=0, row=1, padx=5, pady=5, sticky='ew') # initialize frames self.frames = {} self.frames[0] = ConverterFrame( container, 'Fahrenheit', TemperatureConverter.fahrenheit_to_celsius) self.frames[1] = ConverterFrame( container, 'Celsius', TemperatureConverter.celsius_to_fahrenheit) self.change_frame() def change_frame(self): frame = self.frames[self.selected_value.get()] frame.reset() frame.tkraise()
上面代碼如何工作?
- 每個(gè)單選按鈕都有一個(gè)值 0 或 1。
- 創(chuàng)建 ConverterFrame 類的兩個(gè)實(shí)例,一個(gè)負(fù)責(zé)將溫度從華氏溫度轉(zhuǎn)換為攝氏溫度,另一個(gè)負(fù)責(zé)將溫度從攝氏溫度轉(zhuǎn)換為華氏溫度。 另外,定義一個(gè)字典來存儲這些Frame。 Frame的鍵與單選按鈕的值相同。
- 單擊單選按鈕時(shí),會調(diào)用 change_frame() 方法根據(jù)所選按鈕的值從字典中選擇相應(yīng)的Frame。
- 調(diào)用Frame的 reset() 方法來重置輸入字段和結(jié)果標(biāo)簽。 并且還調(diào)用 tkraise() 方法來顯示Frame。
第四,定義從 tk.Tk 類繼承的 App 類:
class App(tk.Tk): def __init__(self): super().__init__() self.title('Temperature Converter') self.geometry('300x120') self.resizable(False, False)
最后,啟動程序
if __name__ == "__main__": app = App() ControlFrame(app) app.mainloop()
代碼整合如下:
import tkinter as tk from tkinter import ttk from tkinter.messagebox import showerror class TemperatureConverter: @staticmethod def fahrenheit_to_celsius(f, format=True): result = (f - 32) * 5/9 if format: return f'{f} Fahrenheit = {result:.2f} Celsius' return result @staticmethod def celsius_to_fahrenheit(c, format=True): result = c * 9/5 + 32 if format: return f'{c} Celsius = {result:.2f} Fahrenheit' return result class ConverterFrame(ttk.Frame): def __init__(self, container, unit_from, converter): super().__init__(container) self.unit_from = unit_from self.converter = converter # field options options = {'padx': 5, 'pady': 0} # temperature label self.temperature_label = ttk.Label(self, text=self.unit_from) self.temperature_label.grid(column=0, row=0, sticky='w', **options) # temperature entry self.temperature = tk.StringVar() self.temperature_entry = ttk.Entry(self, textvariable=self.temperature) self.temperature_entry.grid(column=1, row=0, sticky='w', **options) self.temperature_entry.focus() # button self.convert_button = ttk.Button(self, text='Convert') self.convert_button.grid(column=2, row=0, sticky='w', **options) self.convert_button.configure(command=self.convert) # result label self.result_label = ttk.Label(self) self.result_label.grid(row=1, columnspan=3, **options) # add padding to the frame and show it self.grid(column=0, row=0, padx=5, pady=5, sticky="nsew") def convert(self, event=None): """ Handle button click event """ try: input_value = float(self.temperature.get()) result = self.converter(input_value) self.result_label.config(text=result) except ValueError as error: showerror(title='Error', message=error) def reset(self): self.temperature_entry.delete(0, "end") self.result_label.text = '' class ControlFrame(ttk.LabelFrame): def __init__(self, container): super().__init__(container) self['text'] = 'Options' # radio buttons self.selected_value = tk.IntVar() ttk.Radiobutton( self, text='F to C', value=0, variable=self.selected_value, command=self.change_frame).grid(column=0, row=0, padx=5, pady=5) ttk.Radiobutton( self, text='C to F', value=1, variable=self.selected_value, command=self.change_frame).grid(column=1, row=0, padx=5, pady=5) self.grid(column=0, row=1, padx=5, pady=5, sticky='ew') # initialize frames self.frames = {} self.frames[0] = ConverterFrame( container, 'Fahrenheit', TemperatureConverter.fahrenheit_to_celsius) self.frames[1] = ConverterFrame( container, 'Celsius', TemperatureConverter.celsius_to_fahrenheit) self.change_frame() def change_frame(self): frame = self.frames[self.selected_value.get()] frame.reset() frame.tkraise() class App(tk.Tk): def __init__(self): super().__init__() self.title('Temperature Converter') self.geometry('480x240') self.resizable(False, False) if __name__ == "__main__": app = App() ControlFrame(app) app.mainloop()
運(yùn)行結(jié)果如下:
到此這篇關(guān)于Python Tkinter GUI編程實(shí)現(xiàn)Frame切換的文章就介紹到這了,更多相關(guān)Python Tkinter GUI Frame切換內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
利用Django提供的ModelForm增刪改數(shù)據(jù)的方法
這篇文章主要介紹了利用Django提供的ModelForm增刪改數(shù)據(jù),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-01-01python腳本設(shè)置系統(tǒng)時(shí)間的兩種方法
這篇文章主要介紹了python腳本設(shè)置系統(tǒng)時(shí)間的兩種方法,其一是調(diào)用socket直接發(fā)送udp包到國家授時(shí)中心,其二是調(diào)用ntplib包,感興趣的小伙伴們可以參考一下2016-02-02Python中關(guān)于print和return的區(qū)別
這篇文章主要介紹了Python中關(guān)于print和return的區(qū)別,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-02-02Python實(shí)現(xiàn)提取JSON文件中指定數(shù)據(jù)并保存至CSV或Excel內(nèi)
這篇文章主要介紹了如何基于Python語言實(shí)現(xiàn)讀取JSON格式的數(shù)據(jù),并將提取到的數(shù)據(jù)保存到.csv格式或.xlsx格式的表格文件中,感興趣的小伙伴可以了解下2023-08-08使用Python如何將視頻按照一定時(shí)間切割(比如:每10s進(jìn)行裁切)
這篇文章主要介紹了使用Python將視頻按照一定時(shí)間切割(比如:每10s進(jìn)行裁切),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07使用Python實(shí)現(xiàn)畫一個(gè)中國地圖
今天小編就為大家分享一篇使用Python實(shí)現(xiàn)畫一個(gè)中國地圖,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11Python下實(shí)現(xiàn)的RSA加密/解密及簽名/驗(yàn)證功能示例
這篇文章主要介紹了Python下實(shí)現(xiàn)的RSA加密/解密及簽名/驗(yàn)證功能,結(jié)合具體實(shí)例形式分析了Python中RSA加密、解密的實(shí)現(xiàn)方法及簽名、驗(yàn)證功能的使用技巧,需要的朋友可以參考下2017-07-07