frontengine-dev 0.0.66__py3-none-any.whl → 0.0.68__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (30) hide show
  1. frontengine/gl_widget/__init__.py +0 -0
  2. frontengine/show/clicker/__init__.py +0 -0
  3. frontengine/show/clicker/clicker_scene.py +7 -0
  4. frontengine/show/clicker/clicker_ui.py +30 -0
  5. frontengine/show/particle/particle_scene.py +19 -13
  6. frontengine/show/particle/{paint_particle.py → particle_ui.py} +13 -19
  7. frontengine/show/particle/particle_utils.py +19 -33
  8. frontengine/show/video/video_player.py +1 -0
  9. frontengine/ui/main_ui.py +11 -20
  10. frontengine/ui/page/control_center/control_center_ui.py +5 -1
  11. frontengine/ui/page/gif/gif_setting_ui.py +9 -7
  12. frontengine/ui/page/image/image_setting_ui.py +12 -9
  13. frontengine/ui/page/particle/__init__.py +0 -0
  14. frontengine/ui/page/particle/particle_setting_ui.py +175 -0
  15. frontengine/ui/page/utils.py +14 -1
  16. frontengine/ui/page/video/video_setting_ui.py +9 -7
  17. frontengine/utils/multi_language/english.py +8 -0
  18. frontengine/utils/multi_language/france.py +8 -0
  19. frontengine/utils/multi_language/germany.py +8 -0
  20. frontengine/utils/multi_language/italy.py +8 -0
  21. frontengine/utils/multi_language/russian.py +8 -0
  22. frontengine/utils/multi_language/simplified_chinese.py +8 -0
  23. frontengine/utils/multi_language/traditional_chinese.py +8 -0
  24. frontengine/worker/__init__.py +0 -0
  25. frontengine/worker/qthread_worker.py +34 -0
  26. {frontengine_dev-0.0.66.dist-info → frontengine_dev-0.0.68.dist-info}/METADATA +1 -1
  27. {frontengine_dev-0.0.66.dist-info → frontengine_dev-0.0.68.dist-info}/RECORD +30 -22
  28. {frontengine_dev-0.0.66.dist-info → frontengine_dev-0.0.68.dist-info}/LICENSE +0 -0
  29. {frontengine_dev-0.0.66.dist-info → frontengine_dev-0.0.68.dist-info}/WHEEL +0 -0
  30. {frontengine_dev-0.0.66.dist-info → frontengine_dev-0.0.68.dist-info}/top_level.txt +0 -0
File without changes
File without changes
@@ -0,0 +1,7 @@
1
+ from PySide6.QtWidgets import QGraphicsScene
2
+
3
+
4
+ class ClickerGraphicScene(QGraphicsScene):
5
+
6
+ def __init__(self):
7
+ super().__init__()
@@ -0,0 +1,30 @@
1
+ from PySide6.QtCore import Qt
2
+ from PySide6.QtWidgets import QWidget, QGridLayout
3
+
4
+ from frontengine.show.clicker.clicker_scene import ClickerGraphicScene
5
+ from frontengine.show.scene.extend_graphic_view import ExtendGraphicView
6
+
7
+
8
+ class ClickerWidget(QWidget):
9
+
10
+ def __init__(self):
11
+ super().__init__()
12
+ self.setAttribute(Qt.WidgetAttribute.WA_TranslucentBackground)
13
+ self.setAttribute(Qt.WidgetAttribute.WA_DeleteOnClose)
14
+ self.clicker_view = ExtendGraphicView()
15
+ self.clicker_scene = ClickerGraphicScene()
16
+ self.clicker_view.setScene(self.clicker_scene)
17
+ self.grid_layout = QGridLayout()
18
+ self.grid_layout.addWidget(self.clicker_view, 0, 0, -1, -1)
19
+ self.setLayout(self.grid_layout)
20
+
21
+ def set_ui_window_flag(self, show_on_bottom: bool = False) -> None:
22
+ self.setWindowFlag(
23
+ Qt.WindowType.WindowTransparentForInput |
24
+ Qt.WindowType.FramelessWindowHint |
25
+ Qt.WindowType.Tool
26
+ )
27
+ if not show_on_bottom:
28
+ self.setWindowFlag(Qt.WindowType.WindowStaysOnTopHint)
29
+ else:
30
+ self.setWindowFlag(Qt.WindowType.WindowStaysOnBottomHint)
@@ -1,11 +1,12 @@
1
+ import random
1
2
  from typing import Callable
2
3
 
3
4
  from PySide6.QtCore import QTimer, QPoint, QRect
4
5
  from PySide6.QtGui import QPixmap
5
- from PySide6.QtWidgets import QGraphicsScene, QWidget
6
+ from PySide6.QtWidgets import QGraphicsScene
6
7
 
7
8
  from frontengine.show.particle.particle_utils import particle_down, particle_up, particle_left, particle_right, \
8
- particle_left_down, particle_left_up, particle_right_down, particle_right_up, particle_random_minus, Particle, \
9
+ particle_left_down, particle_left_up, particle_right_down, particle_right_up, particle_random_minus, \
9
10
  particle_random_add, particle_random
10
11
 
11
12
 
@@ -40,26 +41,31 @@ class ParticleGraphicScene(QGraphicsScene):
40
41
  }.get(self.particle_direction)
41
42
  self.setSceneRect(QRect(0, 0, screen_width, screen_height))
42
43
  self.update_timer: QTimer = QTimer()
43
- self.update_timer.setInterval(10)
44
- self.update_timer.timeout.connect(self.update_particle)
44
+ self.update_timer.setInterval(100)
45
+ self.update_timer.timeout.connect(self.update_particle_xy)
45
46
  self.update_timer.start()
46
47
 
47
48
  def create_particle(self):
48
49
  self.particle_dict = {}
49
50
  for count in range(self.particle_count):
51
+ item = self.addPixmap(self.particle_pixmap)
52
+ item.setOpacity(self.opacity)
50
53
  self.particle_dict.update({
51
- f"particle_{count}": Particle(self.screen_height, self.screen_width, self.particle_pixmap)
54
+ f"particle_{count}": {
55
+ "x": random.randint(0, self.screen_width),
56
+ "y": random.randint(0, self.screen_height),
57
+ "height": self.screen_height,
58
+ "width": self.screen_width,
59
+ "pixmap_item": item,
60
+ }
52
61
  })
53
62
 
54
- def update_particle(self):
55
- self.clear()
63
+ def update_particle_xy(self):
56
64
  self.update_function(self.particle_dict, self.particle_speed)
57
65
  for particle_key, particle in self.particle_dict.items():
58
- pixmap_item = self.addPixmap(particle.pixmap)
59
- pixmap_item.setOpacity(self.opacity)
60
- pixmap_item.setPos(particle.x, particle.y)
61
- particle.pixmap_item = pixmap_item
62
- if not self.sceneRect().contains(QPoint(particle.x, particle.y)):
63
- self.removeItem(particle.pixmap_item)
66
+ pixmap_item = particle.get("pixmap_item")
67
+ pixmap_item.setPos(particle.get("x"), particle.get("y"))
68
+ if not self.sceneRect().contains(QPoint(particle.get("x"), particle.get("y"))):
69
+ self.removeItem(particle.get("pixmap_item"))
64
70
  if len(self.items()) == 0:
65
71
  self.create_particle()
@@ -1,9 +1,6 @@
1
- import sys
2
-
3
1
  from PySide6.QtCore import QSize
4
2
  from PySide6.QtGui import QPixmap, Qt
5
- from PySide6.QtWidgets import QWidget, QApplication, QMainWindow, QGridLayout
6
- from qt_material import QtStyleTools
3
+ from PySide6.QtWidgets import QWidget, QGridLayout
7
4
 
8
5
  from frontengine.show.particle.particle_scene import ParticleGraphicScene
9
6
  from frontengine.show.scene.extend_graphic_view import ExtendGraphicView
@@ -15,6 +12,8 @@ class ParticleWidget(QWidget):
15
12
  screen_height: int = 1080, screen_width: int = 1920, opacity: float = 0.2,
16
13
  particle_speed: int = 1):
17
14
  super().__init__()
15
+ self.setAttribute(Qt.WidgetAttribute.WA_TranslucentBackground)
16
+ self.setAttribute(Qt.WidgetAttribute.WA_DeleteOnClose)
18
17
  if particle_size:
19
18
  self.pixmap = pixmap.scaled(QSize(particle_size, particle_size), Qt.AspectRatioMode.KeepAspectRatio)
