-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathimageManagement.py
114 lines (94 loc) · 4.45 KB
/
imageManagement.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
from tkinter import *
import tkinter
import os
from PIL import Image, ImageTk
from functools import partial
from tkinter import messagebox
fileName = ''
class imageMangement:
def __init__(self):
self.window = tkinter.Toplevel()
self.window.title('視窗') # 窗口标题
# window.resizable(False, False) # 固定視窗大小
self.windowWidth = 1600 # 視窗寬
self.windowHeight = 900 # 視窗高
self.screenWidth, screenHeight = self.window.maxsize() # 獲得螢幕寬和高
self.window.geometry("1300x680")
self.window.wm_attributes('-topmost', 1) # 視窗置頂
self.panel = tkinter.Frame(self.window)
self.deletebtn = tkinter.Button(self.panel, text="刪除", command=self.deleteImgage, width=20, height=10,
bg="pink", fg="white", font="30")
self.chosebtn = tkinter.Button(self.panel, text="選擇", command=self.chose, width=20, height=10,
bg="pink", fg="white", font="30")
self.name = StringVar(value='None')
self.lab = tkinter.Label(self.window, textvariable=self.name)
self.lab.grid(column=1, row=2)
self.panel.grid(column=1, row=3)
self.deletebtn.grid(column=0, row=0)
self.chosebtn.grid(column=1, row=0)
self.show_canvas()
self.x_place = 450
self.y_place = 0
self.show_Thumbnail()
# self.window.mainloop()
# 空畫布
def show_canvas(self):
self.preview = ImageTk.PhotoImage(file="noimagefile.jpg")
self.preview_canvas = tkinter.Canvas(self.window, width=self.preview.width(), height=self.preview.height())
self.preview_canvas.create_image(0, 0, image=self.preview, anchor=tkinter.NW)
# self.preview_canvas.delete("all") # 清空畫布
self.preview_canvas.grid(column=1, row=0)
# self.preview_canvas.pack(side=LEFT, padx=5, pady=5)
# 點擊縮圖顯示圖片
def show_Image(self, n):
self.pil_image = Image.open(n)
self.w, self.h = self.pil_image.size # 獲取圖片的原始大小
self.preview = ImageTk.PhotoImage(file="noimagefile.jpg") # 重新抓一次大小
self.pil_image_resized = self.resize(self.w, self.h, self.preview.width(),
self.preview.height()) # 縮放圖片讓它保持比例,同時限制在一個矩形框範圍內
self.preview = ImageTk.PhotoImage(self.pil_image_resized)
self.preview_canvas.create_image(0, 0, image=self.preview, anchor=tkinter.NW)
self.preview_canvas.grid(column=1, row=0)
n_split = n.split("/")
fileName = n_split[1]
self.name.set(n_split[1])
self.selectImgae = n
# 顯示縮圖
def show_Thumbnail(self):
self.w_box = 150
self.h_box = 100
self.tk_images = list()
imlist = os.listdir('./images')
for x in imlist:
if self.x_place > 1000:
self.x_place = 450
self.y_place = self.y_place + 100
self.x_place = self.x_place + 150
self.y_place = self.y_place + 0
self.fileName = "images/" + x
self.pil_image = Image.open(self.fileName)
self.w, self.h = self.pil_image.size # 獲取圖片的原始大小
self.pil_image_resized = self.resize(self.w, self.h, self.w_box, self.h_box) # 縮放圖片讓它保持比例,同時限制在一個矩形框範圍內
self.tk_images.append(ImageTk.PhotoImage(self.pil_image_resized))
self.img = tkinter.Button(self.window, image=self.tk_images[imlist.index(x)], width=self.w_box,
height=self.h_box, command=partial(self.show_Image, self.fileName), bd=0)
self.img.place(x=self.x_place, y=self.y_place)
# self.window.mainloop()
def resize(self, w, h, w_box, h_box):
self.f1 = 1.0 * w_box / w
self.f2 = 1.0 * h_box / h
self.factor = min([self.f1, self.f2])
self.width = int(w * self.factor)
self.height = int(h * self.factor)
return self.pil_image.resize((self.width, self.height), Image.ANTIALIAS)
def deleteImgage(self):
os.remove(self.selectImgae)
self.x_place = 450
self.y_place = 0
self.show_Thumbnail()
def chose(self):
f = open("f", "w+")
f.write(self.name.get())
f.flush()
f.close()
self.window.destroy()