Evgenii Legotckoi
Nov. 12, 2016, 9:16 p.m.

QML - Lesson 001. TextEdit IP Address Validation

Available similar articles on Qt/С++ and PyQt5/Python

For the full set of lessons on Qt, on validation of IP-addresses to add Article also option to Qt/QML.

There is also a data entry field, in which we will enter the IP-address. Will be used to validate RegExpValidator . One unpleasant aspect in this case is that the slip a few variables in this line RegExpValidator is rather trivial task, therefore, confine ourselves to writing directly in the regular season regExp property of this object.


Project structure

The project consists of the following files:

  • QMLLineEdit.pro - project profile
  • main.cpp - start the source file
  • qml.qrc - resource file
  • main.qml - main starter qml file

QMLLineEdit.pro

  1. QT += qml quick
  2.  
  3. CONFIG += c++11
  4.  
  5. SOURCES += main.cpp
  6.  
  7. RESOURCES += qml.qrc
  8.  
  9. # Additional import path used to resolve QML modules in Qt Creator's code model
  10. QML_IMPORT_PATH =
  11.  
  12. # Default rules for deployment.
  13. qnx: target.path = /tmp/$${TARGET}/bin
  14. else: unix:!android: target.path = /opt/$${TARGET}/bin
  15. !isEmpty(target.path): INSTALLS += target

main.cpp

  1. #include <QGuiApplication>
  2. #include <QQmlApplicationEngine>
  3.  
  4. int main(int argc, char *argv[])
  5. {
  6. // I draw your attention to this attribute.
  7.     // It includes scaling for high resolution devices,
  8.     // Ie Qt5.7 no longer need to count the pixels in dpi
  9. QCoreApplication::setAttribute(Qt::AA_EnableHighDpiScaling);
  10. QGuiApplication app(argc, argv);
  11.  
  12. QQmlApplicationEngine engine;
  13. engine.load(QUrl(QLatin1String("qrc:/main.qml")));
  14.  
  15. return app.exec();
  16. }

main.qml

Code is very little, even less than for Qt/C ++ and PyQt5/Python, so I just give an example without comment and it should be clear to all.

  1. import QtQuick 2.7
  2. import QtQuick.Controls 2.0
  3. import QtQuick.Layouts 1.0
  4.  
  5. ApplicationWindow {
  6. visible: true
  7. width: 480
  8. height: 120
  9. title: qsTr("QML Text Field IP Address")
  10.  
  11. RowLayout {
  12. anchors.fill: parent
  13. anchors.margins: 10
  14.  
  15. Label {
  16. text: "Введите IP-адрес"
  17. }
  18.  
  19. TextField {
  20. validator: RegExpValidator {
  21. regExp: /^((?:[0-1]?[0-9]?[0-9]|2[0-4][0-9]|25[0-5])\.){0,3}(?:[0-1]?[0-9]?[0-9]|2[0-4][0-9]|25[0-5])$/
  22. }
  23. }
  24. }
  25. }

Result

The result is the ability to enter IP addresses and IP addresses only.

Link to repository

Do you like it? Share on social networks!

M
  • Sept. 14, 2017, 3:42 p.m.

Не запскается проект. Только начал изучать QML, ранее работали программы.
Нужно специально как то устанавливать Qt под Android?
Я не мог допстить ошибку - скачивал проект с сайта.
В чем может быть проблема?

Evgenii Legotckoi
  • Sept. 14, 2017, 4:18 p.m.

Возможно проблема в версиях. Какие ошибки выдаёт?
В принципе можете скопипастить содержимое main.qml в свой новый созданный проект. Это должно быть достаточно.

Evgenii Legotckoi
  • Sept. 14, 2017, 4:22 p.m.

И, да , для Андроида необходимо устанавливать соотвествующие NDK и SDK , они есть на сайте Android Studio .

То есть недостаточно скачать сборку Qt для Андроида, необходимо ещё настроить Qt Creator на использование этих NDK и SDK.
M
  • Sept. 14, 2017, 4:38 p.m.

Спасибо. Сейчас все поставлю, попробую заново.
Ошибка не помню какая, я уже переустанавливаю  Qt.

Comments

Only authorized users can post comments.
Please, Log in or Sign up
  • Last comments
  • AK
    April 1, 2025, 11:41 a.m.
    Добрый день. В данный момент работаю над проектом, где необходимо выводить звук из программы в определенное аудиоустройство (колонки, наушники, виртуальный кабель и т.д). Пишу на Qt5.12.12 поско…
  • Evgenii Legotckoi
    March 9, 2025, 9:02 p.m.
    К сожалению, я этого подсказать не могу, поскольку у меня нет необходимости в обходе блокировок и т.д. Поэтому я и не задавался решением этой проблемы. Ну выглядит так, что вам действитель…
  • VP
    March 9, 2025, 4:14 p.m.
    Здравствуйте! Я устанавливал Qt6 из исходников а также Qt Creator по отдельности. Все компоненты, связанные с разработкой для Android, установлены. Кроме одного... Когда пытаюсь скомпилиров…
  • ИМ
    Nov. 22, 2024, 9:51 p.m.
    Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
  • Evgenii Legotckoi
    Oct. 31, 2024, 11:37 p.m.
    Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup