python tkiner實現(xiàn) 一個小小的圖片翻頁功能的示例代碼
具體代碼如下所示:
import tkinter as tkimport tkinter.messageboximport copyimport os,sysdef get_picture(dirs):’’’獲得所有圖片’’’ picture_list = [] for dir,dir_abs,files in os.walk(dirs): for file in files: if file.endswith(’.gif’):picture_list.append(os.path.join(dir,file)) return picture_listclass Window: button_list = [] object_list = [] pictures = get_picture(picture_path) file = pictures[0] is_show = True index = 0 image_file = ’’ def __init__(self): ’’’創(chuàng)建窗口和frame’’’ self.window = tk.Tk() self.window.title(’my window’) self.window.geometry(’600x600’) self.frame = tk.Frame(self.window) self.frame.pack() self.frame_l = tk.Frame(self.frame) self.frame_r = tk.Frame(self.frame) self.frame_l.pack(side=’left’) self.frame_r.pack(side=’right’) self.frame_ll = tk.Frame(self.frame_r) self.frame_rr = tk.Frame(self.frame_r) self.frame_ll.pack(side=’left’) self.frame_rr.pack(side=’right’) def next_picture(self): ’’’下一張圖片’’’ self.index = self.pictures.index(self.file) self.index += 1 if self.index < len(self.pictures): self.checkout_button() self.file = self.pictures[self.index] self.create_canvas(self.file) else: self.index = len(self.pictures) - 1 tkinter.messagebox.showinfo(’提示’, ’已近是最后一張了’) def checkout_button(self): ’’’判斷列表中是否只有button對象’’’ object_list_copy = copy.copy(self.object_list) for ob in self.object_list: if ob in self.button_list:pass else:b = object_list_copy.pop(self.object_list.index(ob))b.destroy() self.object_list = object_list_copy def pre_picture(self): ’’’上一頁’’’ self.index = self.pictures.index(self.file) self.index -= 1 if self.index >= 0: self.checkout_button() self.file = self.pictures[self.index] self.create_canvas(self.file) else: self.index = 0 tkinter.messagebox.showinfo(’提示’, ’已經(jīng)是第一張了’) def show_picture(self): ’’’展示圖片和翻頁按鈕’’’ self.file = self.pictures[0] if self.is_show: self.is_show = False self.create_canvas(self.file) button1 = tk.Button(self.frame_ll, text=’上一張’, width=10, height=1, command=self.pre_picture) button1.pack() button2 = tk.Button(self.frame_rr, text=’下一張’, width=10, height=1, command=self.next_picture) button2.pack() self.button_list.append(button1) self.button_list.append(button2) self.object_list.extend(self.button_list) else: self.is_show = True while self.object_list:o = self.object_list.pop()o.destroy() def new_button(self): ’’’創(chuàng)建展示按鈕’’’ tk.Button(self.frame_l, text=’圖片展示’, width=10, height=1, command=self.show_picture).pack() def create_canvas(self,file): ’’’用畫布展示圖片’’’ self.image_file = tk.PhotoImage(file=file) canvas = tk.Canvas(self.frame_r, height=500, width=600) canvas.create_image(1, 1, anchor=’nw’, image=self.image_file) canvas.pack() self.object_list.append(canvas) def run(self): ’’’主程序調(diào)用’’’ self.window.mainloop()if __name__ == ’__main__’: w = Window() w.new_button() w.run()
樣式如下:有點丑,不過功能沒毛病,就先這么著吧~~~

點擊圖片展示之后

上一頁下一頁可以用,再次點擊圖片展示

總結(jié)
到此這篇關(guān)于python tkiner實現(xiàn) 一個小小的圖片翻頁功能的文章就介紹到這了,更多相關(guān)python tkiner實現(xiàn)圖片翻頁內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. Android table布局開發(fā)實現(xiàn)簡單計算器2. 理解PHP5中static和const關(guān)鍵字3. jQuery 實現(xiàn)DOM元素拖拽交換位置的實例代碼4. php模擬實現(xiàn)斗地主發(fā)牌5. IntelliJ IDEA安裝插件的方法步驟6. phpstorm恢復(fù)默認(rèn)設(shè)置的方法步驟7. Vue封裝一個TodoList的案例與瀏覽器本地緩存的應(yīng)用實現(xiàn)8. Python random庫使用方法及異常處理方案9. Vuex localStorage的具體使用10. .Net Core使用Coravel實現(xiàn)任務(wù)調(diào)度的完整步驟

網(wǎng)公網(wǎng)安備