Форум программистов, компьютерный форум, киберфорум
Python: Tkinter
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.96/25: Рейтинг темы: голосов - 25, средняя оценка - 4.96
8 / 6 / 2
Регистрация: 24.07.2019
Сообщений: 37

pySTray: Создание иконки при свертывании программы в трей

21.03.2021, 17:40. Показов 5149. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Комьюнити, нужна ваша помощь.

создаю программу в tkinter, пишу функцию сворачивания в трей.
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
import tkinter as tk
from PIL import Image
from pystray import MenuItem, Menu, Icon
 
def quit_window(icon, item):
    icon.stop()
    root.destroy()
 
def show_window(icon, item):
    icon.stop()
    root.after(0, root.deiconify)
 
def withdraw_window():
    root.withdraw()
    icon = Icon('main', Image.open('test.ico'), 'Test', menu=Menu(MenuItem('Show', show_window), MenuItem('Quit', quit_window)))
    icon.run()
 
root = tk.Tk()
root.title('Test')
root.geometry('320x240')
root.resizable(False, False)
root.protocol("WM_DELETE_WINDOW", withdraw_window)
root.mainloop()
И программа работает. Но есть вопрос, Можно ли обойтись без подключения библиотеки PIL. Т.к. при упаковывании программы в pyinstaller, программа раздувается на лишние 12 Мб. Т.е. если не реализовывать функцию сворачивания, программа весит 12 Мб. Как только подключаем PIL размер увеличивается до 25 Мб.

Я думал, что можно заменить Image.open другими средствами, но не мог найти.

Что я делал:
1. Я перевел иконку в строку base64, и пробовал переписать функцию так:

Python
1
2
3
4
5
6
7
8
9
from io import BytesIO
from base64 import b64decode
...
def withdraw_window():
    root.withdraw()
    tray_icon = 'AAABAAEAEBAQAAEABAAoAQAAFgAAACgAAAAQAAAAIAAAAAEABAAAAAAAwAAAABMLAAATCwAAEAAAAAAAAAD///8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAEREREREREREREREREREREREREREREREREREREREREREREREAABEREREREQAAERERERERAAAREREREREAABEREREAAAAAAAAREQAAAAAAABERAAAAAAAAEREAAAAAAAARERERERERERERERERERERERERERERERERERERERERERHwD2Uu8A9pZcADLmHAA2xvAABsZQAAbl8AAABjAAAuYQAAYmUAAHJpAAAuYwAAZW7AA2FwwANhbfAPQWTwD2Ug'
 
    icon = Icon('main', Image.open(BytesIO(b64decode(tray_icon))), 'Test', menu=Menu(MenuItem('Show', show_window), MenuItem('Quit', quit_window)))
    icon.run()
И она тоже работает, но все равно требует PIL

2. Пробовал с помощью плагина pickle перевести Image.open('test.ico') в строку байт.

Python
1
2
3
4
import pickle
image = Image.open('test.ico')
pick = pickle.dumps(image, protocol=0)
print(pick)
Получал строку типа b'ccopy_reg\n_reconstructor\np0\n(cPIL.I coImagePlugin\nIcoImageFile\np1\nc__buil tin__\nobject\n ...'

далее я подставлял строку прямо в объект Icon

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
import tkinter as tk
import pickle
from pystray import MenuItem, Menu, Icon
 
def quit_window(icon, item):
    icon.stop()
    root.destroy()
 
def show_window(icon, item):
    icon.stop()
    root.after(0, root.deiconify)
 
def withdraw_window():
    pick_image = b'ccopy_reg\n_reconstructor\np0\n(cPIL.IcoImagePlugin\nIcoImageFile\np1\nc__builtin__\nobject\n ...'
    root.withdraw()
    icon = Icon('main', pickle.loads(pick_image), 'Test', menu=Menu(MenuItem('Show', show_window), MenuItem('Quit', quit_window)))
    icon.run()
 
root = tk.Tk()
root.title('Test')
root.geometry('320x240')
root.resizable(False, False)
root.protocol("WM_DELETE_WINDOW", withdraw_window)
root.mainloop()
И программа работала. И не требовалось подключать PIL. Но только из среды разработки. Как только упаковывалась pyinstaller, прекращала запускаться. Похоже PIL сам подключался при вызове из интерпретатора. Кстати при упаковывании она весила те же 12 Мб.

Подскажите как еще можно обойти подключение PIL? Ведь иконка это поток байтов. Как его еще можно подставить при вызове Icon?
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
21.03.2021, 17:40
Ответы с готовыми решениями:

Создание иконки программно + установка в трей
Привет всем! Мне необходимо на иконке нарисовать 2 цифры (00-99) и установить иконку в нотифи Как это можно реализовать?Возможно у...

Как правильно свернуть в трей при нажатии иконки minimize?
Именно как правильно? Потому что, если делать это в событии OnWindowStateChange следующим образом if WindowState = ws_minimize then...

Поместить иконку программы в трей на MacOS (не Dock, а именно трей - сверху справа)
Доброго времени суток. Хотелось бы узнать как написать на Objective C следующее: в трее должна висеть иконка, при клике на нее...

3
Эксперт Python
 Аватар для dondublon
4653 / 2073 / 366
Регистрация: 17.03.2012
Сообщений: 10,183
Записей в блоге: 6
22.03.2021, 14:25
Лучший ответ Сообщение было отмечено skrn как решение

Решение

Цитата Сообщение от skrn Посмотреть сообщение
Как его еще можно подставить при вызове Icon?
Сохранить именно как поток байт?
0
8 / 6 / 2
Регистрация: 24.07.2019
Сообщений: 37
23.03.2021, 02:45  [ТС]
Про поток ничего сказать не могу. У pystray очень скудная документация.

Читал примеры по pystray, но во всех примерах используется pil для создания иконки.
Почему нельзя использовать средства tkinter, например PhotoImage, я понять не могу.

И еще, pil и pyistaller как я понял не понимают друг друга, поэтому возникает ошибка.
При компиляции через Nuitka приложение раздувается до 90 МБ, что для меня еще более недопустимо.
0
Эксперт Python
 Аватар для dondublon
4653 / 2073 / 366
Регистрация: 17.03.2012
Сообщений: 10,183
Записей в блоге: 6
23.03.2021, 09:26
pystray.Icon() - что требует во втором параметре? Если не по ощущениям, а по документации?

Добавлено через 3 минуты
А, ну я уже сам вижу:
In order for the icon to be displayed, you must provide an icon. This icon must be specified as a PIL.Image.Image
Ну тогда вам не повезло. Либо искать другую либу, которой не нужен PIL, либо самому писать на winapi.
Ещё есть вариант сэмулировать PIL.Image, но это для настоящих извращенцев.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
23.03.2021, 09:26
Помогаю со студенческими работами здесь

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

При запуске программы сразу помещать в трей
Я написал программу она у меня сворачиваеться в трей, а подскажите как сделать так что бы когда прогрумму запускали она была сразу свернута...

Автозапуск программы при загрузке ОС и ее сворачивание в трей
В общем написал программу, которая запускается при загрузке ОС. 8-) Всё в общем замечательно, только есть одна мелочь, а именно: мне...

Сворачивание программы в трей при нажатии на button
Интересует, как реализовать в wpf сворачивание программы в трей при нажатии на какую-либо button, спасибо Добавлено через 1 час 25...

Не работает с создание своей иконки программы с GraphABC
Хочу создать иконку для программы, в которой подключен GraphABC. Делаю все как обычно - беру .rc и .ico, с помощью rc.exe (нашел руками)...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать контроль заполнения реквизита "ПричинаСписания". . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Программное заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru