Форум программистов, компьютерный форум, киберфорум
Python: Tkinter
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.88/34: Рейтинг темы: голосов - 34, средняя оценка - 4.88
1 / 1 / 0
Регистрация: 15.11.2019
Сообщений: 12

Сворачивание/разворачивание элементов окна

31.05.2020, 17:28. Показов 7725. Ответов 7

Студворк — интернет-сервис помощи студентам
Здравствуйте!

Есть код:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
from tkinter import Menu, Frame, Label, Tk, W
from tkinter.ttk import Combobox
root = Tk()
root.title("qwerty")
root.geometry("800x750")
 
main_menu = Menu()
 
frame = Frame()
frame.grid()
 
Label(root, text='Название').grid(row=0, sticky=W)
Label(root, text='Выбор').grid(row=0, column=1, sticky=W)
Label(root, text='A').grid(row=0, column=2, sticky=W)
Label(root, text='B').grid(row=0, column=3, sticky=W)
 
Label(root, text='Название 1').grid(row=1, sticky=W)
Label(root, text='Название 2').grid(row=2, sticky=W)
Label(root, text='Название 3').grid(row=3, sticky=W)
Label(root, text='Название 4').grid(row=4, sticky=W)
 
combo = Combobox(root)
combo['values'] = (1, 2, 3, 4, 5)
combo.current(0)
combo.grid(column=1, row=1)
 
combo2 = Combobox(root)
combo2['values'] = ('a', 'b', 'c', 'd', 'e')
combo2.current(0)
combo2.grid(column=1, row=2)
 
combo3 = Combobox(root)
combo3['values'] = ('a', 'b', 'c', 'd', 'e')
combo3.current(0)
combo3.grid(column=1, row=3)
 
combo4 = Combobox(root)
combo4['values'] = ('a', 'b', 'c', 'd', 'e')
combo4.current(0)
combo4.grid(column=1, row=4)
 
 
Label(root, text='value_1_1').grid(row=1, column=2, sticky=W)
Label(root, text='value_1_2').grid(row=1, column=3, sticky=W)
Label(root, text='value_2_1').grid(row=2, column=2, sticky=W)
Label(root, text='value_2_2').grid(row=2, column=3, sticky=W)
Label(root, text='value_3_1').grid(row=3, column=2, sticky=W)
Label(root, text='value_3_2').grid(row=3, column=3, sticky=W)
Label(root, text='value_4_1').grid(row=4, column=2, sticky=W)
Label(root, text='value_4_2').grid(row=4, column=3, sticky=W)
 
 
root.config(menu=main_menu)
 
root.mainloop()
При его запуске получается результат, который можно видеть на первой картинке.

Я хочу, чтобы все элементы можно было свернуть/развернуть одним нажатием на стрелку, примерно, как на второй картинке во вложении. Как это организовать?

И ещё один вопрос, чтобы не создавать лишнюю тему.
Когда я искал в интернете ответ на свой первый вопрос, то встречал мнение, что библиотека tkinter в нынешнее время почти не используется, а вместо неё лучше использовать pyqt5. Это действительно так? Стоит ли тратить время на изучение tkinter или лучше сперва обратить внимание на pyqt?
Миниатюры
Сворачивание/разворачивание элементов окна   Сворачивание/разворачивание элементов окна  
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
31.05.2020, 17:28
Ответы с готовыми решениями:

