|
|
3 years ago | |
|---|---|---|
| .. | ||
| layout | 3 years ago | |
| 3 years ago | ||
| pic | 3 years ago | |
| README.md | 3 years ago | |
README.md
ТЕХНИЧЕСКОЕ ЗАДАНИЕ на разработку утилиты ubl-settings-info
-
ОПИСАНИЕ:
Графическое средство настройки даты и времени в ОС UBLinux
-
ЭТАПЫ И СРОКИ СОЗДАНИЯ ПРИЛОЖЕНИЯ:
- Общий срок работ по созданию приложения составляет N дней:
- N дня - макет и дизайн приложения и его утверждение
- N дней - разработка приложения
- N дня - тестирование приложения и исправление ошибок
- Перечень этапов разработки приложения:
- Разработка макета и дизайна приложения
- Утверждение и доработка макета
- Создание работающего интерфейса, включая полную разработку действующих ярлыков, кнопок и т.д.
- Проектирование алгоритма работы приложения
- Написание работающего кода приложения, включая полноценно работающие элементы графического интерфейса, а также перевод (поддержка локализации En, Ru), самостоятельно
- Тестирование и исправление ошибок, самостоятельно
- Публикация
- Общий срок работ по созданию приложения составляет N дней:
-
ТЕХНОЛОГИЧЕСКИЕ ТРЕБОВАНИЯ:
- Приложение разрабатывается под нужды операционной системы UBLinux
- Использование фирменного логотипа компании
- Название приложения, техническое: ubl-settings-info (далее ${NAME_APPLICATION})
- Название приложения, публичное: Информация о системе
- Стек технологий:
- Язык программирования: Bash или C(++)
- Приложение для разработки графического интерфейса: Glade 3
- Графические библиотеки: GTK3
- Операционная система разработки: UBLinux DB
- Структура:
- В исходных кодах использовать префикс корня CMAKE_INSTALL_PREFIX для сборки приложений. Например,
CMAKE_INSTALL_PREFIX/share. - Bash/C(++): Весь функционал сосредоточен в графической части, вызовы и исполнение процедур написаны на языках Bash, C(++) /usr/bin/${NAME_APPLICATION} (скомпилированный бинарный файл)
- Графическая часть, фронт /usr/share/${NAME_APPLICATION}/ui/${NAME_APPLICATION}.glade
- Стили виджетов GTK /usr/share/${NAME_APPLICATION}/css/${NAME_APPLICATION}.css
- Элементы изображений
- Иконки:
/usr/share/icons/hicolor/scalable/apps/${NAME_APPLICATION}{*.png,*.svg}
Файлы изображений png иконок должны иметь имена вида:
- ru.ublinux.${NAME_APPLICATION}.svg
- ru.ublinux.${NAME_APPLICATION}.${NAME_ICONS}.svg Где ${NAME_ICONS} - имя графического элемента, например: checked, warning, alert и т.д. Файлы изображений png иконок должны генерироваться из svg файла в размеры 16, 32, 48, 64 пикселей сценарием make-файла.
- Изображения: /usr/share/${NAME_APPLICATION}/ui/{*.png,*.svg}
- Иконки:
/usr/share/icons/hicolor/scalable/apps/${NAME_APPLICATION}{*.png,*.svg}
Файлы изображений png иконок должны иметь имена вида:
- Локализация En/Ru
-
Для локализации должен быть создан файл-шаблон ${NAME_APPLICATION}.pot, на его основе должны быть созданы сами po-файлы переводов на необходимые языки, через файл сборки из po-файлов компилируются mo-файлы и размещаются сценарием установки по указанному пути: /usr/share/locale/${LANG}/LC_MESSAGES/${FILE_MO} где ${LANG} - каталог с именем локали, например, "ru" или "ru_RU", ${FILE_MO} - файл локализации программы, например, "${NAME_APPLICATION}.mo"
-
В файле локализации .pot и .po должна присутствовать строчка информационная, показывающая позицию локализации в коде
Пример:
#: source/${NAME_APPLICATION}.c:41 msgid "Example string for localization" msgstr "Пример строки для локализации" -
Вывод всех текстовых элементов осуществляется через средства локализации.
-
- Версия ПО
- Файл, в котором хранится версия - VERSION.md, находится в корне каталога проекта.
- При компиляции (через сценарий make-файла) данные из файла VERSION.md передаются в значение переменной (-ых) version_application в файлах-исходниках ПО.
- В исходных кодах использовать префикс корня CMAKE_INSTALL_PREFIX для сборки приложений. Например,
-
ТЕХНИЧЕСКОЕ ЗАДАНИЕ:
- Ярлык (desktop-файл):
- Type: Application
- Exec: ubl-settings-info
- Categories: X-UBL-SettingsManager;X-UBL-SystemSettings
- Главное окно:
- Требования к внешнему виду:
- Адаптивный (резиновый) дизайн.
- Наличие элементов интерфейса:
- Статических - не меняют свою ширину при изменении размеров окна или родительского элемента.
- Динамических - меняют свою ширину при изменении размеров окна или родительского элемента. Обычно занимают пространство от края до края окна или родительского элемента, либо пространство от рядом расположенного элемента до до края окна или родительского элемента.
- Минимальный размер окна до прекращения масштабирования 800 на 600 пикселей.
- Шапка в стиле приложений GTK3 с содержимым:
- Иконка приложения. Статический элемент. Выравнивание по левому краю.
- Заголовок окна, название приложения. Выравнивание по центру между элементами.
- Кнопка с иконкой с выпадающим списком -> "Справка, О приложении". Статический элемент. Выравнивание по правому краю.
- Стандартные элементы окна, кнопки "Свернуть, Минимизировать/На весь экран, Закрыть"
- В верхней части крупный логотип утилиты, с права от него краткое описание утилиты. Фон заполнен изображением. Статические элементы. Выравнивание по левому краю.
- Рабочая область.
- Требования к внешнему виду:
- Требования к «Рабочей области». Динамический элемент. От края до края по горизонтали и вертикали окна. Делится на два вертикальных блока (50 на 50 процентов), которые никак не обрамлены. Выводятся группы графического и текстового представления информации:
- Левый блок: - логотип текущей операционной системы (масштабируемый SVG-файл). Статический элемент. Выравнивание по центру родительского элемента.
- Правый блок:
- Список информации о программно-аппаратных характеристиках рабочей станции. Статический элемент. Выравнивание по левому краю.:
- Имя пользователя и хоста, например: miramax166@mmx166-pc
- Название ОС, билд, редакция, например: Система: UBLinux 2204 Desktop Basic
- Информация о ядре ОС, например: Ядро: x86_64 Linux 5.17.6-2-ublinux
- Аптайм системы, например, Время работы: 2h 14m
- Информация о пакетах, например: Установлено пакетов: 2306
- Информация об оболочке, например, Оболочка: sh
- Разрешение эрана (-ов), например, Разрешение: 5760x1080
- Информация о DE, например, Среда рабочего стола: Xfce4
- Информация об оконном менеджере, например, Оконный менеджер: Xfwm4
- Информация о теме системы, например, Тема оконного менеджера: Numix-Archblue
- Информация о теме GTK-среды, например, Тема GTK: Arc-Dark [GTK2]
- Информация о теме значков, например, Тема значков: Faenza-Cupertino
- Информация о шрифте, например, Шрифт: Ubuntu 10
- Информация о диске, например, Диск: 394G / 960G (42%)
- Информация о процессоре, например, CPU: Intel Core i3-9100 @ 4x 4.2GHz [38.0°C]
- Информация о видеокарте, например, GPU: NVIDIA GeForce GT 710
- Информация об ОЗУ, например, Оперативная память: 4406MiB / 15934MiB.
- Список информации о программно-аппаратных характеристиках рабочей станции. Статический элемент. Выравнивание по левому краю.:
-
ОСОБЕННОСТИ
- Кнопка с иконкой с выпадающим списком -> “Справка, О приложении”
- Справка - запуск браузера с переходом на ссылку:
- локализованный (ru_RU) вариант: https://wiki.ublinux.ru/ru/Программное_обеспечение/Программы_и_утилиты/Все/${NAME_APPLICATION} (далее ${URLWIKI})
- локализованный (en_EN) вариант: https://wiki.ublinux.com/ru/Программное_обеспечение/Программы_и_утилиты/Все/${NAME_APPLICATION} (далее ${URLWIKI})
- О приложении. Открывается диалоговое окно с выводом информации о программе:
- Заголовок окна по локализованному названию утилиты
- Копирайты, порядок:
- Иконка приложения
- Название утилиты
- Версия программы (переменная version_application)
- Название утилиты, локализованное
- Ссылка "Домашняя страница проекта" на https://ublinux.ru/
- Авторские права © ООО "Юбисофт", 2022 - $LASTYEAR
- локализованный (en_EN) вариант: "Copyright © UBSoft LLC, 2022 - $LASTYEAR"
- где $LASTYEAR - текущий год.
- Копирайты, порядок:
- Справка - запуск браузера с переходом на ссылку:
- Кнопка с иконкой с выпадающим списком -> “Справка, О приложении”
-
КОМАНДЫ
- Справка, О приложении > Домашняя страница проекта:
xdg-open \${URLWIKI} & - Получить имя текущего пользователя
- команда - ``
- Получить имя хоста
- команда - ``
- Получить название ОС, билд, редакция
- команда - ``
- Поучить информацию о ядре ОС
- команда - ``
- Получить время работы системы
- команда - ``
- Получить информацию о пакете
- команда - ``
- Получить информацию об оболочке
- команда - ``
- Получить информацию об разрешение эрана (-ов)
- команда - ``
- Получить информацию о DE
- команда - ``
- Получить информацию об оконном менеджере
- команда - ``
- Получить информацию о теме системы
- команда - ``
- Получить информацию о теме GTK-среды
- команда - ``
- Получить информацию о теме значков
- команда - ``
- Получить информацию о шрифте
- команда - ``
- Получить информацию о диске
- команда - ``
- Получить информацию о процессоре
- команда - ``
- Получить информацию о видеокарте
- команда - ``
- Получить информацию об ОЗУ
- команда - ``
- Справка, О приложении > Домашняя страница проекта:
-
ПОМОЩЬ И ПАРАМЕТРЫ ЗАПУСКА
-
Помощь
-
Пример вывода:
${NAME_APPLICATION} version: $VERSION Application Description for UBLinux
Использование: ${NAME_APPLICATION} [OPTIONS...] Параметры приложения: $OPTIONS
Где $OPTIONS - параметры запуска, $VERSION - версия программы (переменная version_application).
-
-
Параметры запуска:
- -h, --help - Показать параметры справки
- -V, --version - Показать текущую версию
- --lock-help - Блокировка вызова справки
-
Действия при указанных параметрах:
- --lock-help - делать неактивным пункт "Справка" в выпадающем списке кнопки с иконкой.
-
-
ПРИБЛИЗИТЕЛЬНЫЙ МАКЕТ ПРИЛОЖЕНИЯ.
- Главное окно