20
19
  else:
@@ -28,18 +27,13 @@ class ParticleWidget(QWidget):
28
27
  self.grid_layout.addWidget(self.particle_view, 0, 0, -1, -1)
29
28
  self.setLayout(self.grid_layout)
30
29
 
31
-
32
- class TestUI(QMainWindow, QtStyleTools):
33
-
34
- def __init__(self):
35
- super().__init__()
36
- self.pixmap = QPixmap("pipi.png")
37
- self.main_widget = ParticleWidget(self.pixmap, 64, "random_add", particle_count=500)
38
- self.setCentralWidget(self.main_widget)
39
- self.showMaximized()
40
-
41
-
42
- if __name__ == "__main__":
43
- main_app = QApplication(sys.argv)
44
- window = TestUI()
45
- sys.exit(main_app.exec())
30
+ def set_ui_window_flag(self, show_on_bottom: bool = False) -> None:
31
+ self.setWindowFlag(
32
+ Qt.WindowType.WindowTransparentForInput |
33
+ Qt.WindowType.FramelessWindowHint |
34
+ Qt.WindowType.Tool
35
+ )
36
+ if not show_on_bottom:
37
+ self.setWindowFlag(Qt.WindowType.WindowStaysOnTopHint)
38
+ else:
39
+ self.setWindowFlag(Qt.WindowType.WindowStaysOnBottomHint)
@@ -1,74 +1,60 @@
1
1
  import random
2
2
  from typing import Dict, Callable
3
3
 
4
- from PySide6.QtGui import QPixmap
5
- from PySide6.QtWidgets import QGraphicsPixmapItem
6
4
 
7
-
8
- class Particle(object):
9
-
10
- def __init__(self, height: int, width: int, pixmap: QPixmap):
11
- self.pixmap: QPixmap = pixmap
12
- self.x: int = random.randint(0, width)
13
- self.y: int = random.randint(0, height)
14
- self.height = self.pixmap.height()
15
- self.width = self.pixmap.width()
16
- self.pixmap_item: [QGraphicsPixmapItem, None] = None
17
-
18
-
19
- def particle_down(particle_dict: Dict[str, Particle], particle_speed: int = 30) -> None:
5
+ def particle_down(particle_dict: Dict[str, dict], particle_speed: int = 30) -> None:
20
6
  for particle in particle_dict.values():
21
- particle.y += random.randint(0, particle_speed)
7
+ particle.update({"y": particle.get("y") + random.randint(0, particle_speed)})
22
8
 
23
9
 
24
- def particle_up(particle_dict: Dict[str, Particle], particle_speed: int = 30) -> None:
10
+ def particle_up(particle_dict: Dict[str, dict], particle_speed: int = 30) -> None:
25
11
  for particle in particle_dict.values():
26
- particle.y -= random.randint(0, particle_speed)
12
+ particle.update({"y": particle.get("y") - random.randint(0, particle_speed)})
27
13
 
28
14
 
29
- def particle_left(particle_dict: Dict[str, Particle], particle_speed: int = 30) -> None:
15
+ def particle_left(particle_dict: Dict[str, dict], particle_speed: int = 30) -> None:
30
16
  for particle in particle_dict.values():
31
- particle.x -= random.randint(0, particle_speed)
17
+ particle.update({"x": particle.get("x") - random.randint(0, particle_speed)})
32
18
 
33
19
 
34
- def particle_right(particle_dict: Dict[str, Particle], particle_speed: int = 30) -> None:
20
+ def particle_right(particle_dict: Dict[str, dict], particle_speed: int = 30) -> None:
35
21
  for particle in particle_dict.values():
36
- particle.x += random.randint(0, particle_speed)
22
+ particle.update({"x": particle.get("x") + random.randint(0, particle_speed)})
37
23
 
38
24
 
39
- def particle_left_down(particle_dict: Dict[str, Particle], particle_speed: int = 30) -> None:
25
+ def particle_left_down(particle_dict: Dict[str, dict], particle_speed: int = 30) -> None:
40
26
  particle_left(particle_dict, particle_speed)
41
27
  particle_down(particle_dict, particle_speed)
42
28
 
43
29
 
44
- def particle_left_up(particle_dict: Dict[str, Particle], particle_speed: int = 30) -> None:
30
+ def particle_left_up(particle_dict: Dict[str, dict], particle_speed: int = 30) -> None:
45
31
  particle_left(particle_dict, particle_speed)
46
32
  particle_up(particle_dict, particle_speed)
47
33
 
48
34
 
49
- def particle_right_down(particle_dict: Dict[str, Particle], particle_speed: int = 30) -> None:
35
+ def particle_right_down(particle_dict: Dict[str, dict], particle_speed: int = 30) -> None:
50
36
  particle_right(particle_dict, particle_speed)
51
37
  particle_down(particle_dict, particle_speed)
52
38
 
53
39
 
54
- def particle_right_up(particle_dict: Dict[str, Particle], particle_speed: int = 30) -> None:
40
+ def particle_right_up(particle_dict: Dict[str, dict], particle_speed: int = 30) -> None:
55
41
  particle_right(particle_dict, particle_speed)
56
42
  particle_up(particle_dict, particle_speed)
57
43
 
58
44
 
59
- def particle_random_minus(particle_dict: Dict[str, Particle], particle_speed: int = 30) -> None:
45
+ def particle_random_minus(particle_dict: Dict[str, dict], particle_speed: int = 30) -> None:
60
46
  for particle in particle_dict.values():
61
- particle.y += random.randint(0, particle_speed)
62
- particle.x -= random.randint(0, particle_speed)
47
+ particle.update({"y": particle.get("y") + random.randint(0, particle_speed)})
48
+ particle.update({"x": particle.get("x") - random.randint(0, particle_speed)})
63
49
 
64
50
 
65
- def particle_random_add(particle_dict: Dict[str, Particle], particle_speed: int = 30) -> None:
51
+ def particle_random_add(particle_dict: Dict[str, dict], particle_speed: int = 30) -> None:
66
52
  for particle in particle_dict.values():
67
- particle.y -= random.randint(0, particle_speed)
68
- particle.x += random.randint(0, particle_speed)
53
+ particle.update({"y": particle.get("y") - random.randint(0, particle_speed)})
54
+ particle.update({"x": particle.get("x") + random.randint(0, particle_speed)})
69
55
 
70
56
 
71
- def particle_random(particle_dict: Dict[str, Particle], particle_speed: int = 30) -> None:
57
+ def particle_random(particle_dict: Dict[str, dict], particle_speed: int = 30) -> None:
72
58
  function: Callable = random.choice(
73
59
  [particle_down, particle_up, particle_left, particle_right, particle_right_up, particle_left_down,
74
60
  particle_left_up, particle_right_down, particle_random_add, particle_random_minus])
@@ -45,6 +45,7 @@ class VideoWidget(QVideoWidget):
45
45
  if self.icon_path.exists() and self.icon_path.is_file():
46
46
  self.setWindowIcon(QIcon(str(self.icon_path)))
47
47
 
48
+
48
49
  def set_ui_window_flag(self, show_on_bottom: bool = False) -> None:
49
50
  self.setWindowFlag(
50
51
  Qt.WindowType.WindowTransparentForInput |
frontengine/ui/main_ui.py CHANGED
@@ -4,9 +4,9 @@ from pathlib import Path
4
4
  from typing import Dict, Type
5
5
 
6
6
  from PySide6.QtCore import QTimer, QCoreApplication
7
- from PySide6.QtGui import QIcon, QAction, Qt
7
+ from PySide6.QtGui import QIcon, Qt
8
8
  from PySide6.QtWidgets import QMainWindow, QApplication, QGridLayout, QTabWidget, QMenuBar, QWidget
9
- from qt_material import apply_stylesheet, QtStyleTools
9
+ from qt_material import apply_stylesheet
10
10
 
11
11
  from frontengine.system_tray.extend_system_tray import ExtendSystemTray
12
12
  from frontengine.ui.menu.help_menu import build_help_menu
@@ -15,6 +15,7 @@ from frontengine.ui.menu.language_menu import build_language_menu
15
15
  from frontengine.ui.page.control_center.control_center_ui import ControlCenterUI
16
16
  from frontengine.ui.page.gif.gif_setting_ui import GIFSettingUI
17
17
  from frontengine.ui.page.image.image_setting_ui import ImageSettingUI
18
+ from frontengine.ui.page.particle.particle_setting_ui import ParticleSettingUI
18
19
  from frontengine.ui.page.scene_setting.scene_setting_ui import SceneSettingUI
19
20
  from frontengine.ui.page.sound_player.sound_player_setting_ui import SoundPlayerSettingUI
20
21
  from frontengine.ui.page.text.text_setting_ui import TextSettingUI
@@ -28,7 +29,7 @@ from frontengine.utils.multi_language.language_wrapper import language_wrapper
28
29
  FrontEngine_EXTEND_TAB: Dict[str, Type[QWidget]] = {}
29
30
 
30
31
 
31
- class FrontEngineMainUI(QMainWindow, QtStyleTools):
32
+ class FrontEngineMainUI(QMainWindow):
32
33
 
33
34
  def __init__(self, debug: bool = False, show_system_tray_ray: bool = True):
34
35
  super().__init__()
@@ -55,6 +56,7 @@ class FrontEngineMainUI(QMainWindow, QtStyleTools):
55
56
  self.sound_player_setting_ui = SoundPlayerSettingUI()
56
57
  self.text_setting_ui = TextSettingUI()
57
58
  self.scene_setting_ui = SceneSettingUI()
59
+ self.particle_setting_ui = ParticleSettingUI()
58
60
  self.control_center_ui = ControlCenterUI(
59
61
  self.video_setting_ui,
60
62
  self.image_setting_ui,
@@ -62,11 +64,11 @@ class FrontEngineMainUI(QMainWindow, QtStyleTools):
62
64
  self.gif_setting_ui,
63
65
  self.sound_player_setting_ui,
64
66
  self.text_setting_ui,
65
- self.scene_setting_ui
67
+ self.scene_setting_ui,
68
+ self.particle_setting_ui
66
69
  )
67
70
  # Style menu bar
68
71
  self.menu_bar = QMenuBar()
69
- self.add_style_menu()
70
72
  self.setMenuBar(self.menu_bar)
71
73
  self.tab_widget.addTab(
72
74
  self.video_setting_ui, language_wrapper.language_word_dict.get("tab_video_text"))
@@ -90,6 +92,10 @@ class FrontEngineMainUI(QMainWindow, QtStyleTools):
90
92
  self.scene_setting_ui,
91
93
  language_wrapper.language_word_dict.get("tab_scene_text")
92
94
  )
95
+ self.tab_widget.addTab(
96
+ self.particle_setting_ui,
97
+ language_wrapper.language_word_dict.get("tab_particle_text")
98
+ )
93
99
  self.tab_widget.addTab(
94
100
  self.control_center_ui,
95
101
  language_wrapper.language_word_dict.get("tab_control_center_text")
@@ -124,22 +130,7 @@ class FrontEngineMainUI(QMainWindow, QtStyleTools):
124
130
  apply_stylesheet(self, theme=user_setting_dict.get("theme"))
125
131
  self.showMaximized()
126
132
 
127
- def add_style_menu(self) -> None:
128
- self.menu_bar.style_menu = self.menu_bar.addMenu(
129
- language_wrapper.language_word_dict.get("menu_bar_ui_style")
130
- )
131
- for style in [
132
- 'dark_amber.xml', 'dark_blue.xml', 'dark_cyan.xml', 'dark_lightgreen.xml', 'dark_pink.xml',
133
- 'dark_purple.xml', 'dark_red.xml', 'dark_teal.xml', 'dark_yellow.xml', 'light_amber.xml',
134
- 'light_blue.xml', 'light_cyan.xml', 'light_cyan_500.xml', 'light_lightgreen.xml',
135
- 'light_pink.xml', 'light_purple.xml', 'light_red.xml', 'light_teal.xml', 'light_yellow.xml'
136
- ]:
137
- change_style_action = QAction(style, parent=self)
138
- change_style_action.triggered.connect(self.set_style)
139
- self.menu_bar.style_menu.addAction(change_style_action)
140
-
141
133
  def set_style(self) -> None:
142
- self.apply_stylesheet(self, self.sender().text())
143
134
  user_setting_dict.update({"theme": self.sender().text()})
144
135
 
145
136
  def closeEvent(self, event) -> None:
@@ -4,6 +4,7 @@ from PySide6.QtWidgets import QGridLayout, QWidget, QPushButton, QTextEdit, QScr
4
4
  from frontengine.ui.color.global_color import error_color, output_color
5
5
  from frontengine.ui.page.gif.gif_setting_ui import GIFSettingUI
6
6
  from frontengine.ui.page.image.image_setting_ui import ImageSettingUI
7
+ from frontengine.ui.page.particle.particle_setting_ui import ParticleSettingUI
7
8
  from frontengine.ui.page.scene_setting.scene_setting_ui import SceneSettingUI
8
9
  from frontengine.ui.page.sound_player.sound_player_setting_ui import SoundPlayerSettingUI
9
10
  from frontengine.ui.page.text.text_setting_ui import TextSettingUI
@@ -24,7 +25,8 @@ class ControlCenterUI(QWidget):
24
25
  gif_setting_ui: GIFSettingUI,
25
26
  sound_player_setting_ui: SoundPlayerSettingUI,
26
27
  text_setting_ui: TextSettingUI,
27
- scene_setting_ui: SceneSettingUI
28
+ scene_setting_ui: SceneSettingUI,
29
+ particle_setting_ui: ParticleSettingUI
28
30
  ):
29
31
  super().__init__()
30
32
  # Layout
@@ -39,6 +41,7 @@ class ControlCenterUI(QWidget):
39
41
  self.sound_player_setting_ui = sound_player_setting_ui
40
42
  self.text_setting_ui = text_setting_ui
41
43
  self.scene_setting_ui = scene_setting_ui
44
+ self.particle_setting_ui = particle_setting_ui
42
45
  # Close video widget
43
46
  self.clear_video_button = QPushButton(
44
47
  language_wrapper.language_word_dict.get("control_center_close_all_video")
@@ -155,6 +158,7 @@ class ControlCenterUI(QWidget):
155
158
  self.gif_setting_ui.gif_widget_list.clear()
156
159
  self.sound_player_setting_ui.sound_widget_list.clear()
157
160
  self.text_setting_ui.text_widget_list.clear()
161
+ self.particle_setting_ui.particle_list.clear()
158
162
  self.scene_setting_ui.close_scene()
159
163
 
160
164
  def redirect(self) -> None:
@@ -5,7 +5,7 @@ from PySide6.QtWidgets import QWidget, QGridLayout, QLabel, QSlider, QPushButton
5
5
 
6
6
  from frontengine.show.gif.paint_gif import GifWidget
7
7
  from frontengine.ui.dialog.choose_file_dialog import choose_gif
8
- from frontengine.ui.page.utils import monitor_choose_dialog
8
+ from frontengine.ui.page.utils import monitor_choose_dialog, check_show_fullscreen
9
9
  from frontengine.utils.logging.loggin_instance import front_engine_logger
10
10
  from frontengine.utils.multi_language.language_wrapper import language_wrapper
11
11
 
@@ -61,6 +61,11 @@ class GIFSettingUI(QWidget):
61
61
  language_wrapper.language_word_dict.get("gif_setting_ui_play")
62
62
  )
63
63
  self.start_button.clicked.connect(self.start_play_gif)
64
+ # Expand
65
+ self.fullscreen_checkbox = QCheckBox(
66
+ language_wrapper.language_word_dict.get("fullscreen_checkbox_label")
67
+ )
68
+ self.fullscreen_checkbox.setChecked(True)
64
69
  # Show on all screen
65
70
  self.show_on_all_screen_checkbox = QCheckBox(
66
71
  language_wrapper.language_word_dict.get("Show on all screen")
@@ -79,6 +84,7 @@ class GIFSettingUI(QWidget):
79
84
  self.grid_layout.addWidget(self.speed_slider, 1, 2)
80
85
  self.grid_layout.addWidget(self.choose_file_button, 2, 0)
81
86
  self.grid_layout.addWidget(self.ready_label, 2, 1)
87
+ self.grid_layout.addWidget(self.fullscreen_checkbox, 2, 2)
82
88
  self.grid_layout.addWidget(self.start_button, 3, 0)
83
89
  self.grid_layout.addWidget(self.show_on_all_screen_checkbox, 3, 1)
84
90
  self.grid_layout.addWidget(self.show_on_bottom_checkbox, 3, 2)
@@ -116,15 +122,11 @@ class GIFSettingUI(QWidget):
116
122
  if len(monitors) > select_monitor_index:
117
123
  monitor = monitors[select_monitor_index]
118
124
  gif_widget = self._create_gif_widget()
119
- gif_widget.setScreen(monitor)
120
- gif_widget.move(monitor.availableGeometry().topLeft())
121
- gif_widget.showFullScreen()
125
+ check_show_fullscreen(gif_widget, self.fullscreen_checkbox, monitor)
122
126
  else:
123
127
  for monitor in monitors:
124
128
  gif_widget = self._create_gif_widget()
125
- gif_widget.setScreen(monitor)
126
- gif_widget.move(monitor.availableGeometry().topLeft())
127
- gif_widget.showFullScreen()
129
+ check_show_fullscreen(gif_widget, self.fullscreen_checkbox, monitor)
128
130
 
129
131
  def choose_and_copy_file_to_cwd_gif_dir_then_play(self) -> None:
130
132
  self.ready_label.setText(
@@ -1,11 +1,11 @@
1
1
  from PySide6.QtCore import Qt
2
- from PySide6.QtGui import QScreen, QGuiApplication
2
+ from PySide6.QtGui import QGuiApplication
3
3
  from PySide6.QtWidgets import QWidget, QGridLayout, QSlider, QLabel, QPushButton, QMessageBox, \
4
4
  QCheckBox, QDialog
5
5
 
6
6
  from frontengine.show.image.paint_image import ImageWidget
7
7
  from frontengine.ui.dialog.choose_file_dialog import choose_image
8
- from frontengine.ui.page.utils import monitor_choose_dialog
8
+ from frontengine.ui.page.utils import monitor_choose_dialog, check_show_fullscreen
9
9
  from frontengine.utils.logging.loggin_instance import front_engine_logger
10
10
  from frontengine.utils.multi_language.language_wrapper import language_wrapper
11
11
 
@@ -50,6 +50,11 @@ class ImageSettingUI(QWidget):
50
50
  language_wrapper.language_word_dict.get("image_setting_ui_play")
51
51
  )
52
52
  self.start_button.clicked.connect(self.start_play_image)
53
+ # Expand
54
+ self.fullscreen_checkbox = QCheckBox(
55
+ language_wrapper.language_word_dict.get("fullscreen_checkbox_label")
56
+ )
57
+ self.fullscreen_checkbox.setChecked(True)
53
58
  # Show on all screen
54
59
  self.show_on_all_screen_checkbox = QCheckBox(
55
60
  language_wrapper.language_word_dict.get("Show on all screen")
@@ -65,6 +70,7 @@ class ImageSettingUI(QWidget):
65
70
  self.grid_layout.addWidget(self.opacity_slider, 0, 2)
66
71
  self.grid_layout.addWidget(self.choose_file_button, 1, 0)
67
72
  self.grid_layout.addWidget(self.ready_label, 1, 1)
73
+ self.grid_layout.addWidget(self.fullscreen_checkbox, 1, 2)
68
74
  self.grid_layout.addWidget(self.start_button, 2, 0)
69
75
  self.grid_layout.addWidget(self.show_on_all_screen_checkbox, 2, 1)
70
76
  self.grid_layout.addWidget(self.show_on_bottom_checkbox, 2, 2)
@@ -100,16 +106,13 @@ class ImageSettingUI(QWidget):
100
106
  select_monitor_index = int(combobox.currentText())
101
107
  if len(monitors) > select_monitor_index:
102
108
  monitor = monitors[select_monitor_index]
103
- gif_widget = self._create_image_widget()
104
- gif_widget.setScreen(monitor)
105
- gif_widget.move(monitor.availableGeometry().topLeft())
106
- gif_widget.showFullScreen()
109
+ image_widget = self._create_image_widget()
110
+ check_show_fullscreen(image_widget, self.fullscreen_checkbox, monitor)
111
+
107
112
  else:
108
113
  for monitor in monitors:
109
114
  image_widget = self._create_image_widget()
110
- image_widget.setScreen(monitor)
111
- image_widget.move(monitor.availableGeometry().topLeft())
112
- image_widget.showFullScreen()
115
+ check_show_fullscreen(image_widget, self.fullscreen_checkbox, monitor)
113
116
 
114
117
  def choose_and_copy_file_to_cwd_image_dir_then_play(self) -> None:
115
118
  self.ready_label.setText(
File without changes
@@ -0,0 +1,175 @@
1
+ from PySide6.QtCore import Qt
2
+ from PySide6.QtGui import QGuiApplication, QPixmap
3
+ from PySide6.QtWidgets import QWidget, QGridLayout, QSlider, QLabel, QPushButton, QMessageBox, \
4
+ QCheckBox, QDialog, QComboBox
5
+
6
+ from frontengine.show.particle.particle_ui import ParticleWidget
7
+ from frontengine.ui.dialog.choose_file_dialog import choose_image
8
+ from frontengine.ui.page.utils import monitor_choose_dialog
9
+ from frontengine.utils.logging.loggin_instance import front_engine_logger
10
+ from frontengine.utils.multi_language.language_wrapper import language_wrapper
11
+
12
+
13
+ class ParticleSettingUI(QWidget):
14
+
15
+ def __init__(self):
16
+ super().__init__()
17
+ self.grid_layout = QGridLayout()
18
+ self.grid_layout = QGridLayout(self)
19
+ self.grid_layout.setContentsMargins(0, 0, 0, 0)
20
+ self.setAttribute(Qt.WidgetAttribute.WA_DeleteOnClose)
21
+ # Init variable
22
+ self.particle_list = []
23
+ self.show_all_screen = False
24
+ self.ready_to_play = False
25
+ # Opacity setting
26
+ self.opacity_slider = QSlider()
27
+ self.opacity_slider.setOrientation(Qt.Orientation.Horizontal)
28
+ self.opacity_label = QLabel(
29
+ language_wrapper.language_word_dict.get("Opacity")
30
+ )
31
+ self.opacity_slider.setMinimum(1)
32
+ self.opacity_slider.setMaximum(100)
33
+ self.opacity_slider.setValue(20)
34
+ self.opacity_slider.setTickInterval(1)
35
+ self.opacity_slider_value_label = QLabel(str(self.opacity_slider.value()))
36
+ self.opacity_slider.actionTriggered.connect(self.opacity_trick)
37
+ self.setLayout(self.grid_layout)
38
+ # Choose file button
39
+ self.choose_file_button = QPushButton(
40
+ language_wrapper.language_word_dict.get("image_setting_choose_file")
41
+ )
42
+ self.choose_file_button.clicked.connect(self.choose_and_copy_file_to_cwd_image_dir_then_play)
43
+ # Ready label and variable
44
+ self.ready_label = QLabel(
45
+ language_wrapper.language_word_dict.get("Not Ready")
46
+ )
47
+ self.image_path: [str, None] = None
48
+ # Choose direction
49
+ self.choose_direction_label = QLabel(language_wrapper.language_word_dict.get("choose_particle_direction"))
50
+ self.choose_direction_combobox = QComboBox()
51
+ self.choose_direction_combobox.addItems(
52
+ ["down", "up", "left", "right", "left_down", "left_up", "right_down", "right_up",
53
+ "random_minus", "random_add", "random"])
54
+ # Particle size
55
+ self.particle_size_label = QLabel(language_wrapper.language_word_dict.get("particle_size"))
56
+ self.particle_size_combobox = QComboBox()
57
+ for size in range(10, 310, 10):
58
+ self.particle_size_combobox.addItem(str(size))
59
+ self.particle_size_combobox.setCurrentText("50")
60
+ # Particle count
61
+ self.particle_count_label = QLabel(language_wrapper.language_word_dict.get("particle_count"))
62
+ self.particle_count_combobox = QComboBox()
63
+ for count in range(50, 10010, 10):
64
+ self.particle_count_combobox.addItem(str(count))
65
+ self.particle_count_combobox.setCurrentText("100")
66
+ # Particle count
67
+ self.particle_speed_label = QLabel(language_wrapper.language_word_dict.get("particle_speed"))
68
+ self.particle_speed_combobox = QComboBox()
69
+ for speed in range(1, 11, 1):
70
+ self.particle_speed_combobox.addItem(str(speed))
71
+ # Start button
72
+ self.start_button = QPushButton(
73
+ language_wrapper.language_word_dict.get("particle_setting_ui_play")
74
+ )
75
+ self.start_button.clicked.connect(self.start_play_particle)
76
+ # Show on all screen
77
+ self.show_on_all_screen_checkbox = QCheckBox(
78
+ language_wrapper.language_word_dict.get("Show on all screen")
79
+ )
80
+ self.show_on_all_screen_checkbox.clicked.connect(self.set_show_all_screen)
81
+ # Show on bottom
82
+ self.show_on_bottom_checkbox = QCheckBox(
83
+ language_wrapper.language_word_dict.get("Show on bottom")
84
+ )
85
+ # Add to layout
86
+ self.grid_layout.addWidget(self.opacity_label, 0, 0)
87
+ self.grid_layout.addWidget(self.opacity_slider_value_label, 0, 1)
88
+ self.grid_layout.addWidget(self.opacity_slider, 0, 2)
89
+ self.grid_layout.addWidget(self.choose_file_button, 1, 0)
90
+ self.grid_layout.addWidget(self.ready_label, 1, 1)
91
+ self.grid_layout.addWidget(self.choose_direction_label, 2, 0)
92
+ self.grid_layout.addWidget(self.choose_direction_combobox, 2, 1)
93
+ self.grid_layout.addWidget(self.particle_size_label, 3, 0)
94
+ self.grid_layout.addWidget(self.particle_size_combobox, 3, 1)
95
+ self.grid_layout.addWidget(self.particle_count_label, 4, 0)
96
+ self.grid_layout.addWidget(self.particle_count_combobox, 4, 1)
97
+ self.grid_layout.addWidget(self.particle_speed_label, 5, 0)
98
+ self.grid_layout.addWidget(self.particle_speed_combobox, 5, 1)
99
+ self.grid_layout.addWidget(self.start_button, 6, 0)
100
+ self.grid_layout.addWidget(self.show_on_all_screen_checkbox, 6, 1)
101
+ self.grid_layout.addWidget(self.show_on_bottom_checkbox, 6, 2)
102
+ self.setLayout(self.grid_layout)
103
+
104
+ def set_show_all_screen(self) -> None:
105
+ self.show_all_screen = self.show_on_all_screen_checkbox.isChecked()
106
+
107
+ def _create_particle_widget(self, screen_width: int = 1920, screen_height: int = 1080) -> ParticleWidget:
108
+ particle_widget = ParticleWidget(
109
+ pixmap=QPixmap(self.image_path),
110
+ particle_size=int(self.particle_size_combobox.currentText()),
111
+ particle_direction=self.choose_direction_combobox.currentText(),
112
+ particle_count=int(self.particle_count_combobox.currentText()),
113
+ opacity=float(self.opacity_slider.value()) / 100,
114
+ screen_width=screen_width,
115
+ screen_height=screen_height,
116
+ particle_speed=int(self.particle_speed_combobox.currentText())
117
+ )
118
+ particle_widget.set_ui_window_flag(self.show_on_bottom_checkbox.isChecked())
119
+ self.particle_list.append(particle_widget)
120
+ return particle_widget
121
+
122
+ def start_play_particle(self) -> None:
123
+ if self.image_path is None or self.ready_to_play is False:
124
+ message_box = QMessageBox(self)
125
+ message_box.setText(
126
+ language_wrapper.language_word_dict.get("not_prepare")
127
+ )
128
+ message_box.show()
129
+ else:
130
+ front_engine_logger.info("start play particle")
131
+ monitors = QGuiApplication.screens()
132
+ if self.show_all_screen is False and len(monitors) <= 1:
133
+ particle_widget = self._create_particle_widget(
134
+ monitors[0].availableGeometry().width(),
135
+ monitors[0].availableGeometry().height()
136
+ )
137
+ particle_widget.showFullScreen()
138
+ elif self.show_all_screen is False and len(monitors) >= 2:
139
+ input_dialog, combobox = monitor_choose_dialog(self, monitors)
140
+ result = input_dialog.exec_()
141
+ if result == QDialog.DialogCode.Accepted:
142
+ select_monitor_index = int(combobox.currentText())
143
+ if len(monitors) > select_monitor_index:
144
+ monitor = monitors[select_monitor_index]
145
+ particle_widget = self._create_particle_widget(
146
+ monitor.availableGeometry().width(),
147
+ monitor.availableGeometry().height()
148
+ )
149
+ particle_widget.setScreen(monitor)
150
+ particle_widget.move(monitor.availableGeometry().topLeft())
151
+ particle_widget.showFullScreen()
152
+ else:
153
+ for monitor in monitors:
154
+ particle_widget = self._create_particle_widget(
155
+ monitor.availableGeometry().width(),
156
+ monitor.availableGeometry().height()
157
+ )
158
+ particle_widget.setScreen(monitor)
159
+ particle_widget.move(monitor.availableGeometry().topLeft())
160
+ particle_widget.showFullScreen()
161
+
162
+ def choose_and_copy_file_to_cwd_image_dir_then_play(self) -> None:
163
+ self.ready_label.setText(
164
+ language_wrapper.language_word_dict.get("Not Ready")
165
+ )
166
+ self.ready_to_play = False
167
+ self.image_path = choose_image(self)
168
+ if self.image_path is not None:
169
+ self.ready_label.setText(
170
+ language_wrapper.language_word_dict.get("Ready")
171
+ )
172
+ self.ready_to_play = True
173
+
174
+ def opacity_trick(self) -> None:
175
+ self.opacity_slider_value_label.setText(str(self.opacity_slider.value()))
@@ -1,4 +1,5 @@
1
- from PySide6.QtWidgets import QWidget, QDialog, QGridLayout, QLabel, QComboBox, QPushButton
1
+ from PySide6.QtGui import QScreen
2
+ from PySide6.QtWidgets import QWidget, QDialog, QGridLayout, QLabel, QComboBox, QPushButton, QCheckBox
2
3
 
3
4
  from frontengine.utils.multi_language.language_wrapper import language_wrapper
4
5
 
@@ -21,3 +22,15 @@ def monitor_choose_dialog(parent: QWidget, monitors: list):
21
22
  grid_layout.addWidget(no_button, 2, 1)
22
23
  input_dialog.setLayout(grid_layout)
23
24
  return input_dialog, combobox
25
+
26
+
27
+ def check_show_fullscreen(widget: QWidget, fullscreen_checkbox: QCheckBox, monitor: QScreen):
28
+ if fullscreen_checkbox.isChecked():
29
+ widget.setScreen(monitor)
30
+ widget.move(monitor.availableGeometry().topLeft())
31
+ widget.showFullScreen()
32
+ else:
33
+ widget.setScreen(monitor)
34
+ center = monitor.availableGeometry().center()
35
+ widget.move(center - widget.rect().center())
36
+ widget.show()
@@ -4,7 +4,7 @@ from PySide6.QtWidgets import QWidget, QGridLayout, QSlider, QLabel, QPushButton
4
4
 
5
5
  from frontengine.show.video.video_player import VideoWidget
6
6
  from frontengine.ui.dialog.choose_file_dialog import choose_video
7
- from frontengine.ui.page.utils import monitor_choose_dialog
7
+ from frontengine.ui.page.utils import monitor_choose_dialog, check_show_fullscreen
8
8
  from frontengine.utils.logging.loggin_instance import front_engine_logger
9
9
  from frontengine.utils.multi_language.language_wrapper import language_wrapper
10
10
 
@@ -70,6 +70,11 @@ class VideoSettingUI(QWidget):
70
70
  language_wrapper.language_word_dict.get("video_setting_start_play")
71
71
  )
72
72
  self.start_button.clicked.connect(self.start_play_gif)
73
+ # Expand
74
+ self.fullscreen_checkbox = QCheckBox(
75
+ language_wrapper.language_word_dict.get("fullscreen_checkbox_label")
76
+ )
77
+ self.fullscreen_checkbox.setChecked(True)
73
78
  # Show on all screen
74
79
  self.show_on_all_screen_checkbox = QCheckBox(
75
80
  language_wrapper.language_word_dict.get("Show on all screen")
@@ -92,6 +97,7 @@ class VideoSettingUI(QWidget):
92
97
  self.grid_layout.addWidget(self.choose_file_button, 3, 0)
93
98
  self.grid_layout.addWidget(self.show_on_all_screen_checkbox, 4, 0)
94
99
  self.grid_layout.addWidget(self.show_on_bottom_checkbox, 4, 1)
100
+ self.grid_layout.addWidget(self.fullscreen_checkbox, 4, 2)
95
101
  self.grid_layout.addWidget(self.start_button, 5, 0)
96
102
  self.grid_layout.addWidget(self.ready_label, 5, 1)
97
103
  self.setLayout(self.grid_layout)
@@ -131,18 +137,14 @@ class VideoSettingUI(QWidget):
131
137
  if len(monitors) > select_monitor_index:
132
138
  monitor = monitors[select_monitor_index]
133
139
  video_widget = self._create_video_widget()
134
- video_widget.setScreen(monitor)
135
- video_widget.move(monitor.availableGeometry().topLeft())
136
- video_widget.showFullScreen()
140
+ check_show_fullscreen(video_widget, self.fullscreen_checkbox, monitor)
137
141
  else:
138
142
  count = 0
139
143
  for monitor in monitors:
140
144
  video_widget = self._create_video_widget()
141
145
  if count >= 1:
142
146
  video_widget.media_player.audioOutput().setVolume(0)
143
- video_widget.setScreen(monitor)
144
- video_widget.move(monitor.availableGeometry().topLeft())
145
- video_widget.showFullScreen()
147
+ check_show_fullscreen(video_widget, self.fullscreen_checkbox, monitor)
146
148
  count = count + 1
147
149
 
148
150
  def choose_and_copy_file_to_cwd_gif_dir_then_play(self) -> None:
@@ -62,6 +62,7 @@ english_word_dict = {
62
62
  "show_on_which_monitor": "Show on which monitor",
63
63
  "ok": "ok",
64
64
  "no": "no",
65
+ "fullscreen_checkbox_label": "Fullscreen?",
65
66
  # GIF setting ui
66
67
  "gif_setting_ui_choose_file": "Choose GIF or WEBP file",
67
68
  "gif_setting_ui_play": "Start Play GIF or WEBP",
@@ -108,6 +109,13 @@ english_word_dict = {
108
109
  "scene_input": "load scene file",
109
110
  "scene_script_clear": "clear all script",
110
111
  "scene_script": "Scene script",
112
+ # Particle ui
113
+ "tab_particle_text": "Particle",
114
+ "choose_particle_direction": "Choose particle direction",
115
+ "particle_setting_ui_play": "Start play particle",
116
+ "particle_size": "Particle size",
117
+ "particle_count": "Particle count",
118
+ "particle_speed": "Particle speed",
111
119
  # Chat scene input
112
120
  "chat_scene_input_title": "input chat content",
113
121
  "chat_scene_send_chat": "send text",
@@ -62,6 +62,7 @@ french_word_dict = {
62
62
  "show_on_which_monitor": "Afficher sur quel écran",
63
63
  "ok": "OK",
64
64
  "no": "Non",
65
+ "fullscreen_checkbox_label": "Plein écran?",
65
66
  # GIF setting ui
66
67
  "gif_setting_ui_choose_file": "Choisir un fichier GIF ou WEBP",
67
68
  "gif_setting_ui_play": "Lancer la lecture du GIF ou WEBP",
@@ -109,6 +110,13 @@ french_word_dict = {
109
110
  "scene_input": "Charger le fichier de scène",
110
111
  "scene_script_clear": "Effacer tous les scripts",
111
112
  "scene_script": "Script de scène",
113
+ # Particle ui
114
+ "tab_particle_text": "Particule",
115
+ "choose_particle_direction": "Choisissez la direction des particules",
116
+ "particle_setting_ui_play": "Démarrer la lecture des particules",
117
+ "particle_size": "Taille des particules",
118
+ "particle_count": "Nombre de particules",
119
+ "particle_speed": "Vitesse des particules",
112
120
  # Chat scene input
113
121
  "chat_scene_input_title": "Entrer le contenu de la discussion",
114
122
  "chat_scene_send_chat": "Envoyer le texte",
@@ -62,6 +62,7 @@ germany_word_dict = {
62
62
  "show_on_which_monitor": "Auf welchem Monitor anzeigen",
63
63
  "ok": "OK",
64
64
  "no": "Nein",
65
+ "fullscreen_checkbox_label": "Vollbild?",
65
66
  # GIF-Einstellungs-UI
66
67
  "gif_setting_ui_choose_file": "GIF- oder WEBP-Datei auswählen",
67
68
  "gif_setting_ui_play": "GIF oder WEBP abspielen",
@@ -109,6 +110,13 @@ germany_word_dict = {
109
110
  "scene_input": "Szenendatei laden",
110
111
  "scene_script_clear": "Alle Skripte löschen",
111
112
  "scene_script": "Szenen-Skript",
113
+ # Particle ui
114
+ "tab_particle_text": "Partikel",
115
+ "choose_particle_direction": "Partikelrichtung auswählen",
116
+ "particle_setting_ui_play": "Partikelwiedergabe starten",
117
+ "particle_size": "Partikelgröße",
118
+ "particle_count": "Partikelanzahl",
119
+ "particle_speed": "Partikelgeschwindigkeit",
112
120
  # Chat-Szenen-Eingabe
113
121
  "chat_scene_input_title": "Chat-Inhalt eingeben",
114
122
  "chat_scene_send_chat": "Text senden",
@@ -62,6 +62,7 @@ italian_word_dict = {
62
62
  "show_on_which_monitor": "Mostra su quale schermo",
63
63
  "ok": "OK",
64
64
  "no": "No",
65
+ "fullscreen_checkbox_label": "Schermo intero?",
65
66
  # GIF setting ui
66
67
  "gif_setting_ui_choose_file": "Scegli un file GIF o WEBP",
67
68
  "gif_setting_ui_play": "Avvia la riproduzione di GIF o WEBP",
@@ -109,6 +110,13 @@ italian_word_dict = {
109
110
  "scene_input": "Carica il file di scena",
110
111
  "scene_script_clear": "Cancella tutti gli script",
111
112
  "scene_script": "Script della scena",
113
+ # Particle ui
114
+ "tab_particle_text": "Particella",
115
+ "choose_particle_direction": "Scegli la direzione delle particelle",
116
+ "particle_setting_ui_play": "Avvia la riproduzione delle particelle",
117
+ "particle_size": "Dimensione delle particelle",
118
+ "particle_count": "Numero di particelle",
119
+ "particle_speed": "Velocità delle particelle",
112
120
  # Chat scene input
113
121
  "chat_scene_input_title": "Inserisci il contenuto della chat",
114
122
  "chat_scene_send_chat": "Invia il testo",
@@ -62,6 +62,7 @@ russian_word_dict = {
62
62
  "show_on_which_monitor": "На каком мониторе показать",
63
63
  "ok": "ОК",
64
64
  "no": "Нет",
65
+ "fullscreen_checkbox_label": "Полноэкранный режим?",
65
66
  # GIF setting ui
66
67
  "gif_setting_ui_choose_file": "Выберите файл GIF или WEBP",
67
68
  "gif_setting_ui_play": "Начать воспроизведение GIF или WEBP",
@@ -109,6 +110,13 @@ russian_word_dict = {
109
110
  "scene_input": "Входной файл сцены",
110
111
  "scene_script_clear": "Очистить все скрипты",
111
112
  "scene_script": "Сценарий сцены",
113
+ # Particle ui
114
+ "tab_particle_text": "Частица",
115
+ "choose_particle_direction": "Выберите направление частицы",
116
+ "particle_setting_ui_play": "Начать воспроизведение частиц",
117
+ "particle_size": "Размер частицы",
118
+ "particle_count": "Количество частиц",
119
+ "particle_speed": "Скорость частицы",
112
120
  # Chat scene input
113
121
  "chat_scene_input_title": "Введите содержание чата",
114
122
  "chat_scene_send_chat": "Отправить текст",
@@ -62,6 +62,7 @@ simplified_chinese_word_dict = {
62
62
  "show_on_which_monitor": "显示在哪个屏幕",
63
63
  "ok": "确定",
64
64
  "no": "否",
65
+ "fullscreen_checkbox_label": "全屏?",
65
66
  # GIF 设置 UI
66
67
  "gif_setting_ui_choose_file": "选择 GIF 或 WEBP 文件",
67
68
  "gif_setting_ui_play": "开始播放 GIF 或 WEBP",
@@ -109,6 +110,13 @@ simplified_chinese_word_dict = {
109
110
  "scene_input": "读取场景文件",
110
111
  "scene_script_clear": "清除所有脚本",
111
112
  "scene_script": "场景脚本",
113
+ # Particle ui
114
+ "tab_particle_text": "粒子",
115
+ "choose_particle_direction": "选择粒子方向",
116
+ "particle_setting_ui_play": "开始播放粒子",
117
+ "particle_size": "粒子大小",
118
+ "particle_count": "粒子数量",
119
+ "particle_speed": "粒子速度",
112
120
  # Chat scene input
113
121
  "chat_scene_input_title": "输入聊天内容",
114
122
  "chat_scene_send_chat": "送出文字",
@@ -62,6 +62,7 @@ traditional_chinese_word_dict = {
62
62
  "show_on_which_monitor": "顯示在哪個螢幕",
63
63
  "ok": "確定",
64
64
  "no": "否",
65
+ "fullscreen_checkbox_label": "全螢幕?",
65
66
  # GIF setting ui
66
67
  "gif_setting_ui_choose_file": "選擇 GIF 或 WEBP 檔案",
67
68
  "gif_setting_ui_play": "開始撥放 GIF 或 WEBP",
@@ -109,6 +110,13 @@ traditional_chinese_word_dict = {
109
110
  "scene_input": "讀取場景檔案",
110
111
  "scene_script_clear": "清除所有腳本",
111
112
  "scene_script": "場景腳本",
113
+ # Particle ui
114
+ "tab_particle_text": "粒子",
115
+ "choose_particle_direction": "選擇粒子方向",
116
+ "particle_setting_ui_play": "開始播放粒子",
117
+ "particle_size": "粒子大小",
118
+ "particle_count": "粒子數量",
119
+ "particle_speed": "粒子速度",
112
120
  # Chat scene input
113
121
  "chat_scene_input_title": "輸入聊天內容",
114
122
  "chat_scene_send_chat": "送出文字",
File without changes
@@ -0,0 +1,34 @@
1
+ import traceback
2
+ from typing import Callable
3
+
4
+ from PySide6 import QtCore
5
+ from PySide6.QtCore import Signal, QRunnable, Slot
6
+
7
+
8
+ class QThreadSignal(QtCore.QObject):
9
+ finished = Signal()
10
+ error = Signal(tuple)
11
+ result = Signal(object)
12
+ progress = Signal(int)
13
+
14
+
15
+ class QThreadWorker(QRunnable):
16
+
17
+ def __init__(self, function: Callable, *args, **kwargs):
18
+ super().__init__()
19
+ self.function = function
20
+ self.args = args
21
+ self.kwargs = kwargs
22
+ self.signal = QThreadSignal()
23
+
24
+ @Slot()
25
+ def run(self):
26
+ try:
27
+ result = self.function(*self.args, **self.kwargs)
28
+ except Exception as e:
29
+ traceback.print_exc()
30
+ self.signal.error.emit(e)
31
+ else:
32
+ self.signal.result.emit(result)
33
+ finally:
34
+ self.signal.finished.emit()
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: frontengine_dev
3
- Version: 0.0.66
3
+ Version: 0.0.68
4
4
  Summary: FrontEngine is BingGPT that can use-define front end or only use like screen saver
5
5
  Author-email: JE-Chen <jechenmailman@gmail.com>
6
6
  License: MIT
@@ -1,5 +1,9 @@
1
1
  frontengine/__init__.py,sha256=kRQu2NKQX6VjF70N7Alqp31mxqJ5SRZL1Ri4abYvz0c,1938
2
+ frontengine/gl_widget/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
2
3
  frontengine/show/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
4
+ frontengine/show/clicker/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
5
+ frontengine/show/clicker/clicker_scene.py,sha256=pZJdy4xP52fgU1aZP74KNimJdW7jw6RKmjco2Ct_G5Y,149
6
+ frontengine/show/clicker/clicker_ui.py,sha256=XzayxCffi_LKocMzaIWV9WQ6Zpx1DnadFRCWeaB0j3k,1204
3
7
  frontengine/show/gif/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
4
8
  frontengine/show/gif/paint_gif.py,sha256=N_jj4wf5sPYj1vEjFFqlBDcjCD8hxF45ipRJ5yO6XOs,3024
5
9
  frontengine/show/image/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
@@ -7,9 +11,9 @@ frontengine/show/image/paint_image.py,sha256=BtKyFJP7UdOLMBsCoQ1fnT8ft-cUxDaufFz
7
11
  frontengine/show/load/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
8
12
  frontengine/show/load/load_someone_make_ui.py,sha256=yjMrkA76VEYkKXygwKmoKaADymjjDlebI-7PNa6DrEo,1010
9
13
  frontengine/show/particle/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
10
- frontengine/show/particle/paint_particle.py,sha256=CkFlbYONlH2yBlNnh2Vhy66WYaTQV3MlDkrXavKIgec,1829
11
- frontengine/show/particle/particle_scene.py,sha256=8TbQL60q_qxk5tv0fZp8leR7mkz-JT7aipP7-i-qoA8,2906
12
- frontengine/show/particle/particle_utils.py,sha256=AUHIHZpvvIJWF_iU6Urd9JXSeZdlwGJlTSWT5ywyg94,2999
14
+ frontengine/show/particle/particle_scene.py,sha256=KH09td30_hnZksdf3pAByugq2WUIHIjKFqM7puNbTCA,3142
15
+ frontengine/show/particle/particle_ui.py,sha256=TacLlBOuWN_18GBYEd1Auqvu5vnM1QYBvY3rDmAeny8,1881
16
+ frontengine/show/particle/particle_utils.py,sha256=ekfRYOidAchPlRpuoAuftFBNROMS3e9aA4Z2shQ3Y9c,2725
13
17
  frontengine/show/scene/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
14
18
  frontengine/show/scene/extend_graphic_scene.py,sha256=7UiEr_kRbhheGOj_rYeq3fAUtRacq2WH8fQZV0Q-tA4,148
15
19
  frontengine/show/scene/extend_graphic_view.py,sha256=b5yAA_PqMTCnn7-63Q8Fhm9HBiWfjo48_1xjh2nP67I,1999
@@ -20,13 +24,13 @@ frontengine/show/sound_player/sound_player.py,sha256=VOXwKI6-VdMH18u__atCay3wVJF
20
24
  frontengine/show/text/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
21
25
  frontengine/show/text/draw_text.py,sha256=7uXWXDVU6TE5sfQ52bXCNkl0uBIR3dku7xyZPKOqRD4,3685
22
26
  frontengine/show/video/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
23
- frontengine/show/video/video_player.py,sha256=_Sjbcy0KwY3hdr5JIYDIFtnmeDj2EUP0A8w_nSDPnu0,3358
27
+ frontengine/show/video/video_player.py,sha256=ndiMp4nNvxJ3cpuBw_qvtbdm8dnwdm7Jnxl3ke0i0ZU,3360
24
28
  frontengine/show/web/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
25
29
  frontengine/show/web/webview.py,sha256=2-7HW395Fp0SZnjUcrTGW-AWk_5OAAyzgjoXnnPpQoE,2842
26
30
  frontengine/system_tray/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
27
31
  frontengine/system_tray/extend_system_tray.py,sha256=k4u2lEox-fCwmQKy1qnek9SGoqUkMFv8Av_DcNanwcE,1595
28
32
  frontengine/ui/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
29
- frontengine/ui/main_ui.py,sha256=h_lrgMi04dMEupZ9GMCcbgC1SV6I_uBShRNkPpoenC4,7927
33
+ frontengine/ui/main_ui.py,sha256=47vTOtnNbiPV3J1LtKRRSnXlTmaedJSX7Cf4neIwhyA,7304
30
34
  frontengine/ui/color/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
31
35
  frontengine/ui/color/global_color.py,sha256=Rh-R-X2BHVjcK5MTBZ1nEMVHgLj1rP4nk-wTQKbiwFA,125
32
36
  frontengine/ui/dialog/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
@@ -37,13 +41,15 @@ frontengine/ui/menu/help_menu.py,sha256=WD6t4Mp5OKAlfI9RDKz2kN9ODBcil2rf4H61REK6
37
41
  frontengine/ui/menu/how_to_menu.py,sha256=s1azoiD8H2lApbFPcrv8QvsR1mwh6O_gFHRngQ7bsbc,952
38
42
  frontengine/ui/menu/language_menu.py,sha256=p0nA4bgxc7CIX8_WxUKlnjNLFyvmqCx-h6GXSazlVeM,4271
39
43
  frontengine/ui/page/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
40
- frontengine/ui/page/utils.py,sha256=UxHVStfVg-6563T20pEjnVMYzMvy9JePAj1VOm8HX_g,1103
44
+ frontengine/ui/page/utils.py,sha256=kb77e3Vc9WgXI4WDS5bpeOXrxs5G9F0u2d5_b5X0qhs,1595
41
45
  frontengine/ui/page/control_center/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
42
- frontengine/ui/page/control_center/control_center_ui.py,sha256=zyFdFML00ZHcC8NV2Lws95EssIDM_WUMU6h3qePhU7Y,7992
46
+ frontengine/ui/page/control_center/control_center_ui.py,sha256=BxXlWwW9uf48b1jfWgtTBCGZOShlW03m8kzI43YjpaM,8237
43
47
  frontengine/ui/page/gif/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
44
- frontengine/ui/page/gif/gif_setting_ui.py,sha256=HherbCmOJgO5TLXHt9sflTspmCQh1pv1IGyfKmp7kog,6908
48
+ frontengine/ui/page/gif/gif_setting_ui.py,sha256=lVVMAxNcl2xDgRlXdabG7cT2xlsxpm-0322ZM5Efqgg,7028
45
49
  frontengine/ui/page/image/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
46
- frontengine/ui/page/image/image_setting_ui.py,sha256=0in02Swq_qM-jZNevgoZe0QzjbnAl5L0ZMHOTHzQbrQ,6038
50
+ frontengine/ui/page/image/image_setting_ui.py,sha256=8whUEXIOTKeiobGO6-FXBbmjyfL-gGcq2KqGQDVsghY,6151
51
+ frontengine/ui/page/particle/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
52
+ frontengine/ui/page/particle/particle_setting_ui.py,sha256=mYRrXT2weh0Rn-d_Dz9yFR6CHYXjEgHxNlhapTwXD6E,8947
47
53
  frontengine/ui/page/scene_setting/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
48
54
  frontengine/ui/page/scene_setting/scene_manager.py,sha256=3s7UlMbQVTyDZd725wdzDvXqeiunE1Q5UQj5hxWGhIs,4978
49
55
  frontengine/ui/page/scene_setting/scene_setting_ui.py,sha256=jc6BGKHJGmPbFxChyILW3BBU_EF1yT0l63OJNqJYWSM,2590
@@ -59,7 +65,7 @@ frontengine/ui/page/sound_player/sound_player_setting_ui.py,sha256=OFRxUyUXVj3-P
59
65
  frontengine/ui/page/text/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
60
66
  frontengine/ui/page/text/text_setting_ui.py,sha256=nSrXkezs7X9-7Kd16raaz3WZJFwyL4cuz3j74VQIS9U,6317
61
67
  frontengine/ui/page/video/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
62
- frontengine/ui/page/video/video_setting_ui.py,sha256=crFydSKtBLDkdXyRENQupbXBX68OCBX_D97Fn3zowmk,8078
68
+ frontengine/ui/page/video/video_setting_ui.py,sha256=2HKaPHG-SiHx0ryo-arpm6pK4gGxuaOHkna9u4q-M4Y,8190
63
69
  frontengine/ui/page/web/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
64
70
  frontengine/ui/page/web/web_setting_ui.py,sha256=FgTCn68WTeFp197mhvilWKK25m0xF0gSZ9b7hfG2ELQ,5596
65
71
  frontengine/user_setting/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
@@ -87,18 +93,20 @@ frontengine/utils/json_format/json_process.py,sha256=xJt_4Hm_o3sNDoeGtRW9Q7fsRj3
87
93
  frontengine/utils/logging/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
88
94
  frontengine/utils/logging/loggin_instance.py,sha256=Zjr384o2q8x0QWv_hNoHIM_zCp5-HFgW14t-d30GUcQ,598
89
95
  frontengine/utils/multi_language/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
90
- frontengine/utils/multi_language/english.py,sha256=9A1Hl9HkRqjhDj3oGYpFCItGMU-VnTbuRfn31xQd5Fk,5849
91
- frontengine/utils/multi_language/france.py,sha256=k_LCWiDB22k6PKvrhIrQq2Inm1BoaH5Gwgb6xyMy8o0,6797
92
- frontengine/utils/multi_language/germany.py,sha256=jwg7KXtCahhES6ZPeeUugLoJgaUpnjgbRxN2ZTlJWXs,6534
93
- frontengine/utils/multi_language/italy.py,sha256=UaxuEyet2TUyLBR9JI1Bb7-zCx9iZ9oERImXTtTOV18,6560
96
+ frontengine/utils/multi_language/english.py,sha256=-Xc9wLLJuqaUIPrPv_g2V7T347FcVmaNKMrjNf2Kpb0,6195
97
+ frontengine/utils/multi_language/france.py,sha256=_N3gNqYsaLqOty8jUrF_ghA_uxwQ72jJzjG3i7_M6WQ,7197
98
+ frontengine/utils/multi_language/germany.py,sha256=RXJ-v9PViP9UkQq_jTj19fFlAhkp4G6IhvcgmJ8Eoag,6898
99
+ frontengine/utils/multi_language/italy.py,sha256=WALzKGHm3iWlUrgKW7qM3YjPJ_bRT--dCg8qDSoEn7o,6974
94
100
  frontengine/utils/multi_language/language_wrapper.py,sha256=GpQxvMlDMiHOAp71Ki0bOM0sL5kiI9tszpE1fQCZC14,1588
95
- frontengine/utils/multi_language/russian.py,sha256=roDQ_TIbbk5B0kOr6sJEjeDMJZGqloz43oapIcaR8PE,8326
96
- frontengine/utils/multi_language/simplified_chinese.py,sha256=wDnne4PiVA3eJ9Q4sxiJ-n_81E-42hi6608698LwsPA,6076
97
- frontengine/utils/multi_language/traditional_chinese.py,sha256=SSE338u2Y_-N0fumIVeBBRhnvjizT92tQdYcOJiMSFM,6083
101
+ frontengine/utils/multi_language/russian.py,sha256=KoORJ56Cjt_qJekBopHIolXjbeu5DRrM2cj6i9-v66o,8821
102
+ frontengine/utils/multi_language/simplified_chinese.py,sha256=ViN7N2XXdscSJmxnefAh7IpSK53-SLMypmxtCZcvv7Y,6403
103
+ frontengine/utils/multi_language/traditional_chinese.py,sha256=Xd4i4uiJz6zyssVPAxEAcU-WzjzkbcUoeI3X9KLNEEU,6413
98
104
  frontengine/utils/redirect_manager/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
99
105
  frontengine/utils/redirect_manager/redirect_manager_class.py,sha256=zGJeVpjRU12MCnhVAdksAIhK_IhddI4cNKVb7DMgOZA,1888
100
- frontengine_dev-0.0.66.dist-info/LICENSE,sha256=b3VlPBXnrDylKGffOEOLWMgOX-yfd65XC7PA1_sox2o,1085
101
- frontengine_dev-0.0.66.dist-info/METADATA,sha256=Rv31k5QgebDTl5qw9MdcyVLCziH8Qm98L1eL2DnFtmg,2170
102
- frontengine_dev-0.0.66.dist-info/WHEEL,sha256=GJ7t_kWBFywbagK5eo9IoUwLW6oyOeTKmQ-9iHFVNxQ,92
103
- frontengine_dev-0.0.66.dist-info/top_level.txt,sha256=btCybScN_ubeQ8phsSDBB0T-HyHjqt7b-WPy61uTox0,12
104
- frontengine_dev-0.0.66.dist-info/RECORD,,
106
+ frontengine/worker/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
107
+ frontengine/worker/qthread_worker.py,sha256=TcmRv4PUlWxYLzMoB_6fUefEZpVhNy5D6_hhShAdKzU,875
108
+ frontengine_dev-0.0.68.dist-info/LICENSE,sha256=b3VlPBXnrDylKGffOEOLWMgOX-yfd65XC7PA1_sox2o,1085
109
+ frontengine_dev-0.0.68.dist-info/METADATA,sha256=iGxOCVVmabq5SquuT406Ymcv5vyerRmaE_ND8mz-dFw,2170
110
+ frontengine_dev-0.0.68.dist-info/WHEEL,sha256=GJ7t_kWBFywbagK5eo9IoUwLW6oyOeTKmQ-9iHFVNxQ,92
111
+ frontengine_dev-0.0.68.dist-info/top_level.txt,sha256=btCybScN_ubeQ8phsSDBB0T-HyHjqt7b-WPy61uTox0,12
112
+ frontengine_dev-0.0.68.dist-info/RECORD,,