Проект iMpos. Часть 004. Языковые настройки приложения, QTranslator. Создание диалога входа в ситему

QTtranslator, Dialog, QtDesigner, locale

Языковые настройки приложения, QTranslator.

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

#ifndef QT_NO_TRANSLATION
    //Определяем имя языкового файла в зависимости от текущей локали
    QString translatorFileName = QLatin1String("qt_");
    translatorFileName += QLocale::system().name();
    //Создаем и пытаемся загрузить 
    QTranslator *translator = new QTranslator(&a);
    if (translator->load(translatorFileName, QLibraryInfo::location(QLibraryInfo::TranslationsPath)))
        a.installTranslator(translator);
    else
        qWarning(logWarning()) << "Не удалось загрузить языковый файл.";
#endif  

Регистрация пользователя приложения

Диалог регистрации пользователя приложения будем вызывать в зависимости от настройки 1000, перед запуском основного окна программы.

Окно будет иметь следующий вид:

Добавляем новые файлы в наш проект. Правая кнопка мыши на названии проекта. Выбираем Добавить новый...

Выбираем шаблон Класс формы Qt Designer

Шаблон формы выбираем Dialog without Buttons

Указываем имя класса и путь к его файлам.

Итоговой шаг.

Создался заголовочный файл класса logindialog.h файл исходника logindialog.cpp и файл формы logindialog.ui который открылся в редакторе форм.

Во многих статьях на различных сайтах я встречал фразу “создавать интерфейс в Designer пусть будут дизайнеры, а мы будем делать это в коде”, да и в примерах идущих с Qt интерфейс создается в коде программы.
Я при первом знакомстве с ним потратил несколько дней на изучение его возможностей и остановился на том что по максимуму буду использовать его использовать. Зачем делать руками то что среда делает автоматически.
Добавляем необходимые элементы управления на форму и даем осмысленные имена объектам.

Объект labelLogo будет содержать рисунок, для того чтобы он отображался необходимо создать файл ресурсов и добавить туда изображение.
Переходим во вкладку Редактор и добавляем новый файл. Выбираем Файл ресурсов Qt .

Указываем имя и путь к файлу.

Итог:

В каталоге с проектом создаем папку Image и помещаем туда файл users.png . В каталоге проекта правой кнопкой на файле resource.qrc , выбираем Добавить существующие файлы , выбираем файл с изображением. Получаем следующее:

Открываем форму logindialog.ui выбираем объект labelLogo ищем свойство pixmap.

Нажимаем кнопку … и выбираем изображение.

Нажимаем Ctrl+J (Подогнать размер)

Выбираем объект labelTitle выбираем свойство styleSheet, Добавляем шрифт, устанавливаем Bold и размер 14

Добавляем цвет, выбираем color, выбираю синий цвет. Получаем следующую таблицу стилей:

Теперь включаем свойство wordWarp и изменяем allignment

Снова Ctrl+J и изменяем размер объекта.

Выбираем объект comboBoxUser и включаем свойство editable для того чтобы осуществлялся поиск имени пользователя при вводе с клавиатуры.

Далее выбираем все кроме изображения и заголовка, Ctrl+L(правая кнопка мыши компоновка, скомпоновать по вертикали)
В свойства получившегося Layot изменяем layoutStretch вот так :

Таким образом мы устанавливаем объекту labelInfo максимальный размер.

Выделяем всю форму, правая кнопка мыши, Компоновка, Компоновать по сетке (либо кнопка на панели инструментов).
Выбираем labelLogo меняем вертикальное выравнивание на AlignTop.

Нажимаем Alt+Shift+R и тестируем поведение диалога.

Чистого времени для создания диалога потрачено не более 5 минут, причем аосле каждого изменения можно просматривать как будет выглядеть форма в процессе работы. За это я и предпочитаю Qt Designer.

Архив проекта
iMposCh004.zip iMposCh004.zip

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.

Был бы там ещё QSplitter - цены бы не было Qt Designer. :) Мне он как раз на моём проекте понадобился. Так что теперь челлендж по формам через код.

Согласен насчет того, что Qt Designer очень удобная вещь.

Многие програмисты говорят о том, что якобы мы не дизайнеры и пользоваться Qt дизайнером не будем. Вот только это абсолютно однобокое мнение тех, которые пишут кучу "бесполезного" кода для вёрстки, а полезный код, который выполняет конкретную работу, порой просто теряется в куче созданий и инициализаций Объектов Вёрстки. Я не хочу смотреть на вёрстку в коде диалогового окна, я хочу видеть то, что это окно делает, не кучу new QLabel() , которые создаются и не меняются в течение всего жизненного цикла диалога.

Например в нашем проекте генерированный через Qt Designer код главного окна приложения занимает 16000 строк кода, это без полезной работы этого окна. И смотреть на это не нужно и не хочется, ибо это лишнее, смотреть тот код, который и так сгенерирован рабочим и там не будет пропущен какой-нибудь parent, что нельзя сказать с уверенностью, если это будет писать программист.

Также они абсолютно кладут болт на работу переводчиков. Поскольку Qt Linguist позволяет при переводе просматривать готовый диалог ui формы, и переводчику будет удобнее сделать качественный перевод видя контекст окна приложения, чем непонятные строчки кода, где это всё написано.

Так что выводы можно сделать довольно однозначные.

На самом деле QSplitter есть, только немного по хитрому он там ставится. Вот статья по QSplitter

Ага, попробовал. Удобно. Спасибо!

Comments

Only authorized users can post comments.
Please, Log in or Sign up
Donate

Hello, Dear Users of EVILEG!!!

If the site helped you, then support the development of the site financially, please.

You can do it by following ways:

Thank you, Evgenii Legotckoi

T
Dec. 11, 2019, 4:56 p.m.
Toma

C++ - Тест 003. Условия и циклы

  • Result:50points,
  • Rating points-4
AT
Dec. 10, 2019, 8:06 a.m.
Anastasija Troschenkova

C++ - Test 001. The first program and data types

  • Result:60points,
  • Rating points-1
AT
Dec. 10, 2019, 8:02 a.m.
Anastasija Troschenkova

Qt - Test 001. Signals and slots

  • Result:73points,
  • Rating points1
Last comments
Dec. 9, 2019, 3:41 a.m.
Evgenij Legotskoj

Эта ошибка invalid use of incomplete type ‘class Ui::AnotherWindow’ обычно говорит о том, что не найдено определение класса или структуры. Типичная проблема - не подключён заголовочны…
NB
Dec. 9, 2019, 3:36 a.m.
Nikolaj Batmanov

Ну, не настолько со мной всё полхо...))) Вроде бы. Я ж кнопки отрисовываю.
Dec. 9, 2019, 3:14 a.m.
Evgenij Legotskoj

Добрый день. У вас ui файлов по ходу нет. UI файлы используются для вёрстки в графическом дизайнере.
NB
Dec. 9, 2019, 3:05 a.m.
Nikolaj Batmanov

Здравствуйте! Полностью скопировал ваш пример к себе, чтобы разобраться. А он не хочет запускаться, дает ошибку: invalid use of incomplete type ‘class Ui::AnotherWindow’ ui(new Ui…
Dec. 8, 2019, 7:23 a.m.
Evgenij Legotskoj

У меня здесь есть одна старая статья с примером векторного редактора. Там есть ответы на ваши вопросы. Поизучайте Qt/C++ - Урок 072. Пример векторного редактора на Qt QGraphicsItem, QG…
Now discuss on the forum
Dec. 12, 2019, 11:49 a.m.
qml_puthon_user

Да, с console.log() я разобрался, счётчик ничего не показывает
Dec. 12, 2019, 9:27 a.m.
Evgenij Legotskoj

Добрый день. Вообще Qt Designer это рисовалка формочек. Вы хотите от него больше, чем в нём есть. Максимум, что вы можете сделать, это накидать всю вёрстку в дизайнере, а потом привязыватьс…
MU
Dec. 11, 2019, 8:27 a.m.
Maciej Urmański

Thank you! Now works, and this is solution. num_embed = Embed.objects.filter(added_by=recipe.added_by).count()
Dec. 11, 2019, 8:12 a.m.
Mihailll

Так работает. Взял этот пример https://api-2d3d-cad.com/face_recognition_with_opencv/ void MainWindow::on_pushButton_4_clicked() //фото определение лица{ // Load Face cascade (.xml…
TD
Dec. 10, 2019, 4:14 a.m.
Timur Dosov

Спасибо, работает. А ещё вопрос: как загрузить страницу с динамической подгрузкой контента по скроллингу? Например - [https://ntvplus.ru/tv/]. Пока делаю через костыль - QApplication::s…
EVILEG
About
Services
© EVILEG 2015-2019
Recommend hosting TIMEWEB