-
Notifications
You must be signed in to change notification settings - Fork 244
/
Copy pathmainGUI.py
130 lines (100 loc) · 5.41 KB
/
mainGUI.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
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
import os
from tkinter import filedialog
import customtkinter as ctk
import pyautogui
import pygetwindow
from PIL import ImageTk, Image
from predictions import predict
# global variables
project_folder = os.path.dirname(os.path.abspath(__file__))
folder_path = project_folder + '/images/'
filename = ""
class App(ctk.CTk):
def __init__(self):
super().__init__()
self.title("Bone Fracture Detection")
self.geometry(f"{500}x{740}")
self.head_frame = ctk.CTkFrame(master=self)
self.head_frame.pack(pady=20, padx=60, fill="both", expand=True)
self.main_frame = ctk.CTkFrame(master=self)
self.main_frame.pack(pady=20, padx=60, fill="both", expand=True)
self.head_label = ctk.CTkLabel(master=self.head_frame, text="Bone Fracture Detection",
font=(ctk.CTkFont("Roboto"), 28))
self.head_label.pack(pady=20, padx=10, anchor="nw", side="left")
img1 = ctk.CTkImage(Image.open(folder_path + "info.png"))
self.img_label = ctk.CTkButton(master=self.head_frame, text="", image=img1, command=self.open_image_window,
width=40, height=40)
self.img_label.pack(pady=10, padx=10, anchor="nw", side="right")
self.info_label = ctk.CTkLabel(master=self.main_frame,
text="Bone fracture detection system, upload an x-ray image for fracture detection.",
wraplength=300, font=(ctk.CTkFont("Roboto"), 18))
self.info_label.pack(pady=10, padx=10)
self.upload_btn = ctk.CTkButton(master=self.main_frame, text="Upload Image", command=self.upload_image)
self.upload_btn.pack(pady=0, padx=1)
self.frame2 = ctk.CTkFrame(master=self.main_frame, fg_color="transparent", width=256, height=256)
self.frame2.pack(pady=10, padx=1)
img = Image.open(folder_path + "Question_Mark.jpg")
img_resized = img.resize((int(256 / img.height * img.width), 256)) # new width & height
img = ImageTk.PhotoImage(img_resized)
self.img_label = ctk.CTkLabel(master=self.frame2, text="", image=img)
self.img_label.pack(pady=1, padx=10)
self.predict_btn = ctk.CTkButton(master=self.main_frame, text="Predict", command=self.predict_gui)
self.predict_btn.pack(pady=0, padx=1)
self.result_frame = ctk.CTkFrame(master=self.main_frame, fg_color="transparent", width=200, height=100)
self.result_frame.pack(pady=5, padx=5)
self.loader_label = ctk.CTkLabel(master=self.main_frame, width=100, height=100, text="")
self.loader_label.pack(pady=3, padx=3)
self.res1_label = ctk.CTkLabel(master=self.result_frame, text="")
self.res1_label.pack(pady=5, padx=20)
self.res2_label = ctk.CTkLabel(master=self.result_frame, text="")
self.res2_label.pack(pady=5, padx=20)
self.save_btn = ctk.CTkButton(master=self.result_frame, text="Save Result", command=self.save_result)
self.save_label = ctk.CTkLabel(master=self.result_frame, text="")
def upload_image(self):
global filename
f_types = [("All Files", "*.*")]
filename = filedialog.askopenfilename(filetypes=f_types, initialdir=project_folder+'/test/Wrist/')
self.save_label.configure(text="")
self.res2_label.configure(text="")
self.res1_label.configure(text="")
self.img_label.configure(self.frame2, text="", image="")
img = Image.open(filename)
img_resized = img.resize((int(256 / img.height * img.width), 256)) # new width & height
img = ImageTk.PhotoImage(img_resized)
self.img_label.configure(self.frame2, image=img, text="")
self.img_label.image = img
self.save_btn.pack_forget()
self.save_label.pack_forget()
def predict_gui(self):
global filename
bone_type_result = predict(filename)
result = predict(filename, bone_type_result)
print(result)
if result == 'fractured':
self.res2_label.configure(text_color="RED", text="Result: Fractured", font=(ctk.CTkFont("Roboto"), 24))
else:
self.res2_label.configure(text_color="GREEN", text="Result: Normal", font=(ctk.CTkFont("Roboto"), 24))
bone_type_result = predict(filename, "Parts")
self.res1_label.configure(text="Type: " + bone_type_result, font=(ctk.CTkFont("Roboto"), 24))
print(bone_type_result)
self.save_btn.pack(pady=10, padx=1)
self.save_label.pack(pady=5, padx=20)
def save_result(self):
tempdir = filedialog.asksaveasfilename(parent=self, initialdir=project_folder + '/PredictResults/',
title='Please select a directory and filename', defaultextension=".png")
screenshots_dir = tempdir
window = pygetwindow.getWindowsWithTitle('Bone Fracture Detection')[0]
left, top = window.topleft
right, bottom = window.bottomright
pyautogui.screenshot(screenshots_dir)
im = Image.open(screenshots_dir)
im = im.crop((left + 10, top + 35, right - 10, bottom - 10))
im.save(screenshots_dir)
self.save_label.configure(text_color="WHITE", text="Saved!", font=(ctk.CTkFont("Roboto"), 16))
def open_image_window(self):
im = Image.open(folder_path + "rules.jpeg")
im = im.resize((700, 700))
im.show()
if __name__ == "__main__":
app = App()
app.mainloop()