Pygame, сворачивание и разворачивание окна
Добрый день помогите в следующем вопросе. Есть иконка по которой если нажать откроется окно с другими иконками(типо список возможных...

Запретить закрытие, сворачивание, разворачивание окна
Здравствуйте, возникла необходимость создать окно, которое нельзя будет закрыть, свернуть или развернуть при помощи кнопок. Кнопки я скрыл,...

Разворачивание / сворачивание окна при нажатии на кнопку
При нажатии на кнопку программа должна разворачивать экран в полный размер, а при втором нажатии брать исходный размер. Делаю вот так, но...

7
║XLR8║
 Аватар для outoftime
1212 / 909 / 270
Регистрация: 25.07.2009
Сообщений: 4,360
Записей в блоге: 5
31.05.2020, 23:26
-Azan-, tkinter поставляется с python, всё остальное это "сторонние" библиотеки. На этом строятся все плюсы и минусы.

Полагаю, вы ищите это http://effbot.org/tkinterbook/frame.html
When to use the Frame Widget
Frame widgets are used to group other widgets into complex layouts.
0
1 / 1 / 0
Регистрация: 15.11.2019
Сообщений: 12
01.06.2020, 23:26  [ТС]
outoftime, спасибо за ссылку, но это не совсем то что я хочу получить. Вы предлагаете сделать кнопку примерно вот так:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
from tkinter import Menu, Frame, Label, Tk, W, N, E, LabelFrame, Button
from tkinter.ttk import Combobox
root = Tk()
root.title("qwerty")
root.geometry("800x750")
 
main_menu = Menu()
 
frame = Frame()
frame.grid()
Label(root, text='Выбор параметров').grid(row=0, sticky=W)
bottomframe = Frame(root)
bottomframe.grid(row=1, column=0, sticky=N)
 
 
def bth():
    bottomframe.grid_remove()
    btn.config(text='Показать')
    btn.config(command=bth2)
 
 
def bth2():
    bottomframe.grid()
    btn.config(text='Скрыть')
    btn.config(command=bth)
 
 
btn = Button(root, text='Скрыть', command=bth)
btn.grid(row=0, column=1, sticky=N+E)
 
Label(bottomframe, text='Название').grid(row=0, sticky=W)
Label(bottomframe, text='Выбор').grid(row=0, column=1, sticky=W)
Label(bottomframe, text='A').grid(row=0, column=2, sticky=W)
Label(bottomframe, text='B').grid(row=0, column=3, sticky=W)
 
Label(bottomframe, text='Название 1').grid(row=1, sticky=W)
Label(bottomframe, text='Название 2').grid(row=2, sticky=W)
Label(bottomframe, text='Название 3').grid(row=3, sticky=W)
Label(bottomframe, text='Название 4').grid(row=4, sticky=W)
 
combo = Combobox(bottomframe)
combo['values'] = (1, 2, 3, 4, 5)
combo.current(0)
combo.grid(column=1, row=1)
 
combo2 = Combobox(bottomframe)
combo2['values'] = ('a', 'b', 'c', 'd', 'e')
combo2.current(0)
combo2.grid(column=1, row=2)
 
combo3 = Combobox(bottomframe)
combo3['values'] = ('a', 'b', 'c', 'd', 'e')
combo3.current(0)
combo3.grid(column=1, row=3)
 
combo4 = Combobox(bottomframe)
combo4['values'] = ('a', 'b', 'c', 'd', 'e')
combo4.current(0)
combo4.grid(column=1, row=4)
 
 
Label(bottomframe, text='value_1_1').grid(row=1, column=2, sticky=W)
Label(bottomframe, text='value_1_2').grid(row=1, column=3, sticky=W)
Label(bottomframe, text='value_2_1').grid(row=2, column=2, sticky=W)
Label(bottomframe, text='value_2_2').grid(row=2, column=3, sticky=W)
Label(bottomframe, text='value_3_1').grid(row=3, column=2, sticky=W)
Label(bottomframe, text='value_3_2').grid(row=3, column=3, sticky=W)
Label(bottomframe, text='value_4_1').grid(row=4, column=2, sticky=W)
Label(bottomframe, text='value_4_2').grid(row=4, column=3, sticky=W)
 
 
root.config(menu=main_menu)
 
root.mainloop()
Результат работы можно видеть на первой и пятой картинках во вложении.

Ну или так, если использовать LabelFrame:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
from tkinter import Menu, Frame, Label, Tk, W, N, E, LabelFrame, Button
from tkinter.ttk import Combobox
root = Tk()
root.title("qwerty")
root.geometry("800x750")
 
main_menu = Menu()
 
frame = Frame()
frame.grid()
 
label_frame = LabelFrame(root, text='Выбрать параметры')
label_frame.grid(row=0, column=0, sticky=N)
 
 
def bth():
    label_frame.grid_remove()
    btn.config(text='Показать')
    btn.config(command=bth2)
 
 
def bth2():
    label_frame.grid()
    btn.config(text='Скрыть')
    btn.config(command=bth)
 
 
btn = Button(root, text='Скрыть', highlightthickness=1, command=bth)
btn.grid()
 
Label(label_frame, text='Название').grid(row=0, sticky=W)
Label(label_frame, text='Выбор').grid(row=0, column=1, sticky=W)
Label(label_frame, text='A').grid(row=0, column=2, sticky=W)
Label(label_frame, text='B').grid(row=0, column=3, sticky=W)
 
Label(label_frame, text='Название 1').grid(row=1, sticky=W)
Label(label_frame, text='Название 2').grid(row=2, sticky=W)
Label(label_frame, text='Название 3').grid(row=3, sticky=W)
Label(label_frame, text='Название 4').grid(row=4, sticky=W)
 
combo = Combobox(label_frame)
combo['values'] = (1, 2, 3, 4, 5)
combo.current(0)
combo.grid(column=1, row=1)
 
combo2 = Combobox(label_frame)
combo2['values'] = ('a', 'b', 'c', 'd', 'e')
combo2.current(0)
combo2.grid(column=1, row=2)
 
combo3 = Combobox(label_frame)
combo3['values'] = ('a', 'b', 'c', 'd', 'e')
combo3.current(0)
combo3.grid(column=1, row=3)
 
combo4 = Combobox(label_frame)
combo4['values'] = ('a', 'b', 'c', 'd', 'e')
combo4.current(0)
combo4.grid(column=1, row=4)
 
 
Label(label_frame, text='value_1_1').grid(row=1, column=2, sticky=W)
Label(label_frame, text='value_1_2').grid(row=1, column=3, sticky=W)
Label(label_frame, text='value_2_1').grid(row=2, column=2, sticky=W)
Label(label_frame, text='value_2_2').grid(row=2, column=3, sticky=W)
Label(label_frame, text='value_3_1').grid(row=3, column=2, sticky=W)
Label(label_frame, text='value_3_2').grid(row=3, column=3, sticky=W)
Label(label_frame, text='value_4_1').grid(row=4, column=2, sticky=W)
Label(label_frame, text='value_4_2').grid(row=4, column=3, sticky=W)
 
 
root.config(menu=main_menu)
 
root.mainloop()
Результат работы можно видеть на третьей и шестой картинках во вложении.

Данный результат меня не устраивает.
В идеале я хочу получить следующее:
1) Все элементы объединены рамкой ( находятся внутри неё).
2) В левом верхнем углу рамки есть надпись, как в примере с LabelFrame.
3) В правом верхнем углу есть кнопка или что-то в этом роде, при первом нажатии на которую рамка бы сворачивалась, а при втором разворачивалась.
4) Кнопка должна всегда быть видимой.
Примерный вариант того, что я хочу получить можно увидеть на третьей и четвертой картинках во вложении.
Подскажите, пожалуйста, как это сделать.
Миниатюры
Сворачивание/разворачивание элементов окна   Сворачивание/разворачивание элементов окна   Сворачивание/разворачивание элементов окна  

Сворачивание/разворачивание элементов окна  
Изображения
  
0
1 / 1 / 0
Регистрация: 15.11.2019
Сообщений: 12
03.06.2020, 13:12  [ТС]
Неужели вообще вариантов нет? Должна же быть в python возможность такое сделать.
0
║XLR8║
 Аватар для outoftime
1212 / 909 / 270
Регистрация: 25.07.2009
Сообщений: 4,360
Записей в блоге: 5
03.06.2020, 20:23
Лучший ответ Сообщение было отмечено -Azan- как решение

Решение

-Azan-, унаследуйся от виджета LabelFrame как во втором примере и добавь чего тебе не хватает. Внутряк ложи в bottomframe который будешь прятать как в первом примере. Не весь виджет а только внутрянку.
1
1 / 1 / 0
Регистрация: 15.11.2019
Сообщений: 12
04.06.2020, 17:05  [ТС]
outoftime, спасибо! То что нужно!

Добавлено через 3 минуты
Добавляю получившийся код. Вдруг кому-то поможет.

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
from tkinter import Menu, Frame, Label, Tk, W, N, E, LabelFrame, Button
from tkinter.ttk import Combobox
root = Tk()
root.title("qwerty")
root.geometry("800x750")
 
main_menu = Menu()
 
frame = Frame()
frame.grid()
 
label_frame = LabelFrame(root)
label_frame.grid(row=0, column=0, sticky=N)
Label(label_frame, text='Выбор параметров').grid(row=0, sticky=W)
bottomframe = Frame(label_frame)
bottomframe.grid(row=1, column=0, sticky=N)
 
 
def bth():
    bottomframe.grid_remove()
    btn.config(text='Показать')
    btn.config(command=bth2)
 
 
def bth2():
    bottomframe.grid()
    btn.config(text='Скрыть')
    btn.config(command=bth)
 
 
btn = Button(label_frame, text='Скрыть', command=bth)
btn.grid(row=0, padx=130, pady=10)
 
Label(bottomframe, text='Название').grid(row=0, sticky=W)
Label(bottomframe, text='Выбор').grid(row=0, column=1, sticky=W)
Label(bottomframe, text='A').grid(row=0, column=2, sticky=W)
Label(bottomframe, text='B').grid(row=0, column=3, sticky=W)
 
Label(bottomframe, text='Название 1').grid(row=1, sticky=W)
Label(bottomframe, text='Название 2').grid(row=2, sticky=W)
Label(bottomframe, text='Название 3').grid(row=3, sticky=W)
Label(bottomframe, text='Название 4').grid(row=4, sticky=W)
 
combo = Combobox(bottomframe)
combo['values'] = (1, 2, 3, 4, 5)
combo.current(0)
combo.grid(column=1, row=1)
 
combo2 = Combobox(bottomframe)
combo2['values'] = ('a', 'b', 'c', 'd', 'e')
combo2.current(0)
combo2.grid(column=1, row=2)
 
combo3 = Combobox(bottomframe)
combo3['values'] = ('a', 'b', 'c', 'd', 'e')
combo3.current(0)
combo3.grid(column=1, row=3)
 
combo4 = Combobox(bottomframe)
combo4['values'] = ('a', 'b', 'c', 'd', 'e')
combo4.current(0)
combo4.grid(column=1, row=4)
 
 
Label(bottomframe, text='value_1_1').grid(row=1, column=2, sticky=W)
Label(bottomframe, text='value_1_2').grid(row=1, column=3, sticky=W)
Label(bottomframe, text='value_2_1').grid(row=2, column=2, sticky=W)
Label(bottomframe, text='value_2_2').grid(row=2, column=3, sticky=W)
Label(bottomframe, text='value_3_1').grid(row=3, column=2, sticky=W)
Label(bottomframe, text='value_3_2').grid(row=3, column=3, sticky=W)
Label(bottomframe, text='value_4_1').grid(row=4, column=2, sticky=W)
Label(bottomframe, text='value_4_2').grid(row=4, column=3, sticky=W)
 
 
root.config(menu=main_menu)
 
root.mainloop()
1
║XLR8║
 Аватар для outoftime
1212 / 909 / 270
Регистрация: 25.07.2009
Сообщений: 4,360
Записей в блоге: 5
07.06.2020, 05:58
-Azan-, почитал по tkinter ради интереса, советуется наследование не использовать во избежание конфликта имён. (давно писал, но не отправил)


-Azan-, по вашему коду, вы кнопку поставили не так как хотели. Вы, вроде, хотели её на самом LabelFrame разместить, пример:

Кликните здесь для просмотра всего текста
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
from tkinter import Menu, Frame, Label, Tk, W, N, E, LabelFrame, Button
from tkinter.ttk import Combobox
from tkinter import NE
root = Tk()
root.title("qwerty")
root.geometry("800x750")
 
main_menu = Menu()
 
label_frame = LabelFrame(root, text='Выбрать параметры')
label_frame.grid(row=0, column=0, sticky=N)
 
 
 
def bth():
    bottomframe.grid_forget()
    btn.config(text='Показать')
    btn.config(command=bth2)
    lebel_frame.config()
 
 
def bth2():
    bottomframe.grid()
    btn.config(text='Скрыть')
    btn.config(command=bth)
    
 
btn = Button(label_frame, text='Скрыть', command=bth)
btn.place(relx=1, rely=0, x=-5, y=-5, anchor=NE, bordermode="outside")
 
