Простой GUI калькулятор на Python #1. Создание дизайна приложения

image-loader.svg

Штош. Наверное, каждый начинающий программист после «Hello, world!» хочет написать какой-нибудь простенький проект. Почти всегда в голову приходит идея создания калькулятора. Но консольный калькулятор — это как-то скучно и просто. Хочется сделать приложение вот прямо как в системе. Ну или хотя бы что-то похожее.

В этой серии статей я научу вас делать простой кроссплатформенный десктопный калькулятор. Здесь не будет тригонометрических функций, процентов, интегралов и других полезных вещей. Вы сможете добавить их по своему желанию.

image-loader.svg

Мы будем использовать язык Python, фреймворк Qt, библиотеку PySide6, сразу установим её:

pip install PySide6

Создавать интерфейс мы будем в приложении Qt Designer. Его можно скачать отдельно или найти в папке установленного PySide. Для этого перейдем по пути:

python(или venv*)/Lib/site-packages/PySide6/designer.exe

Создаем Main Window, т.е. главное окно приложения.

image-loader.svg

Сразу убираем ненужные меню и статус бары.

image-loader.svg

Название приложения можно изменить в свойстве главного окна windowTitle.

image-loader.svg

Перетащим нужные элементы в интерфейс. В нашем калькуляторе будет поле ввода Line Edit.

image-loader.svg

Label с временным выражением над этим полем ввода.

image-loader.svg

Grid Layout для кнопок.

image-loader.svg

Просто закинем эти элементы и выберем «Lay Out Vertically» для центрального виджета.

image-loader.svg

Теперь закинем кнопки в Grid Layout, у меня будет 4 колонки и 5 рядов. Чтобы скопировать и вставить элемент, можно перетащить его с зажатой клавишей Ctrl.

image-loader.svg

Поставим текст во все кнопки. Для Backspace мы позже поставим иконку.

image-loader.svg

Проставим горячие клавиши для всех кнопок, кроме Clear и отрицания. За это отвечает свойство shortcut. К сожалению, в Qt Designer нельзя указать несколько горячих клавиш для одной кнопки. Мы сделаем это позже в коде (для точки и равно).

image-loader.svg

Запишем 0 в Line Edit и выберем правое горизонтальное выравнивание для текста.

image-loader.svg

Нам нужно сделать так, чтобы пользователь не мог вводить что попало в это поле, чтобы он мог его только читать. Для этого существует свойство ReadOnly.

image-loader.svg

Укажем максимальную длину в 16 символов, как в калькуляторе Windows.

image-loader.svg

Запишем в лейбл какое-нибудь выражение и поставим правое выравнивание.

image-loader.svg

Чтобы посмотреть превью дизайна используйте сочетание клавиш Ctrl + R.

image-loader.svg

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

image-loader.svg

Вы спросите: «Почему интерфейс так плохо выглядит?». Все потому, что у элементов не настроена вертикальная политика. Для лейбла и поля поставим Maximum.

Конечно же не забываем сохранить файл интерфейса. Он имеет расширение ui. Обычно я называю файл design.

Для всех кнопок поставим Expanding.

image-loader.svg

Приступаем к стилизации калькулятора. Сначала нужно определиться с цветовой палитрой. Я буду использовать 4 цвета:

  1. Почти черный #121212 для фона.

  2. Белый #FFF для текста кнопок и поля ввода.

  3. Серый #666 для фона кнопок при наведении.

  4. Серый посветлее #888 для текста временного выражения и фона кнопок при нажатии.

В Qt Designer поддерживается язык css. Напишем простенький stylesheet для главного окна. Для всего виджета указываем белый цвет текста и почти черный цвет #121212 для фона.

Я буду использовать бесплатный шрифт Rubik из библиотеки Google Fonts. Он довольно приятный.

QWidget {
	color: white;
	background-color: #121212;
	font-family: Rubik;
	font-size: 16pt;
	font-weight: 600;
}

Давайте посмотрим, что получается.

image-loader.svgimage-loader.svg

Давайте изменим кнопки на плоские с прозрачным фоном.

QPushButton {
	background-color: transparent;
	border: none;
}

Теперь напишем изменение фона кнопок при наведении и нажатии. При наведении цвет фона будет меняться на серый #666, при нажатии на серый #888.

QPushButton:hover {
	background-color: #666;
}

QPushButton:pressed {
	background-color: #888;
}

Посмотрим на результат.

image-loader.svg

Теперь разберемся с Line Edit. Поставим размер шрифта 40pt и уберем границы. Я не буду делать какие-то изменения при наведении и нажатии, потому что пользователь не может взаимодействовать с этим полем.

font-size: 40pt;
border: none;

image-loader.svg

Для лейбла укажем только цвет #888. С этим элементом пользователь тоже не может взаимодействовать.

color: #888;

image-loader.svg

Теперь зайдем на Google Icons и возьмем черную иконку калькулятора и белую иконку backspace. Я возьму Sharp иконки с размером 24 пикселя. Сохранить нужно в формате PNG.

image-loader.svgimage-loader.svg

Далее идет нудный процесс вытаскивания иконок из скачанных архивов. Я думаю, вы справитесь.

Создадим файл ресурсов. Resource Browser > Edit Resources > New Resource File.

image-loader.svgimage-loader.svgimage-loader.svg

Добавим префикс для иконок.

image-loader.svg

Закинем туда наши две иконки.

image-loader.svg

Поставим иконку Backspace с помощью свойства icon > choose Resource.

image-loader.svg

Поставим размер 24×24 пикселя в свойстве iconSize.

image-loader.svg

То же самое проделаем для иконки приложения.

image-loader.svg

Почти готово. Убираем текст из лейбла. Ставим размер главного окна. У меня будет 300 на 500 пикселей. Такой же размер поставлю минимальным для приложения.

image-loader.svg

Еще добавлю такую фичу — курсор «указывающая рука» для кнопок. Поставлю только для одной кнопки, сейчас доделаем в коде.

image-loader.svgimage-loader.svg

Файл интерфейса представляет собой файл с xml разметкой. Мы можем найти блок кода с указывающей рукой, введя в поиске по коду «Pointing».

image-loader.svg


 PointingHandCursor

Заметим, что этот блок кода идет после блока размерной политики. Поэтому нам нужно заменить


 
  0
  0
 

на


 
  0
  0
 


 PointingHandCursor

В современных редакторах это сделать очень просто. Например, в VS Code нужно нажать Ctrl + H.

Впишем нужные блоки кода и нажмем Replace All (Ctrl + Alt + Enter).

Проверяем в дизайне.

image-loader.svg

Дизайн сделан, поздравляю!

Для начала нам нужно конвертировать файл ресурсов в питоновский файл. Для этого напишем в терминале:

pyside6-rcc "название файла ресурсов" > "название Python файла на выходе"

В нашем случае:

pyside6-rcc files.qrc > files_rc.py

image-loader.svg

Теперь конвертируем в Python файл интерфейса. Для этого введем в терминал тот же самый синтаксис, но теперь используем pyside6-uic:

pyside6-uic design.ui > design.py

image-loader.svg

Если у вас на выходе получаются файлы с кодировкой UTF-16, конвертируйте их в UTF-8 во избежание дальнейших проблем.

image-loader.svgimage-loader.svg

Штош, в следующей статье напишем код для главного функционала калькулятора. До встречи.

Репозиторий на GitHub

© Habrahabr.ru