Evgenii Legotckoi
Evgenii Legotckoi24. Oktober 2015 03:30

QML - Lektion 009. Skalierbare Schnittstelle in Qt QML Android

Wenn wir über skalierbare Schnittstellen sprechen, dh skalierbare Schnittstellen bei der Entwicklung von Anwendungen auf Qt, dann besteht das Hauptproblem darin, dass es notwendig ist, eine Schnittstelle zu erstellen, die auf absolut allen Bildschirmen lesbar ist, sei es ein Computerbildschirm oder ein Smartphone-Bildschirm.

GUI-Parameter wie Breite und Höhe werden in Qt in Pixeln angegeben, aber bei gleicher Bildschirmauflösung auf einem Computer und auf einem Smartphone (z. B. 1366 x 768 Pixel) wird das Ergebnis völlig unterschiedlich sein. Auf einem Computer ist eine Schaltfläche mit 40 x 60 Pixel bequem, ich würde sogar sagen, groß, aber auf einem Smartphone-Bildschirm wird es schwierig sein, sie mit dem Finger zu treffen.

Daher ist es bei der Entwicklung der Schnittstelle einer Anwendung für viele Plattformen und Bildschirme notwendig, das Problem der Schnittstellenskalierbarkeit irgendwie zu lösen.


Skalierbare Schnittstelle

Die grundlegende Entscheidung, wie eine skalierbare Schnittstelle erstellt wird, besteht darin, die Größe der Elemente in Abhängigkeit von der Pixeldichte pro mm oder Zoll zu bestimmen.

dpi - Anzahl der Pixel pro Zoll. Dieses Merkmal wird viel häufiger verwendet als die Anzahl der Pixel pro mm. Mit dieser Eigenschaft können Sie die Pixel, die in einer Schaltfläche 1 mal 2 Zentimeter groß sein werden, neu berechnen und so eine Anwendungsoberfläche erstellen, die auf absolut allen Geräten, für die Sie entwickeln werden, gleich aussieht. Unabhängig von der Größe des Anwendungsbildschirms.

Nach der Neuberechnung der Pixel erhalten Sie einen abstrakten Wert, der aufgerufen wird:

dip oder dp - Dichteunabhängige Pixel . Dichteunabhängiges Pixel. Dadurch können Sie die Anwendungsschnittstelle schreiben, ohne darüber nachzudenken, wie viele Pixel die Breite und Höhe des Bildschirms auf einem Smartphone oder Tablet haben.

Entwicklung einer skalierbaren Schnittstelle für Android

Wie Sie wissen, gibt es viele Android -Geräte und alle haben unterschiedliche Bildschirmauflösungen, daher gibt Google die folgende Empfehlung für die Entwicklung einer skalierbaren Benutzeroberfläche:

  • Interface muss basierend auf dip erstellt werden (Pixeldichte unabhängig)
  • Wenden Sie im Allgemeinen die folgende Formel an, um die Neigung in die Anzahl der Pixel umzuwandeln:

px = dp * (dpi / 160)

Diese Formel übersetzt das Verhältnis der Pixeldichte des Zielgeräts zur Pixeldichte des Geräts mit einem Bildschirm von mdpi , d. h. mittlere dpi . Die Formel funktioniert auch hervorragend für 5-Zoll-Full-HD-Bildschirme.

Wenn wir speziell von Qt, sprechen, dann ist in diesem Fall zu beachten, dass Qt es nicht ermöglicht, Schnittstellenparameter sofort in dip. dip zu setzen. Das heißt, verwenden Sie die obige Formel.

Beim Entwickeln einer skalierbaren Schnittstelle in Qt Qml können Sie ein separates Objekt verwenden, das Ihre Dip-Pixel nimmt und ihr Äquivalent in physischen Bildschirmpixeln zurückgibt, wie im folgenden Code.

Die Funktion pixelDenstity gibt die Dichte von Pixeln pro mm zurück, also multiplizieren wir den resultierenden Wert mit 25,4 , um ihn in Zoll umzuwandeln. Und dann gibt die Funktion dieses Objekts, das Dip-Pixel empfängt, die bereits skalierte Anzahl physischer Pixel auf dem Bildschirm des Zielgeräts zurück. Gleichzeitig habe ich eine Überprüfung auf eine Pixeldichte kleiner als 120 dpi hinzugefügt. Dies ist für normale Desktops wie meinen 15,6-Zoll-Laptop mit einer Auflösung von 1366 x 768 erforderlich. In diesem Fall beträgt die Dichte 72 dpi . Und wenn dieser Wert noch durch 160 dividiert wird, fällt die Oberfläche sehr klein aus, was für einen Desktop-PC ebenfalls nicht akzeptabel ist. Daher wird dip für Desktops nicht in px übersetzt. dip entspricht in diesem Fall px.**

import QtQuick 2.0
import QtQuick.Window 2.0

Item {

    property int dpi: Screen.pixelDensity * 25.4

    function dp(x){
        if(dpi < 120) {
            return x; // Для обычного монитора компьютера
        } else {
            return x*(dpi/160);
        }
    }
}

Zusammenfassung. Skalierbare Schnittstelle

Als Ergebnis der Funktion dieses Objekts gelang es mir, das folgende Bild der Anwendung zu erhalten, die auf dem Bildschirm eines Meizu m1 Note-Smartphones mit Full-HD-Bildschirm auf einem 5,5-Zoll- und auf einem 15,6-Zoll-Laptop-Bildschirm entwickelt wird

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

Kommentare

Nur autorisierte Benutzer können Kommentare posten.
Bitte Anmelden oder Registrieren
Letzte Kommentare
ИМ
Игорь Максимов5. Oktober 2024 07:51
Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
d
dblas55. Juli 2024 11:02
QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
k
kmssr8. Februar 2024 18:43
Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
EVA
EVA25. Dezember 2023 10:30
Boost - statisches Verknüpfen im CMake-Projekt unter Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
Jetzt im Forum diskutieren
J
JacobFib17. Oktober 2024 03:27
добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
JW
Jhon Wick1. Oktober 2024 15:52
Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
КГ
Кирилл Гусарев27. September 2024 09:09
Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
F
Fynjy22. Juli 2024 04:15
при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

Folgen Sie uns in sozialen Netzwerken