tkfluent 0.0.8__py3-none-any.whl → 0.1.0__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.
tkflu/__init__.py CHANGED
@@ -24,7 +24,7 @@ from .slider import FluSlider
24
24
  from .text import FluText
25
25
  from .thememanager import FluThemeManager
26
26
  from .togglebutton import FluToggleButton
27
- from .tooltip import FluToolTip
27
+ from .tooltip import FluToolTip, FluToolTip2, FluToolTipBase
28
28
  from .toplevel import FluToplevel
29
29
  from .window import FluWindow
30
30
 
tkflu/__main__.py CHANGED
@@ -2,8 +2,6 @@ from tkflu import *
2
2
  from tkinter import *
3
3
  from tkinter.font import *
4
4
 
5
- from tkflu.listbox import FluListBox
6
-
7
5
  blue_primary_color()
8
6
 
9
7
  def togglestate():
@@ -69,6 +67,14 @@ badge1.pack(padx=5, pady=5)
69
67
  badge2 = FluBadge(frame, text="FluBadge (Accent)", width=120, style="accent")
70
68
  badge2.pack(padx=5, pady=5)
71
69
 
70
+ label1 = FluLabel(frame, text="FluLabel(Hover Me)")
71
+ label1.tooltip(text="FluToolTip")
72
+ label1.pack(padx=5, pady=5)
73
+
74
+ label2 = FluLabel(frame, text="FluLabel2(Hover Me)")
75
+ label2.tooltip(text="FluToolTip2", way=1)
76
+ label2.pack(padx=5, pady=5)
77
+
72
78
  button1 = FluButton(
73
79
  frame, text="FluButton", command=lambda: print("FluButton -> Clicked")
74
80
  )
tkflu/badge.py CHANGED
@@ -51,7 +51,10 @@ class FluBadgeCanvas(DCanvas):
51
51
  create_roundrect = create_round_rectangle
52
52
 
53
53
 
54
- class FluBadge(FluBadgeCanvas, DDrawWidget):
54
+ from .tooltip import FluToolTipBase
55
+
56
+
57
+ class FluBadge(FluBadgeCanvas, DDrawWidget, FluToolTipBase):
55
58
 
56
59
  def __init__(self, *args,
57
60
  text="",
tkflu/button.py CHANGED
@@ -62,9 +62,9 @@ class FluButtonCanvas(DCanvas):
62
62
 
63
63
 
64
64
  from .constants import MODE, STATE, BUTTONSTYLE
65
+ from .tooltip import FluToolTipBase
65
66
 
66
-
67
- class FluButton(FluButtonCanvas, DDrawWidget):
67
+ class FluButton(FluButtonCanvas, DDrawWidget, FluToolTipBase):
68
68
  def __init__(self, *args,
69
69
  text="",
70
70
  width=120,
@@ -98,7 +98,7 @@ class FluButton(FluButtonCanvas, DDrawWidget):
98
98
  from .defs import set_default_font
99
99
  set_default_font(font, self.attributes)
100
100
 
101
- def _init(self, mode: MODE, style: STATE):
101
+ def _init(self, mode: MODE, style: BUTTONSTYLE):
102
102
 
103
103
  from easydict import EasyDict
104
104
 
tkflu/bwm.py CHANGED
@@ -1,4 +1,7 @@
1
- class BWm(object):
1
+ from .designs.gradient import FluGradient
2
+
3
+
4
+ class BWm(FluGradient):
2
5
  def _draw(self, event=None):
3
6
 
4
7
  """
@@ -126,6 +129,18 @@ class BWm(object):
126
129
  def _theme(self, mode):
127
130
  from .designs.window import window
128
131
  n = window(mode)
132
+ """if self.attributes.back_color is not None:
133
+ n["back_color"] = self.attributes.back_color"""
134
+
135
+ if self.dcget("back_color"):
136
+ back_colors = self.generate_hex2hex(self.dcget("back_color"), n["back_color"], steps=10)
137
+ for i in range(10):
138
+ def update(ii=i): # 使用默认参数立即捕获i的值
139
+ self.dconfigure(back_color=back_colors[ii])
140
+ self._draw()
141
+
142
+ self.after(i * 10, update) # 直接传递函数,不需要lambda
143
+
129
144
  self.dconfigure(
130
145
  back_color=n["back_color"],
131
146
  text_color=n["text_color"],
tkflu/constants.py CHANGED
@@ -18,3 +18,8 @@ STANDARD = 'standard'
18
18
  ACCENT = 'accent'
19
19
  MENU = 'menu'
20
20
  BUTTONSTYLE = Literal["standard", "accent", "menu"]
21
+
22
+ # FluFrame Styles
23
+ STANDARD = 'standard'
24
+ POPUPMENU = 'popupmenu'
25
+ FRAMESTYLE = Literal["standard", "popupmenu"]
@@ -0,0 +1 @@
1
+ # 这里没什么好东西,请不要在项目中导入,可以自行查看该文件夹中其他demo
@@ -0,0 +1,18 @@
1
+ from tkflu import *
2
+ from pywinstyles import *
3
+
4
+
5
+ root = FluWindow()
6
+
7
+ thememanager = FluThemeManager()
8
+ thememanager.mode("dark")
9
+
10
+ root.dconfigure(back_color="#000000")
11
+
12
+ btn1 = FluButton(root, text="Normal", command=lambda: apply_style(root, "normal"))
13
+ btn1.pack(padx=5, pady=5)
14
+
15
+ btn2 = FluButton(root, text="Acrylic", command=lambda: apply_style(root, "acrylic"))
16
+ btn2.pack(padx=5, pady=5)
17
+
18
+ root.mainloop()
tkflu/demos/demo1.py ADDED
@@ -0,0 +1,8 @@
1
+ from tkflu import *
2
+
3
+
4
+ root = FluWindow()
5
+
6
+ root.after(1000, lambda: root.theme("dark"))
7
+
8
+ root.mainloop()
tkflu/demos/grad.py ADDED
@@ -0,0 +1,70 @@
1
+ import matplotlib.pyplot as plt
2
+ import numpy as np
3
+
4
+
5
+ def color_gradient(color1, color2, steps=10, output_format='both'):
6
+ """
7
+ 生成颜色渐变序列
8
+ :param color1: 起始颜色 (RGB元组或HEX字符串)
9
+ :param color2: 结束颜色 (RGB元组或HEX字符串)
10
+ :param steps: 渐变步数
11
+ :param output_format: 输出格式 ('rgb', 'hex' 或 'both')
12
+ :return: 渐变颜色列表
13
+ """
14
+
15
+ # 输入格式处理
16
+ def parse_color(color):
17
+ if isinstance(color, str): # HEX格式
18
+ color = color.lstrip('#')
19
+ return tuple(int(color[i:i + 2], 16) for i in (0, 2, 4))
20
+ return color # 已经是RGB格式
21
+
22
+ rgb1 = np.array(parse_color(color1))
23
+ rgb2 = np.array(parse_color(color2))
24
+
25
+ # 生成渐变
26
+ gradient = []
27
+ for t in np.linspace(0, 1, steps):
28
+ rgb = rgb1 + (rgb2 - rgb1) * t
29
+ rgb = np.round(rgb).astype(int)
30
+ rgb_clipped = np.clip(rgb, 0, 255) # 确保在0-255范围内
31
+ gradient.append(rgb_clipped)
32
+
33
+ # 格式转换
34
+ result = []
35
+ for color in gradient:
36
+ r, g, b = color
37
+ if output_format == 'rgb':
38
+ result.append(tuple(color))
39
+ elif output_format == 'hex':
40
+ result.append(f"#{r:02x}{g:02x}{b:02x}")
41
+ else: # both
42
+ result.append({
43
+ 'rgb': tuple(color),
44
+ 'hex': f"#{r:02x}{g:02x}{b:02x}"
45
+ })
46
+
47
+ return result
48
+
49
+
50
+ # 示例使用
51
+ if __name__ == "__main__":
52
+ # 输入颜色 (支持RGB或HEX)
53
+ start_color = "#FF0000" # 红色
54
+ end_color = (0, 0, 255) # 蓝色
55
+
56
+ # 生成渐变 (20个步骤)
57
+ gradient = color_gradient(start_color, end_color, steps=20, output_format='both')
58
+
59
+ # 打印输出
60
+ print("颜色渐变序列:")
61
+ for i, color in enumerate(gradient):
62
+ print(f"{i + 1:2d}: RGB{color['rgb']} -> {color['hex']}")
63
+
64
+ # 可视化展示
65
+ plt.figure(figsize=(10, 2))
66
+ for i, color in enumerate(gradient):
67
+ plt.fill_between([i, i + 1], 0, 1, color=np.array(color['rgb']) / 255)
68
+ plt.title("Color Gradient Visualization")
69
+ plt.axis('off')
70
+ plt.show()
tkflu/demos/grad2.py ADDED
@@ -0,0 +1,140 @@
1
+ import tkinter as tk
2
+ from tkinter import ttk
3
+ import numpy as np
4
+
5
+
6
+ class GradientLabelApp:
7
+ def __init__(self, root):
8
+ self.root = root
9
+ self.root.title("Tkinter渐变标签演示")
10
+ self.root.geometry("400x200")
11
+
12
+ # 渐变控制变量
13
+ self.is_animating = False
14
+ self.current_step = 0
15
+ self.gradient_steps = 20 # 渐变步数
16
+
17
+ # 创建UI组件
18
+ self.create_widgets()
19
+
20
+ # 预生成渐变序列 (从蓝色到红色)
21
+ self.gradient = self.generate_gradient_hex(
22
+ "#ffffff",
23
+ "#005fb8",
24
+ self.gradient_steps
25
+ )
26
+
27
+ def create_widgets(self):
28
+ """创建界面组件"""
29
+ # 渐变显示标签
30
+ self.label = tk.Label(
31
+ self.root,
32
+ text="渐变背景标签",
33
+ font=('Arial', 20),
34
+ relief='raised',
35
+ borderwidth=2
36
+ )
37
+ self.label.pack(pady=20, ipadx=50, ipady=30, fill='x', padx=20)
38
+
39
+ # 控制按钮框架
40
+ button_frame = ttk.Frame(self.root)
41
+ button_frame.pack(pady=10)
42
+
43
+ # 开始按钮
44
+ self.start_button = ttk.Button(
45
+ button_frame,
46
+ text="开始渐变",
47
+ command=self.toggle_animation
48
+ )
49
+ self.start_button.pack(side='left', padx=5)
50
+
51
+ # 重置按钮
52
+ ttk.Button(
53
+ button_frame,
54
+ text="重置",
55
+ command=self.reset_animation
56
+ ).pack(side='left', padx=5)
57
+
58
+ def generate_gradient(self, start_color, end_color, steps):
59
+ """生成颜色渐变序列"""
60
+ gradient = []
61
+ for t in np.linspace(0, 1, steps):
62
+ r = int(start_color[0] + (end_color[0] - start_color[0]) * t)
63
+ g = int(start_color[1] + (end_color[1] - start_color[1]) * t)
64
+ b = int(start_color[2] + (end_color[2] - start_color[2]) * t)
65
+ gradient.append(f"#{r:02x}{g:02x}{b:02x}")
66
+ return gradient
67
+
68
+ def generate_gradient_hex(self, start_hex, end_hex, steps):
69
+ """
70
+ 专为HEX颜色设计的渐变生成器
71
+ :param start_hex: 起始颜色 HEX格式 (如 "#FF0000")
72
+ :param end_hex: 结束颜色 HEX格式 (如 "#0000FF")
73
+ :param steps: 渐变步数
74
+ :return: HEX格式的颜色列表
75
+ """
76
+
77
+ # 去除#号并转换为RGB元组
78
+ def hex_to_rgb(h):
79
+ h = h.lstrip('#')
80
+ return tuple(int(h[i:i + 2], 16) for i in (0, 2, 4))
81
+
82
+ # RGB转HEX
83
+ def rgb_to_hex(rgb):
84
+ return f"#{rgb[0]:02x}{rgb[1]:02x}{rgb[2]:02x}"
85
+
86
+ rgb_start = hex_to_rgb(start_hex)
87
+ rgb_end = hex_to_rgb(end_hex)
88
+
89
+ gradient = []
90
+ for t in np.linspace(0, 1, steps):
91
+ # 计算每个通道的中间值
92
+ r = int(rgb_start[0] + (rgb_end[0] - rgb_start[0]) * t)
93
+ g = int(rgb_start[1] + (rgb_end[1] - rgb_start[1]) * t)
94
+ b = int(rgb_start[2] + (rgb_end[2] - rgb_start[2]) * t)
95
+
96
+ # 确保值在0-255范围内并转换为HEX
97
+ gradient.append(rgb_to_hex((
98
+ max(0, min(255, r)),
99
+ max(0, min(255, g)),
100
+ max(0, min(255, b))
101
+ )))
102
+
103
+ return gradient
104
+
105
+ def toggle_animation(self):
106
+ """切换动画状态"""
107
+ self.is_animating = not self.is_animating
108
+ self.start_button.config(
109
+ text="停止渐变" if self.is_animating else "开始渐变"
110
+ )
111
+ if self.is_animating:
112
+ self.animate_gradient()
113
+
114
+ def animate_gradient(self):
115
+ """执行渐变动画"""
116
+ if not self.is_animating:
117
+ return
118
+
119
+ # 更新标签背景色
120
+ color = self.gradient[self.current_step]
121
+ self.label.config(background=color)
122
+
123
+ # 更新步进
124
+ self.current_step = (self.current_step + 1) % len(self.gradient)
125
+
126
+ # 50ms后继续下一帧 (约20FPS)
127
+ self.root.after(50, self.animate_gradient)
128
+
129
+ def reset_animation(self):
130
+ """重置动画状态"""
131
+ self.is_animating = False
132
+ self.current_step = 0
133
+ self.start_button.config(text="开始渐变")
134
+ self.label.config(background='SystemButtonFace') # 恢复默认背景色
135
+
136
+
137
+ if __name__ == "__main__":
138
+ root = tk.Tk()
139
+ app = GradientLabelApp(root)
140
+ root.mainloop()
tkflu/demos/grad3.py ADDED
@@ -0,0 +1,22 @@
1
+ from tkflu import *
2
+
3
+
4
+ root = FluWindow()
5
+
6
+ theme_manager = FluThemeManager(root)
7
+
8
+ menubar = FluMenuBar(root)
9
+ menubar.add_command(label="Item1", width=80, command=lambda: print("FluMenu1 -> Clicked"))
10
+ menubar.show()
11
+
12
+ button = FluToggleButton(
13
+ text="Toggle Theme", command=lambda: toggle_theme(button, theme_manager)
14
+ )
15
+ button.pack(padx=3, pady=3, )
16
+
17
+ button2 = FluToggleButton(
18
+ text="Toggle Button"
19
+ )
20
+ button2.pack(padx=3, pady=3, )
21
+
22
+ root.mainloop()
tkflu/demos/test.py ADDED
@@ -0,0 +1,8 @@
1
+ import numpy as np
2
+
3
+ float1 = 1.0
4
+ float2 = 5.0
5
+ steps = 10 # 生成 10 个点
6
+
7
+ floats = np.linspace(float1, float2, steps).tolist()
8
+ print(floats)
tkflu/demos/tooltip.py ADDED
@@ -0,0 +1,13 @@
1
+ from tkflu import *
2
+
3
+
4
+ root = FluWindow()
5
+
6
+ thememanager = FluThemeManager(root, mode="light")
7
+
8
+ button = FluButton(root, text="Click me", command=lambda: print("Clicked"), style="standard")
9
+ button.pack()
10
+
11
+ tooltip = FluToolTip(button, text="This is a tooltip")
12
+
13
+ root.mainloop()
@@ -0,0 +1,54 @@
1
+ class FluGradient:
2
+ def hex_to_rgb(self, h: str):
3
+ h = h.lstrip('#')
4
+ return tuple(int(h[i:i + 2], 16) for i in (0, 2, 4))
5
+
6
+ def rgb_to_hex(self, rgb):
7
+ return f"#{rgb[0]:02x}{rgb[1]:02x}{rgb[2]:02x}"
8
+
9
+ def generate_rgb2hex(self, start_color, end_color, steps):
10
+ """生成颜色渐变序列"""
11
+ import numpy as np
12
+ gradient = []
13
+ for t in np.linspace(0, 1, steps):
14
+ r = int(start_color[0] + (end_color[0] - start_color[0]) * t)
15
+ g = int(start_color[1] + (end_color[1] - start_color[1]) * t)
16
+ b = int(start_color[2] + (end_color[2] - start_color[2]) * t)
17
+ gradient.append(f"#{r:02x}{g:02x}{b:02x}")
18
+ return gradient
19
+
20
+ def generate_hex2hex(self, start_hex, end_hex, steps):
21
+ """
22
+ 专为HEX颜色设计的渐变生成器
23
+ :param start_hex: 起始颜色 HEX格式 (如 "#FF0000")
24
+ :param end_hex: 结束颜色 HEX格式 (如 "#0000FF")
25
+ :param steps: 渐变步数
26
+ :return: HEX格式的颜色列表
27
+ """
28
+
29
+ # 去除#号并转换为RGB元组
30
+
31
+ # RGB转HEX
32
+
33
+ rgb_start = self.hex_to_rgb(start_hex)
34
+ rgb_end = self.hex_to_rgb(end_hex)
35
+ import numpy as np
36
+ gradient = []
37
+ for t in np.linspace(0, 1, steps):
38
+ # 计算每个通道的中间值
39
+ r = int(rgb_start[0] + (rgb_end[0] - rgb_start[0]) * t)
40
+ g = int(rgb_start[1] + (rgb_end[1] - rgb_start[1]) * t)
41
+ b = int(rgb_start[2] + (rgb_end[2] - rgb_start[2]) * t)
42
+
43
+ # 确保值在0-255范围内并转换为HEX
44
+ gradient.append(
45
+ self.rgb_to_hex(
46
+ (
47
+ max(0, min(255, r)),
48
+ max(0, min(255, g)),
49
+ max(0, min(255, b))
50
+ )
51
+ )
52
+ )
53
+
54
+ return gradient
@@ -0,0 +1,13 @@
1
+ from .primary_color import get_primary_color
2
+
3
+
4
+ def menubar(mode):
5
+ mode = mode.lower()
6
+ if mode == "light":
7
+ return {
8
+ "back_color": "#f3f3f3",
9
+ }
10
+ else:
11
+ return {
12
+ "back_color": "#202020",
13
+ }
@@ -0,0 +1,15 @@
1
+ def tooltip(mode):
2
+ if mode.lower() == "light":
3
+ return {
4
+ "back_color": "#e2e2e2",
5
+ "text_color": "#000000",
6
+ "frame_color": "#F9F9F9",
7
+ "frame_border_color": "#ebebeb"
8
+ }
9
+ else:
10
+ return {
11
+ "back_color": "#1a1a1a",
12
+ "text_color": "#ffffff",
13
+ "frame_color": "#2f2f2f",
14
+ "frame_border_color": "#161616"
15
+ }
tkflu/entry.py CHANGED
@@ -71,7 +71,10 @@ class FluEntryCanvas(DCanvas):
71
71
  create_roundrect = create_round_rectangle
72
72
 
73
73
 
74
- class FluEntry(FluEntryCanvas, DDrawWidget):
74
+ from .tooltip import FluToolTipBase
75
+
76
+
77
+ class FluEntry(FluEntryCanvas, DDrawWidget, FluToolTipBase):
75
78
  def __init__(self, *args,
76
79
  width=120,
77
80
  height=32,
tkflu/frame.py CHANGED
@@ -188,6 +188,8 @@ class FluFrame(Frame, DObject):
188
188
  border_width=n["border_width"],
189
189
  radius=n["radius"],
190
190
  )
191
+ self._draw()
192
+ self.canvas.update()
191
193
 
192
194
  def _light(self):
193
195
  self._theme("light", "standard")
tkflu/label.py CHANGED
@@ -1,7 +1,8 @@
1
1
  from tkdeft.windows.drawwidget import DDrawWidget
2
+ from .tooltip import FluToolTipBase
2
3
 
3
4
 
4
- class FluLabel(DDrawWidget):
5
+ class FluLabel(DDrawWidget, FluToolTipBase):
5
6
  def __init__(self, *args,
6
7
  text="",
7
8
  width=120,
tkflu/menu.py CHANGED
@@ -1,8 +1,9 @@
1
1
  from .popupmenu import FluPopupMenu
2
2
  from tkdeft.object import DObject
3
+ from .tooltip import FluToolTipBase
3
4
 
4
5
 
5
- class FluMenu(FluPopupMenu):
6
+ class FluMenu(FluPopupMenu, FluToolTipBase):
6
7
  def __init__(self, *args, **kwargs):
7
8
  super().__init__(*args, **kwargs)
8
9
 
@@ -85,7 +86,7 @@ class FluMenu(FluPopupMenu):
85
86
  id = widget._w
86
87
 
87
88
  def command(event=None):
88
- print(menu._w)
89
+ #print(menu._w)
89
90
 
90
91
  menu.popup(widget.winfo_rootx()+widget.winfo_width()+100, widget.winfo_rooty())
91
92
  menu.window.deiconify()
tkflu/menubar.py CHANGED
@@ -1,8 +1,9 @@
1
1
  from tkinter import Frame, Menu
2
2
  from tkdeft.object import DObject
3
+ from .designs.gradient import FluGradient
3
4
 
4
5
 
5
- class FluMenuBar(Frame, DObject):
6
+ class FluMenuBar(Frame, DObject, FluGradient):
6
7
  def __init__(self, *args, mode="light", height=40, **kwargs):
7
8
  self._init(mode)
8
9
 
@@ -26,6 +27,9 @@ class FluMenuBar(Frame, DObject):
26
27
 
27
28
  self.theme(mode=mode)
28
29
 
30
+ def show(self):
31
+ self.pack(fill="x")
32
+
29
33
  def add_command(self, custom_widget=None, width=40, **kwargs):
30
34
  if custom_widget:
31
35
  widget = custom_widget(self)
@@ -103,6 +107,16 @@ class FluMenuBar(Frame, DObject):
103
107
  def action(self, id):
104
108
  return self.dcget("actions")[id]
105
109
 
110
+ def update_children(self):
111
+ actions = self.dcget("actions")
112
+ for key in actions:
113
+ widget = actions[key]
114
+ if hasattr(widget, "theme"):
115
+ widget.theme(mode=self.mode)
116
+ if hasattr(widget, "_draw"):
117
+ widget._draw()
118
+ widget.update()
119
+
106
120
  def theme(self, mode="light"):
107
121
  self.theme_myself(mode=mode)
108
122
 
@@ -116,22 +130,30 @@ class FluMenuBar(Frame, DObject):
116
130
  widget._draw()
117
131
  widget.update()
118
132
 
119
- def theme_myself(self, mode="light"):
133
+ def theme_myself(self, mode="light", animate_steps: int = 10):
134
+ from .designs.menubar import menubar
135
+ m = menubar(mode)
120
136
  self.mode = mode
121
137
  if mode.lower() == "dark":
122
- self._dark()
138
+ if hasattr(self, "tk"):
139
+ back_colors = self.generate_hex2hex(self.attributes.back_color, m["back_color"], steps=10)
140
+ for i in range(10):
141
+ def update(ii=i): # 使用默认参数立即捕获i的值
142
+ self.dconfigure(back_color=back_colors[ii])
143
+ self._draw()
144
+
145
+ self.after(i * 10, update) # 直接传递函数,不需要lambda
146
+ self.after(animate_steps*10+50, lambda: self.update_children())
123
147
  else:
124
- self._light()
148
+ if hasattr(self, "tk"):
149
+ back_colors = self.generate_hex2hex(self.attributes.back_color, m["back_color"], steps=10)
150
+ for i in range(10):
151
+ def update(ii=i): # 使用默认参数立即捕获i的值
152
+ self.dconfigure(back_color=back_colors[ii])
153
+ self._draw()
125
154
 
126
- def _light(self):
127
- self.dconfigure(
128
- back_color="#f3f3f3"
129
- )
155
+ self.after(i * 20, update) # 直接传递函数,不需要lambda
130
156
 
131
- def _dark(self):
132
- self.dconfigure(
133
- back_color="#202020"
134
- )
135
157
 
136
158
  def _draw(self, event=None):
137
159
  self.config(background=self.attributes.back_color)
tkflu/popupwindow.py CHANGED
@@ -2,16 +2,17 @@ from tkinter import Toplevel
2
2
 
3
3
 
4
4
  class FluPopupWindow(Toplevel):
5
- def __init__(self, *args, transparent_color="#ebebeb", mode="light", width=100, height=46, **kwargs):
5
+ def __init__(self, *args, transparent_color="#ebebeb", mode="light", width=100, height=46, custom=True, **kwargs):
6
6
  super().__init__(*args, background=transparent_color, **kwargs)
7
7
 
8
8
  self.theme(mode=mode)
9
9
 
10
10
  self.geometry(f"{width}x{height}")
11
11
 
12
- self.transient_color = transparent_color
13
- self.overrideredirect(True)
14
- self.attributes("-transparentcolor", transparent_color)
12
+ if custom:
13
+ self.transient_color = transparent_color
14
+ self.overrideredirect(True)
15
+ self.wm_attributes("-transparentcolor", transparent_color)
15
16
 
16
17
  self.withdraw()
17
18
 
@@ -22,6 +23,7 @@ class FluPopupWindow(Toplevel):
22
23
 
23
24
  def popup(self, x, y):
24
25
  self.geometry(f"+{x}+{y}")
26
+ #self.focus_set()
25
27
 
26
28
  def theme(self, mode=None):
27
29
  if mode: