完成scrollbar的拖动行为(暂未绑定滚轮事件)
Build and Publish / Run (push) Successful in 48s
Details
Build and Publish / Run (push) Successful in 48s
Details
This commit is contained in:
parent
548c3a5315
commit
c860771118
6
debug.py
6
debug.py
|
@ -85,8 +85,8 @@ if __name__ == "__main__":
|
||||||
magictk.Entry(frame7, w=200).pack(side='left')
|
magictk.Entry(frame7, w=200).pack(side='left')
|
||||||
frame7.pack()
|
frame7.pack()
|
||||||
|
|
||||||
frame8 = magictk.Container(win, h=10, container_h=30*6*5)
|
frame8 = magictk.Container(win, h=100, container_h=30*6*2)
|
||||||
for i in range(5):
|
for i in range(2):
|
||||||
magictk.Button(frame8, text="Default",
|
magictk.Button(frame8, text="Default",
|
||||||
func=lambda s: print("Btn 1")).pack()
|
func=lambda s: print("Btn 1")).pack()
|
||||||
magictk.ButtonFill(frame8, text="Primary",
|
magictk.ButtonFill(frame8, text="Primary",
|
||||||
|
@ -99,6 +99,6 @@ if __name__ == "__main__":
|
||||||
func=lambda s: print("Btn 5")).pack()
|
func=lambda s: print("Btn 5")).pack()
|
||||||
magictk.ButtonFill(frame8, color_type="danger", text="Danger",
|
magictk.ButtonFill(frame8, color_type="danger", text="Danger",
|
||||||
func=lambda s: print("Btn 6")).pack()
|
func=lambda s: print("Btn 6")).pack()
|
||||||
frame8.pack()
|
frame8.pack(expand="y")
|
||||||
|
|
||||||
win.mainloop()
|
win.mainloop()
|
||||||
|
|
|
@ -21,17 +21,42 @@ class Container(Frame):
|
||||||
def scroll_callback(self, obj, pos):
|
def scroll_callback(self, obj, pos):
|
||||||
super().place(x=0, y=-pos, w=self.w-7, h=self.container_h)
|
super().place(x=0, y=-pos, w=self.w-7, h=self.container_h)
|
||||||
|
|
||||||
|
def update_frame(self, *args, **kwargs):
|
||||||
|
self.w = self.root_frame.winfo_width()
|
||||||
|
self.h = self.root_frame.winfo_height()
|
||||||
|
# if (self.h >= self.container_h-2):
|
||||||
|
# # self.scroll.scroll_y = 0
|
||||||
|
# # self.scroll.update_pos()
|
||||||
|
# # self.scroll.place_forget()
|
||||||
|
# pass
|
||||||
|
# else:
|
||||||
|
super().place(x=0, y=-self.scroll.get(), w=self.w-7, h=self.container_h)
|
||||||
|
self.scroll._r_allh = self.container_h
|
||||||
|
self.scroll._r_maxh = self.h
|
||||||
|
self.scroll.place(x=self.w-7, y=0, w=8, relheight=1)
|
||||||
|
self.scroll.h = self.h
|
||||||
|
scrolltmp = self.scroll.scroll_y*self.scroll.y_size
|
||||||
|
self.scroll.cal_bar()
|
||||||
|
self.scroll.update_pos()
|
||||||
|
if (self.scroll.y_size==0):
|
||||||
|
self.scroll.scroll_y=0
|
||||||
|
else:
|
||||||
|
self.scroll.scroll_y = min(self.scroll.h-self.scroll.bar_len,
|
||||||
|
max(0, scrolltmp/self.scroll.y_size))
|
||||||
|
|
||||||
def __init__(self, master, color=None, w=300, h=200, container_h=500, *args, **kwargs):
|
def __init__(self, master, color=None, w=300, h=200, container_h=500, *args, **kwargs):
|
||||||
self.root = master.root
|
self.root = master.root
|
||||||
self.w = w
|
self.w = w
|
||||||
self.h = h
|
self.h = h
|
||||||
self.container_h = container_h
|
self.container_h = container_h
|
||||||
self.root_frame = Frame(master, width=w, height=h)
|
self.root_frame = Frame(master, width=w, height=self.container_h)
|
||||||
super().__init__(self.root_frame, *args, **kwargs)
|
super().__init__(self.root_frame, *args, **kwargs)
|
||||||
super().place(x=0, y=0, w=self.w-7, h=container_h)
|
super().place(x=0, y=0, w=self.w-7, h=container_h)
|
||||||
self.scroll = ScrollBar(self.root_frame,
|
self.scroll = ScrollBar(self.root_frame,
|
||||||
h=self.h, allh=self.container_h-self.h, maxh=self.h, callback=self.scroll_callback)
|
h=self.h, allh=self.container_h, maxh=self.h, callback=self.scroll_callback)
|
||||||
self.scroll.place(x=self.w-7, y=0, w=8, relheight=1)
|
self.scroll.place(x=self.w-7, y=0, w=8, relheight=1)
|
||||||
|
self.root_frame.bind("<Configure>", self.update_frame)
|
||||||
|
# self.configure
|
||||||
|
|
||||||
def pack(self, *args, **kwargs):
|
def pack(self, *args, **kwargs):
|
||||||
self.root_frame.pack(*args, **kwargs)
|
self.root_frame.pack(*args, **kwargs)
|
||||||
|
|
|
@ -15,10 +15,15 @@ class ScrollBar:
|
||||||
scroll_y = 0
|
scroll_y = 0
|
||||||
y_size = 1.0
|
y_size = 1.0
|
||||||
bar_len = 100
|
bar_len = 100
|
||||||
|
_dis_event = False
|
||||||
|
|
||||||
def cal_bar(self):
|
def cal_bar(self):
|
||||||
self.bar_len = max(self.h*self._r_maxh//self._r_allh, 20)
|
self.bar_len = self._r_maxh*self.h//self._r_allh
|
||||||
self.y_size = self._r_allh/(self.h-self.bar_len)
|
if (self.h-self.bar_len == 0):
|
||||||
|
self.y_size = 0
|
||||||
|
else:
|
||||||
|
self.bar_len = max(20, self.bar_len)
|
||||||
|
self.y_size = (self._r_allh-self._r_maxh)/(self.h-self.bar_len)
|
||||||
|
|
||||||
def __draw_corner(self, r_x, r_y, x, y, colors="#000000", rid="", bgcolor=None, **kwargs):
|
def __draw_corner(self, r_x, r_y, x, y, colors="#000000", rid="", bgcolor=None, **kwargs):
|
||||||
if bgcolor is None:
|
if bgcolor is None:
|
||||||
|
@ -33,12 +38,16 @@ class ScrollBar:
|
||||||
for j in i:
|
for j in i:
|
||||||
if (r_x == 0):
|
if (r_x == 0):
|
||||||
px = x+x_n+1
|
px = x+x_n+1
|
||||||
|
zpx = x_n+1
|
||||||
else:
|
else:
|
||||||
px = x+6-x_n
|
px = x+6-x_n
|
||||||
|
zpx = 6-x_n
|
||||||
if (r_y == 0):
|
if (r_y == 0):
|
||||||
py = y+y_n+1
|
py = y+y_n+1
|
||||||
|
zpy = y_n+1
|
||||||
else:
|
else:
|
||||||
py = y+3-y_n-1
|
py = y+3-y_n-1
|
||||||
|
zpy = 3-y_n-1
|
||||||
if (j < 0):
|
if (j < 0):
|
||||||
lcolor = -j
|
lcolor = -j
|
||||||
else:
|
else:
|
||||||
|
@ -52,7 +61,7 @@ class ScrollBar:
|
||||||
px, py, px, py, width=0, fill=g_color)
|
px, py, px, py, width=0, fill=g_color)
|
||||||
|
|
||||||
self.__fill_obj[rid].append(obj)
|
self.__fill_obj[rid].append(obj)
|
||||||
self.__fill_obj[rid+"_pos"].append([px, py])
|
self.__fill_obj[rid+"_pos"].append([zpx, zpy])
|
||||||
self.__fill_obj[rid+"_pos2"].append([y_n, x_n])
|
self.__fill_obj[rid+"_pos2"].append([y_n, x_n])
|
||||||
|
|
||||||
x_n += 1
|
x_n += 1
|
||||||
|
@ -86,12 +95,21 @@ class ScrollBar:
|
||||||
def pack(self, *args, **kwargs):
|
def pack(self, *args, **kwargs):
|
||||||
self.canvas.pack(*args, **kwargs)
|
self.canvas.pack(*args, **kwargs)
|
||||||
|
|
||||||
|
def pack_forget(self, *args, **kwargs):
|
||||||
|
self.canvas.pack_forget(*args, **kwargs)
|
||||||
|
|
||||||
def grid(self, *args, **kwargs):
|
def grid(self, *args, **kwargs):
|
||||||
self.canvas.grid(*args, **kwargs)
|
self.canvas.grid(*args, **kwargs)
|
||||||
|
|
||||||
|
def grid_forget(self, *args, **kwargs):
|
||||||
|
self.canvas.grid_forget(*args, **kwargs)
|
||||||
|
|
||||||
def place(self, *args, **kwargs):
|
def place(self, *args, **kwargs):
|
||||||
self.canvas.place(*args, **kwargs)
|
self.canvas.place(*args, **kwargs)
|
||||||
|
|
||||||
|
def place_forget(self, *args, **kwargs):
|
||||||
|
self.canvas.place_forget(*args, **kwargs)
|
||||||
|
|
||||||
def update_pos(self):
|
def update_pos(self):
|
||||||
for i in range(len(self.__fill_obj["upside"])):
|
for i in range(len(self.__fill_obj["upside"])):
|
||||||
self.canvas.coords(
|
self.canvas.coords(
|
||||||
|
@ -100,15 +118,26 @@ class ScrollBar:
|
||||||
self.__fill_obj["fgbar"][0], 1, 4+self.scroll_y, self.w-1, self.scroll_y+self.bar_len-4+1)
|
self.__fill_obj["fgbar"][0], 1, 4+self.scroll_y, self.w-1, self.scroll_y+self.bar_len-4+1)
|
||||||
for i in range(len(self.__fill_obj["bottomside"])):
|
for i in range(len(self.__fill_obj["bottomside"])):
|
||||||
self.canvas.coords(
|
self.canvas.coords(
|
||||||
self.__fill_obj["bottomside"][i], int(self.__fill_obj["bottomside_pos"][i][0]), self.__fill_obj["bottomside_pos"][i][1]+self.scroll_y, int(self.__fill_obj["bottomside_pos"][i][0]), self.__fill_obj["bottomside_pos"][i][1]+self.scroll_y)
|
self.__fill_obj["bottomside"][i], int(self.__fill_obj["bottomside_pos"][i][0]), self.__fill_obj["bottomside_pos"][i][1]+self.scroll_y+self.bar_len-5, int(self.__fill_obj["bottomside_pos"][i][0]), self.__fill_obj["bottomside_pos"][i][1]+self.scroll_y+self.bar_len-5)
|
||||||
|
|
||||||
def bind_event(self):
|
def bind_event(self):
|
||||||
|
def mouse_move(event: tkinter.Event):
|
||||||
|
if (not self._dis_event):
|
||||||
|
delta_y = event.y-self.scroll_y
|
||||||
|
self.scroll_y = min(self.h-self.bar_len,
|
||||||
|
max(0, self.scroll_y+delta_y-self.move_start))
|
||||||
|
self.callback(self, self.get())
|
||||||
|
self.update_pos()
|
||||||
|
|
||||||
def mouse_press(event: tkinter.Event):
|
def mouse_press(event: tkinter.Event):
|
||||||
|
if (not self._dis_event):
|
||||||
|
flag = False
|
||||||
if (event.y >= self.scroll_y and event.y <= self.scroll_y+self.bar_len):
|
if (event.y >= self.scroll_y and event.y <= self.scroll_y+self.bar_len):
|
||||||
pass
|
pass
|
||||||
else:
|
else:
|
||||||
self.scroll_y = min(self.h-self.bar_len,
|
self.scroll_y = min(self.h-self.bar_len,
|
||||||
max(0, event.y-self.bar_len//2))
|
max(0, event.y-self.bar_len//2))
|
||||||
|
flag = True
|
||||||
self.move_start = event.y-self.scroll_y
|
self.move_start = event.y-self.scroll_y
|
||||||
for i in range(len(self.__fill_obj["upside"])):
|
for i in range(len(self.__fill_obj["upside"])):
|
||||||
self.canvas.itemconfig(
|
self.canvas.itemconfig(
|
||||||
|
@ -120,16 +149,12 @@ class ScrollBar:
|
||||||
self.canvas.itemconfig(
|
self.canvas.itemconfig(
|
||||||
self.__fill_obj["bottomside"][i], fill=color_tmpl.mix_color(
|
self.__fill_obj["bottomside"][i], fill=color_tmpl.mix_color(
|
||||||
self.color["background"], self.color["border_base"], int((1-self.border_info[self.__fill_obj["bottomside_pos2"][i][0]][self.__fill_obj["bottomside_pos2"][i][1]]/255)*1000)/1000))
|
self.color["background"], self.color["border_base"], int((1-self.border_info[self.__fill_obj["bottomside_pos2"][i][0]][self.__fill_obj["bottomside_pos2"][i][1]]/255)*1000)/1000))
|
||||||
|
if (flag):
|
||||||
self.update_pos()
|
self.update_pos()
|
||||||
|
mouse_move(event)
|
||||||
def mouse_move(event: tkinter.Event):
|
|
||||||
delta_y = event.y-self.scroll_y
|
|
||||||
self.scroll_y = min(self.h-self.bar_len,
|
|
||||||
max(0, self.scroll_y+delta_y-self.move_start))
|
|
||||||
self.callback(self, self.get())
|
|
||||||
self.update_pos()
|
|
||||||
|
|
||||||
def mouse_release(event: tkinter.Event):
|
def mouse_release(event: tkinter.Event):
|
||||||
|
if (not self._dis_event):
|
||||||
for i in range(len(self.__fill_obj["upside"])):
|
for i in range(len(self.__fill_obj["upside"])):
|
||||||
self.canvas.itemconfig(
|
self.canvas.itemconfig(
|
||||||
self.__fill_obj["upside"][i], fill=color_tmpl.mix_color(
|
self.__fill_obj["upside"][i], fill=color_tmpl.mix_color(
|
||||||
|
@ -155,6 +180,6 @@ class ScrollBar:
|
||||||
|
|
||||||
def get(self):
|
def get(self):
|
||||||
if (self.scroll_y+self.bar_len >= self.h):
|
if (self.scroll_y+self.bar_len >= self.h):
|
||||||
return self._r_allh
|
return self._r_allh-self._r_maxh
|
||||||
else:
|
else:
|
||||||
return int(min(self.scroll_y*self.y_size, self._r_allh))
|
return int(min(self.scroll_y*self.y_size, self._r_allh))
|
||||||
|
|
Loading…
Reference in New Issue