You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

main.py 26KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579
  1. """
  2. Abhängigkeiten:
  3. - tkinter (Tkinter-Bibliothek)
  4. - recording (Modul für die Videoaufnahme)
  5. - processing (Modul für die Videoverarbeitung)
  6. - tkinter.filedialog (Dateiauswahldialog)
  7. - os
  8. Autor: Roberto Gelsinger
  9. Datum: 07.12.2023
  10. Version: Modulversion
  11. """
  12. import tkinter as tk
  13. from recording import start_recording, recording_finished_event
  14. from recording import start_recording,start_normal_recording,stop_normal_recording
  15. from processing import process_video
  16. from tkinter import filedialog
  17. from tkinter import simpledialog
  18. import os
  19. from PIL import ImageTk, Image
  20. import pandas as pd
  21. from excel_processing import process_all_videos_and_save_results
  22. from datetime import datetime
  23. recording_finished = False
  24. code_version= "1.0"
  25. #minimum_calculation_intervall is in seconds (10 is Currently a placeholder real values should be selected after testing)
  26. minimum_calculation_intervall = 2
  27. current_dir = os.getcwd()
  28. testcase_excel_file_path = os.path.join(current_dir, 'testing/excel/Testcase_excel_dataset.xlsx')
  29. testruns_excel_file_path = os.path.join(current_dir, 'testing/excel/Testruns.xlsx')
  30. class VideoProcessingApp(tk.Tk):
  31. def __init__(self):
  32. super().__init__()
  33. self.title("Driving Simulator EVM")
  34. self.geometry('530x380')
  35. #self.resizable(False, False)
  36. self.frames = {}
  37. #init user interface()
  38. self.initialize_header_frame()
  39. self.initialize_toolbar()
  40. self.initialize_icon()
  41. self.setup_recording_controls()
  42. self.setup_testcase_controls()
  43. self.setup_testing_controls()
  44. self.setup_video_processing_controls()
  45. self.center_window()
  46. self.selected_button = None
  47. self.check_recording_status()
  48. self.mainloop()
  49. def open_testcase_excel_file(self):
  50. os.startfile(testcase_excel_file_path)
  51. def open_testrun_excel_file(self):
  52. os.startfile(testruns_excel_file_path)
  53. def test_data_set(self):
  54. kommentar = self.testrun_kommentar_entry.get("1.0", "end-1c")
  55. process_all_videos_and_save_results(testcase_excel_file_path,testruns_excel_file_path,code_version,kommentar)
  56. def start_normal_recording_with_input(self):
  57. """
  58. Startet die Videoaufnahme mit dem eingegebenen Videonamen.
  59. Der Name wird aus dem Tkinter Entry-Widget gelesen.
  60. """
  61. video_name = self.video_name_entry.get() # Holt den Text aus dem Textfeld
  62. video_resolution1 = int(self.aufnahme_aufloesung1_entry.get())
  63. video_resolution2 = int(self.aufnahme_aufloesung2_entry.get())
  64. fps = int(self.aufnahme_fps_entry.get())
  65. start_normal_recording(video_name,video_resolution1,video_resolution2,fps)
  66. def write_to_excel(self, video_name, excel_path):
  67. # Datenerfassung
  68. date = datetime.now().strftime("%Y-%m-%d")
  69. time = datetime.now().strftime("%H:%M:%S")
  70. licht = self.testcase_licht_entry.get()
  71. webcam_name = self.testcase_kamera_entry.get()
  72. testperson_name = self.testcase_testperson_entry.get()
  73. abstand = int(self.testcase_abstand_entry.get())
  74. winkel = self.testcase_winkel_entry.get()
  75. hintergrund = self.testcase_hintergrund_entry.get()
  76. video_length = int(self.video_length_entry.get())
  77. auflösung = f"{int(self.testcase_resolution1_entry.get())}x{int(self.testcase_resolution2_entry.get())}"
  78. fps = int(self.testcase_fps_entry.get())
  79. kommentar = self.testcase_kommentar_entry.get("1.0", "end-1c")
  80. # Entferne die Dateiendung (z.B. '.avi') und extrahiere dann den Puls
  81. video_name_without_extension = video_name.split('.')[0]
  82. puls_part = video_name_without_extension.split('_')[-1]
  83. try:
  84. puls = int(puls_part)
  85. except ValueError:
  86. puls = '' # Setze Puls auf einen leeren String, falls keine gültige Zahl gefunden wird
  87. # Versuche, die vorhandene Datei zu lesen, erstelle eine neue, wenn sie nicht existiert
  88. try:
  89. existing_df = pd.read_excel(excel_path)
  90. except FileNotFoundError:
  91. existing_df = pd.DataFrame(columns=['Testcase','Date', 'Time', 'VideoName', 'CodeVersion', 'Testperson',
  92. 'Abstand', 'Videolänge', 'Webcam', 'Auflösung', 'FPS',
  93. 'Winkel', 'Hintergrund', 'Licht', 'Puls', 'Kommentar'])
  94. # Neue Datenreihe erstellen
  95. next_testcase_index = len(existing_df) + 1
  96. new_data = pd.DataFrame({'Testcase': [next_testcase_index],'Date': [date], 'Time': [time], 'VideoName': [video_name],
  97. 'CodeVersion': [code_version], 'Testperson': [testperson_name],
  98. 'Abstand': [abstand], 'Videolänge': [video_length], 'Webcam': [webcam_name],
  99. 'Auflösung': [auflösung], 'FPS': [fps], 'Winkel': [winkel],
  100. 'Hintergrund': [hintergrund], 'Licht': [licht], 'Puls': [puls],
  101. 'Kommentar': [kommentar]})
  102. # Daten zur existierenden DataFrame hinzufügen
  103. updated_df = existing_df._append(new_data, ignore_index=True)
  104. # DataFrame in Excel schreiben
  105. if not existing_df.empty:
  106. # Modus 'a' (Anhängen) verwenden, wenn die DataFrame nicht leer ist
  107. with pd.ExcelWriter(excel_path, engine='openpyxl', mode='a', if_sheet_exists='replace') as writer:
  108. updated_df.to_excel(writer, index=False, sheet_name='Sheet1')
  109. else:
  110. # Modus 'w' (Schreiben) verwenden, wenn die DataFrame leer ist oder die Datei nicht existiert
  111. with pd.ExcelWriter(excel_path, engine='openpyxl', mode='w') as writer:
  112. updated_df.to_excel(writer, index=False, sheet_name='Sheet1')
  113. def start_recording_with_input(self):
  114. """
  115. Startet die Videoaufnahme mit dem eingegebenen Videonamen.
  116. Der Name wird aus dem Tkinter Entry-Widget gelesen.
  117. """
  118. video_name = self.testcase_name_entry.get()
  119. video_length = int(self.video_length_entry.get()) # Hole die Länge des Videos
  120. testcase_resolution1 = int(self.testcase_resolution1_entry.get())
  121. testcase_resolution2 = int(self.testcase_resolution2_entry.get())
  122. testcase_fps=int(self.testcase_fps_entry.get())
  123. start_recording(video_name, video_length,testcase_resolution1,testcase_resolution2,testcase_fps)
  124. def select_video(self):
  125. """
  126. Öffnet einen Dateidialog zum Auswählen eines Videos und setzt den Namen des ausgewählten Videos
  127. in das Tkinter Entry-Widget für die Videoverarbeitung.
  128. """
  129. selected_video_path = filedialog.askopenfilename() # Den ausgewählten Videopfad abfragen
  130. if selected_video_path:
  131. selected_video_name = os.path.basename(selected_video_path) # Extrahieren Sie den Videonamen
  132. self.videoprocessing_name_entry.delete(0, tk.END) # Löschen Sie den aktuellen Text im Textfeld
  133. self.videoprocessing_name_entry.insert(0, selected_video_name) # Fügen Sie den Videonamen ein
  134. def process_selected_video(self):
  135. """
  136. Verarbeitet das ausgewählte Video, dessen Name aus dem Tkinter Entry-Widget gelesen wird.
  137. """
  138. selected_video_name = self.videoprocessing_name_entry.get()
  139. # Den ausgewählten Videonamen abfragen
  140. if selected_video_name:
  141. process_video(selected_video_name)
  142. def check_recording_status(self):
  143. excel_file_path = 'testing/excel/Testcase_excel_dataset.xlsx'
  144. global recording_finished # Deklarieren Sie die Verwendung der globalen Variable
  145. if recording_finished_event.is_set():
  146. recording_finished_event.clear()
  147. video_name = self.testcase_name_entry.get()
  148. length = int(self.video_length_entry.get()) # Hole die Länge des Videos
  149. pulse = simpledialog.askinteger("Puls", "Bitte geben Sie Ihren Puls ein:")
  150. if pulse is not None:
  151. new_video_name = f"{video_name}_{length}_{pulse}.avi"
  152. original_video_path = os.path.join('videos', f"{video_name}.avi")
  153. new_video_path = os.path.join('videos', new_video_name)
  154. os.rename(original_video_path, new_video_path)
  155. print(f"Video umbenannt zu {new_video_name}")
  156. self.write_to_excel(new_video_name, excel_file_path)
  157. else:
  158. print("recording_finished ist False, warte auf Aufnahmeende")
  159. print("Kein Puls eingegeben.")
  160. # Planen Sie die nächste Überprüfung
  161. self.after(100, self.check_recording_status)
  162. #ui relateted methods
  163. def center_window(self):
  164. # Aktualisieren der "idle" Aufgaben um die Größe korrekt zu erhalten
  165. self.update_idletasks()
  166. # Berechnen der Breite und Höhe für das Zentrieren des Fensters
  167. window_width = self.winfo_width()
  168. window_height = self.winfo_height()
  169. # Finden der Mitte des Bildschirms
  170. screen_width = self.winfo_screenwidth()
  171. screen_height = self.winfo_screenheight()
  172. # Berechnen der x und y Koordinaten, um das Fenster in der Mitte des Bildschirms zu positionieren
  173. x_coordinate = int((screen_width / 2) - (window_width / 2))
  174. y_coordinate = int((screen_height / 2) - (window_height / 2))
  175. self.geometry(f"{window_width}x{window_height}+{x_coordinate}+{y_coordinate}")
  176. #displaying selected frame
  177. def show_frame(self, frame_name):
  178. # Verstecke alle Frames und setze die Button-Farben zurück Create Testcase
  179. for name, fr in self.frames.items():
  180. fr.pack_forget()
  181. if name == "Recording":
  182. self.btn_recording.configure(bg='white',fg='black', relief=tk.RAISED)
  183. elif name == "Processing":
  184. self.btn_processing.configure(bg='white',fg='black', relief=tk.RAISED)
  185. elif name == "Testing":
  186. self.btn_testing.configure(bg='white',fg='black', relief=tk.RAISED)
  187. elif name == "Create Testcase":
  188. self.btn_testcase.configure(bg='white',fg='black', relief=tk.RAISED)
  189. # Zeige den ausgewählten Frame
  190. frame = self.frames[frame_name]
  191. frame.pack(fill="both", expand=True)
  192. # Hebe den entsprechenden Button hervor
  193. if frame_name == "Recording":
  194. self.btn_recording.configure(bg='#c82423',fg='white', relief=tk.SUNKEN)
  195. elif frame_name == "Processing":
  196. self.btn_processing.configure(bg='#c82423',fg='white', relief=tk.SUNKEN)
  197. elif frame_name == "Testing":
  198. self.btn_testing.configure(bg='#c82423',fg='white', relief=tk.SUNKEN)
  199. elif frame_name == "Create Testcase":
  200. self.btn_testcase.configure(bg='#c82423',fg='white', relief=tk.SUNKEN)
  201. def initialize_header_frame(self):
  202. # Header-Frame für App-Name und Icon
  203. header_frame = tk.Frame(self, bd=1, relief=tk.RAISED, bg='white')
  204. header_frame.pack(side=tk.TOP, fill=tk.X)
  205. # App-Name Label
  206. self.app_name_label = tk.Label(header_frame, text="Driving Simulator-EVM", font=('Helvetica', 28, 'bold'), bg='white', fg='red')
  207. self.app_name_label.pack(side=tk.LEFT, padx=10)
  208. self.app_name_label.config(fg="#c82423", bg="#FFFFFF")
  209. # Laden Sie das Bild mit PIL und konvertieren Sie es in ein Format, das Tkinter verwenden kann
  210. self.image = Image.open("code\Interface\ohmbild2.png")
  211. self.resized_image = self.image.resize((50, 30), Image.LANCZOS)
  212. self.photo = ImageTk.PhotoImage(self.resized_image)
  213. # Erstellen Sie ein Label-Widget, um das Bild anzuzeigen
  214. self.picture = tk.Label(self, image=self.photo)
  215. self.picture.place(x=445, y=0)
  216. self.picture.config(bg="#FFFFFF")
  217. def initialize_toolbar(self):
  218. toolbar = tk.Frame(self, bd=1, relief=tk.RAISED, bg='white')
  219. toolbar.pack(side=tk.TOP, fill=tk.X)
  220. self.btn_recording = tk.Button(toolbar, text="Recording", bg='white', command=lambda: self.show_frame("Recording"))
  221. self.btn_recording.pack(side=tk.LEFT, padx=2, pady=2)
  222. self.btn_processing = tk.Button(toolbar, text="Processing", bg='white', command=lambda: self.show_frame("Processing"))
  223. self.btn_processing.pack(side=tk.LEFT, padx=2, pady=2)
  224. self.btn_testcase = tk.Button(toolbar, text="Create Testcase", bg='white', command=lambda: self.show_frame("Create Testcase"))
  225. self.btn_testcase.pack(side=tk.LEFT, padx=3, pady=3)
  226. self.btn_testing = tk.Button(toolbar, text="Testing", bg='white', command=lambda: self.show_frame("Testing"))
  227. self.btn_testing.pack(side=tk.LEFT, padx=3, pady=3)
  228. def setup_recording_controls(self):
  229. self.recording_frame = tk.Frame(self)
  230. self.recording_frame.configure(bg='white')
  231. self.frames["Recording"] = self.recording_frame
  232. # mainlabel for recording
  233. self.recording_main_label = tk.Label(self.recording_frame, text="Recording", font=("Helvetica", 20))
  234. self.recording_main_label.place(x=25, y=10)
  235. self.recording_main_label.config(bg="#FFFFFF")
  236. self.video_name_entry_label = tk.Label(self.recording_frame, text="Videoname(Output)", font=("Helvetica", 10))
  237. self.video_name_entry_label.place(x=25, y=60)
  238. self.video_name_entry_label.config(bg="#FFFFFF")
  239. self.video_name_entry = tk.Entry(self.recording_frame)
  240. self.video_name_entry.place(x=25, y=85)
  241. self.video_name_entry.config(bg="#FFFFFF")
  242. self.aufnahme_entry_label = tk.Label(self.recording_frame, text="Auflösung,FPS", font=("Helvetica", 10))
  243. self.aufnahme_entry_label.place(x=25, y=110)
  244. self.aufnahme_entry_label.config(bg="#FFFFFF")
  245. self.aufnahme_aufloesung1_entry = tk.Entry(self.recording_frame)
  246. self.aufnahme_aufloesung1_entry.place(x=25, y=140)
  247. self.aufnahme_aufloesung1_entry.config(bg="#FFFFFF", width=5)
  248. self.aufnahme_aufloesung1_entry.insert(0, 2560)
  249. self.aufnahme_aufloesung_x_entry_label = tk.Label(self.recording_frame, text="x", font=("Helvetica", 8))
  250. self.aufnahme_aufloesung_x_entry_label.place(x=60, y=140)
  251. self.aufnahme_aufloesung_x_entry_label.config(bg="#FFFFFF")
  252. self.aufnahme_aufloesung2_entry = tk.Entry(self.recording_frame)
  253. self.aufnahme_aufloesung2_entry.place(x=72, y=140)
  254. self.aufnahme_aufloesung2_entry.config(bg="#FFFFFF", width=5)
  255. self.aufnahme_aufloesung2_entry.insert(0, 1440)
  256. self.aufnahme_aufloesung_komma_entry_label = tk.Label(self.recording_frame, text=",", font=("Helvetica", 8))
  257. self.aufnahme_aufloesung_komma_entry_label.place(x=105, y=140)
  258. self.aufnahme_aufloesung_komma_entry_label.config(bg="#FFFFFF")
  259. self.aufnahme_fps_entry = tk.Entry(self.recording_frame)
  260. self.aufnahme_fps_entry.place(x=115, y=140)
  261. self.aufnahme_fps_entry.config(bg="#FFFFFF", width=4)
  262. self.aufnahme_fps_entry.insert(0, 20)
  263. # Buttons
  264. self.start_button = tk.Button(self.recording_frame, text="Aufnahme starten", command=self.start_normal_recording_with_input)
  265. self.start_button.place(x=25, y=175)
  266. self.start_button.config(bg="#c82423", fg="#FFFFFF")
  267. self.stop_button = tk.Button(self.recording_frame, text="Aufnahme stoppen", command=stop_normal_recording)
  268. self.stop_button.place(x=25, y=210)
  269. self.stop_button.config(bg="#c82423", fg="#FFFFFF")
  270. def setup_video_processing_controls(self):
  271. self.processing_frame = tk.Frame(self)
  272. self.processing_frame.configure(bg='white')
  273. self.frames["Processing"] = self.processing_frame
  274. # mainlabel for processing
  275. self.processing_main_label = tk.Label(self.processing_frame, text="Processing", font=("Helvetica", 20))
  276. self.processing_main_label.place(x=10, y=10)
  277. self.processing_main_label.config(bg="#FFFFFF")
  278. self.videoprocessing_name_entry_label = tk.Label(self.processing_frame, text="Videoname(Loaded)", font=("Helvetica", 10))
  279. self.videoprocessing_name_entry_label.place(x=10, y=60)
  280. self.videoprocessing_name_entry_label.config(bg="#FFFFFF")
  281. self.videoprocessing_name_entry = tk.Entry(self.processing_frame)
  282. self.videoprocessing_name_entry.place(x=10, y=85)
  283. self.videoprocessing_name_entry.config(bg="#FFFFFF")
  284. # Button to select video for processing
  285. self.select_video_button = tk.Button(self.processing_frame, text="Video auswählen", command=self.select_video)
  286. self.select_video_button.place(x=10, y=120)
  287. self.select_video_button.config(bg="#c82423", fg="#FFFFFF")
  288. # Button to start processing
  289. self.processing_button = tk.Button(self.processing_frame, text="Verarbeiten", command=self.process_selected_video)
  290. self.processing_button.place(x=10, y=160)
  291. self.processing_button.config(bg="#c82423", fg="#FFFFFF")
  292. # Checkbox for Use Intervalls
  293. var1 = 10
  294. self.intervall_checkbox = tk.Checkbutton(self.processing_frame, text="Check to Process Intervalls instead of the full video",variable=var1, onvalue=1, offvalue=0)#set command
  295. self.intervall_checkbox.place(x=180,y=60)
  296. # Spinbox for selection of test Intervall in mins
  297. self.intervall_spinbox = tk.Spinbox(self.processing_frame, from_=1, to=10)
  298. self.intervall_spinbox.place(x=180,y=100)
  299. # Label for selection of test Intervall in mins
  300. self.intervall_spinbox_label = tk.Label(self.processing_frame, text="Selection of test every X mins")
  301. self.intervall_spinbox_label.place(x=340,y=100)
  302. # Spinbox for selection of test duration
  303. self.duration_spinbox = tk.Spinbox(self.processing_frame, from_=2, to=10)
  304. self.duration_spinbox.place(x=180,y=140)
  305. # Label for selection of test duration in s
  306. self.duration_spinbox_label = tk.Label(self.processing_frame, text="Selection of test Duration X in s")
  307. self.duration_spinbox_label.place(x=340,y=140)
  308. def setup_testcase_controls(self):
  309. self.testcase_frame = tk.Frame(self, bg='white')
  310. self.frames["Create Testcase"] = self.testcase_frame
  311. # mainlabel for Recording(Testcase)
  312. self.recording_testcase_label = tk.Label(self.testcase_frame, text="Record Testcase", font=("Helvetica", 20))
  313. self.recording_testcase_label.place(x=10, y=10)
  314. self.recording_testcase_label.config(bg="#FFFFFF")
  315. #kommentar
  316. self.testcase_kommentar_entry_label = tk.Label(self.testcase_frame, text="Kommentar", font=("Helvetica", 10))
  317. self.testcase_kommentar_entry_label.place(x=320, y=60)
  318. self.testcase_kommentar_entry_label.config(bg="#FFFFFF")
  319. self.testcase_kommentar_entry = tk.Text(self.testcase_frame, height=4.5, width=20)
  320. self.testcase_kommentar_entry.place(x=320, y=85)
  321. self.testcase_kommentar_entry.config(bg="#FFFFFF")
  322. #code version
  323. self.testcase_version_entry_label = tk.Label(self.testcase_frame, text="Version: "+code_version, font=("Helvetica", 10))
  324. self.testcase_version_entry_label.place(x=240, y=20)
  325. self.testcase_version_entry_label.config(bg="#FFFFFF")
  326. #licht
  327. self.testcase_licht_entry_label = tk.Label(self.testcase_frame, text="Licht", font=("Helvetica", 10))
  328. self.testcase_licht_entry_label.place(x=10, y=180)
  329. self.testcase_licht_entry_label.config(bg="#FFFFFF")
  330. self.testcase_licht_entry = tk.Entry(self.testcase_frame)
  331. self.testcase_licht_entry.place(x=10, y=205)
  332. self.testcase_licht_entry.config(bg="#FFFFFF")
  333. #kamera
  334. self.testcase_kamera_entry_label = tk.Label(self.testcase_frame, text="Webcam(Name)", font=("Helvetica", 10))
  335. self.testcase_kamera_entry_label.place(x=10, y=240)
  336. self.testcase_kamera_entry_label.config(bg="#FFFFFF")
  337. self.testcase_kamera_entry = tk.Entry(self.testcase_frame)
  338. self.testcase_kamera_entry.place(x=10, y=265)
  339. self.testcase_kamera_entry.config(bg="#FFFFFF")
  340. #testperson
  341. self.testcase_testperson_entry_label = tk.Label(self.testcase_frame, text="Testperson(Name)", font=("Helvetica", 10))
  342. self.testcase_testperson_entry_label.place(x=160, y=60)
  343. self.testcase_testperson_entry_label.config(bg="#FFFFFF")
  344. self.testcase_testperson_entry = tk.Entry(self.testcase_frame)
  345. self.testcase_testperson_entry.place(x=160, y=85)
  346. self.testcase_testperson_entry.config(bg="#FFFFFF")
  347. #abstand
  348. self.testcase_abstand_entry_label = tk.Label(self.testcase_frame, text="Abstand zur Kamera", font=("Helvetica", 10))
  349. self.testcase_abstand_entry_label.place(x=160, y=120)
  350. self.testcase_abstand_entry_label.config(bg="#FFFFFF")
  351. self.testcase_abstand_entry = tk.Entry(self.testcase_frame)
  352. self.testcase_abstand_entry.place(x=160, y=145)
  353. self.testcase_abstand_entry.config(bg="#FFFFFF")
  354. #Winkel
  355. self.testcase_winkel_entry_label = tk.Label(self.testcase_frame, text="Kamerawinkel", font=("Helvetica", 10))
  356. self.testcase_winkel_entry_label.place(x=160, y=180)
  357. self.testcase_winkel_entry_label.config(bg="#FFFFFF")
  358. self.testcase_winkel_entry = tk.Entry(self.testcase_frame)
  359. self.testcase_winkel_entry.place(x=160, y=205)
  360. self.testcase_winkel_entry.config(bg="#FFFFFF")
  361. #Hintergrund
  362. self.testcase_hintergrund_entry_label = tk.Label(self.testcase_frame, text="Hintergrund", font=("Helvetica", 10))
  363. self.testcase_hintergrund_entry_label.place(x=160, y=240)
  364. self.testcase_hintergrund_entry_label.config(bg="#FFFFFF")
  365. self.testcase_hintergrund_entry = tk.Entry(self.testcase_frame)
  366. self.testcase_hintergrund_entry.place(x=160, y=265)
  367. self.testcase_hintergrund_entry.config(bg="#FFFFFF")
  368. #videoname
  369. self.testcase_name_entry_label = tk.Label(self.testcase_frame, text="Videoname(Output)", font=("Helvetica", 10))
  370. self.testcase_name_entry_label.place(x=10, y=60)
  371. self.testcase_name_entry_label.config(bg="#FFFFFF")
  372. self.testcase_name_entry = tk.Entry(self.testcase_frame)
  373. self.testcase_name_entry.place(x=10, y=85)
  374. self.testcase_name_entry.config(bg="#FFFFFF")
  375. #videolänge
  376. self.video_length_entry_label = tk.Label(self.testcase_frame, text="Videolänge (Sek.)", font=("Helvetica", 10))
  377. self.video_length_entry_label.place(x=10, y=120)
  378. self.video_length_entry_label.config(bg="#FFFFFF")
  379. self.video_length_entry = tk.Entry(self.testcase_frame)
  380. self.video_length_entry.place(x=10, y=145)
  381. self.video_length_entry.config(bg="#FFFFFF")
  382. #auflösung und fps
  383. self.testcase_resolution_label = tk.Label(self.testcase_frame, text="Auflösung,FPS", font=("Helvetica", 10))
  384. self.testcase_resolution_label.place(x=320, y=180)
  385. self.testcase_resolution_label.config(bg="#FFFFFF")
  386. self.testcase_resolution1_entry = tk.Entry(self.testcase_frame)
  387. self.testcase_resolution1_entry.place(x=320, y=205)
  388. self.testcase_resolution1_entry.config(bg="#FFFFFF", width=5)
  389. self.testcase_resolution1_entry.insert(0, 2560)
  390. self.resolution_x_label = tk.Label(self.testcase_frame, text="x", font=("Helvetica", 8))
  391. self.resolution_x_label.place(x=365, y=205)
  392. self.resolution_x_label.config(bg="#FFFFFF")
  393. self.testcase_resolution2_entry = tk.Entry(self.testcase_frame)
  394. self.testcase_resolution2_entry.place(x=377, y=205)
  395. self.testcase_resolution2_entry.config(bg="#FFFFFF", width=5)
  396. self.testcase_resolution2_entry.insert(0, 1440)
  397. self.resolution_comma_label = tk.Label(self.testcase_frame, text=",", font=("Helvetica", 8))
  398. self.resolution_comma_label.place(x=410, y=205)
  399. self.resolution_comma_label.config(bg="#FFFFFF")
  400. self.testcase_fps_entry = tk.Entry(self.testcase_frame)
  401. self.testcase_fps_entry.place(x=420, y=205)
  402. self.testcase_fps_entry.config(bg="#FFFFFF", width=4)
  403. self.testcase_fps_entry.insert(0, 20)
  404. # Button to start testcase recording
  405. self.create_testcase_button = tk.Button(self.testcase_frame, text="Testcase aufnehmen", command=self.start_recording_with_input)
  406. self.create_testcase_button.place(x=320, y=240)
  407. self.create_testcase_button.config(bg="#c82423", fg="#FFFFFF")
  408. def setup_testing_controls(self):
  409. self.testing_frame = tk.Frame(self, bg='white')
  410. self.frames["Testing"] = self.testing_frame
  411. #kommentar
  412. self.testrun_kommentar_entry_label = tk.Label(self.testing_frame, text="Kommentar", font=("Helvetica", 10))
  413. self.testrun_kommentar_entry_label.place(x=10, y=60)
  414. self.testrun_kommentar_entry_label.config(bg="#FFFFFF")
  415. self.testrun_kommentar_entry = tk.Text(self.testing_frame, height=4.5, width=20)
  416. self.testrun_kommentar_entry.place(x=10, y=85)
  417. self.testrun_kommentar_entry.config(bg="#FFFFFF")
  418. # mainlabel for testing
  419. self.testing_main_label = tk.Label(self.testing_frame, text="Testing", font=("Helvetica", 20))
  420. self.testing_main_label.place(x=10, y=10)
  421. self.testing_main_label.config(bg="#FFFFFF")
  422. # Button to start test
  423. self.test_button = tk.Button(self.testing_frame, text="Test durchführen", command=self.test_data_set)
  424. self.test_button.place(x=350, y=60)
  425. self.test_button.config(bg="#c82423", fg="#FFFFFF")
  426. # Button open testcase excel
  427. self.open_testcase_button = tk.Button(self.testing_frame, text="Open Testcase Excel", command=self.open_testcase_excel_file)
  428. self.open_testcase_button.place(x=10, y=200)
  429. self.open_testcase_button.config(bg="#c82423", fg="#FFFFFF")
  430. # Button open testrun excel
  431. self.open_testrun_button = tk.Button(self.testing_frame, text="Open Testrun Excel", command=self.open_testrun_excel_file)
  432. self.open_testrun_button.place(x=10, y=235)
  433. self.open_testrun_button.config(bg="#c82423", fg="#FFFFFF")
  434. def initialize_icon(self):
  435. # Icon ändern
  436. self.iconbitmap('code\Interface\ohm.ico')
  437. # Ändert die Hintergrundfarbe
  438. self.configure(bg="#FFFFFF")
  439. def main():
  440. app = VideoProcessingApp()
  441. app.mainloop()
  442. if __name__ == "__main__":
  443. main()