bottomframe = Frame(label_frame)
bottomframe.grid()
 
 
 
Label(bottomframe, text='Название').grid(row=0, sticky=W)
Label(bottomframe, text='Выбор').grid(row=0, column=1, sticky=W)
Label(bottomframe, text='A').grid(row=0, column=2, sticky=W)
Label(bottomframe, text='B').grid(row=0, column=3, sticky=W)
 
Label(bottomframe, text='Название 1').grid(row=1, sticky=W)
Label(bottomframe, text='Название 2').grid(row=2, sticky=W)
Label(bottomframe, text='Название 3').grid(row=3, sticky=W)
Label(bottomframe, text='Название 4').grid(row=4, sticky=W)
 
combo = Combobox(bottomframe)
combo['values'] = (1, 2, 3, 4, 5)
combo.current(0)
combo.grid(column=1, row=1)
 
combo2 = Combobox(bottomframe)
combo2['values'] = ('a', 'b', 'c', 'd', 'e')
combo2.current(0)
combo2.grid(column=1, row=2)
 
combo3 = Combobox(bottomframe)
combo3['values'] = ('a', 'b', 'c', 'd', 'e')
combo3.current(0)
combo3.grid(column=1, row=3)
 
combo4 = Combobox(bottomframe)
combo4['values'] = ('a', 'b', 'c', 'd', 'e')
combo4.current(0)
combo4.grid(column=1, row=4)
 
 
Label(bottomframe, text='value_1_1').grid(row=1, column=2, sticky=W)
Label(bottomframe, text='value_1_2').grid(row=1, column=3, sticky=W)
Label(bottomframe, text='value_2_1').grid(row=2, column=2, sticky=W)
Label(bottomframe, text='value_2_2').grid(row=2, column=3, sticky=W)
Label(bottomframe, text='value_3_1').grid(row=3, column=2, sticky=W)
Label(bottomframe, text='value_3_2').grid(row=3, column=3, sticky=W)
Label(bottomframe, text='value_4_1').grid(row=4, column=2, sticky=W)
Label(bottomframe, text='value_4_2').grid(row=4, column=3, sticky=W)
 
 
root.config(menu=main_menu)
 
root.mainloop()


Идея в том, чтобы задать относительное позиционирование, но place & grid window manager-ы между собой не особо дружат. Вот такая вот пища для размышлений.
0
1 / 1 / 0
Регистрация: 15.11.2019
Сообщений: 12
07.06.2020, 21:31  [ТС]
outoftime, в идеале да, но и так неплохо для начала.
Позже я вернусь к этому вопросу, когда навык программирования улучшу.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
07.06.2020, 21:31
Помогаю со студенческими работами здесь

Сворачивание-разворачивание основного окна (улетает с панели)
Потратил вчера пол-дня на эту проблему, поэтому прошу помощи... . Вопрос у меня такой: вот я создал в Билдере приложение, стартую его, если...

Событие, которое отвечает за реакцию на сворачивание и разворачивание окна
Какое событие Pygame отвечает за реакцию на сворачивание и разворачивание окна? if event.type == pygame.СОБЫТИЕ: pass ...

Сворачивание и разворачивание окон
Привет, подскажите пожалуйста, почему при сворачивании/разворачивании форм через панель задач, после 3-4 раза, появляется главная форма...

Сворачивание и разворачивание окон
У меня есть главная форма, есть несколько дочерних. В главной я кнопкой выбираю дочернюю, она открывается Show, главная скрывается Hide....

Сворачивание-разворачивание окон
Здравствуйте. С Visual C++ Общаюсь недавно, так что сразу прошу прощения за глупый вопрос. Создаю проект в MFC AppWizard(exe). Программа...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
10 пpимет, которые всегда сбываются
Maks 31.03.2026
1. Чтобы, наконец, пришла маршрутка, надо закурить. Если сигарета последняя, маршрутка придет еще до второй затяжки даже вопреки расписанию. 2. Нaдоели зима и снег? Не надо переезжать. Достаточно. . .
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 31.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO Апнулись до NET10. Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта так и в интерактивном режиме. из сложностей - чисто функциональный подход. Решил. . .
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru