Evgenii Legotckoi
Evgenii Legotckoi24 жовтня 2015 р. 03:30

QML - Урок 009. Масштабований інтерфейс в Qt QML Android

Якщо говорити про Scalable інтерфейси, тобто масштабовані інтерфейси при розробці додатків на Qt, то основною проблемою є те, що необхідно створити такий інтерфейс, який буде читати абсолютно на всіх екранах, будь то екран комп'ютера або екран смартфона.

Параметри графічного інтерфейсу, такі як ширина та висота, задаються в Qt у пікселях, але при однаковій роздільній здатності екрана на комп'ютері та на смартфоні (наприклад, 1366 на 768 пікселів) вийде абсолютно різний результат. На комп'ютері кнопка розміром 40 на 60 пікселів буде зручною, я навіть сказав би, великий, а на екрані смартфона по ній вже буде складно потрапити пальцем.

Отже, при розробці інтерфейсу однієї програми під безліч платформ і екранів необхідно якимось чином вирішувати проблему масштабованості інтерфейсу.


Масштабований інтерфейс

Основним рішенням того, як створити інтерфейс, що масштабується, є визначення розмірів елементів в залежності від щільності пікселів на мм або дюйм.

dpi – кількість пікселів на дюйм. Ця характеристика використовується значно частіше, ніж кількість пікселів на мм. Використовуючи цю характеристику, можна зробити перелік пікселів, які будуть перебувати в кнопці розміром 1 на 2 сантиметри і, таким чином, створити такий інтерфейс, який виглядатиме однаково абсолютно на всіх пристроях, під які Ви будете вести розробку. Незалежно від розміру екрана програми.

Після перерахунку пікселів Ви отримаєте абстрактну величину, яка називається:

dip або dp - Density-independent Pixels . Незалежний від густини піксель. Який дозволить писати інтерфейс програми, не замислюючись про те, скільки буде пікселів за шириною та висотою екрана на смартфоні або планшеті.

Розробка масштабованого інтерфейсу під Android

Як відомо, пристроїв під Android безліч і всі вони мають різні дозволи екранів, тому компанія Google дає наступну рекомендацію з розробки масштабованого інтерфейсу:

  • Інтерфейс необхідно створювати на основі dip (незалежних від щільності пікселів)
  • І в загальному випадку застосовувати наступну формулу для перекладу dip у кількість пікселів:

px = dp * (dpi / 160)

Ця формула переводить співвідношення щільності пікселів цільового пристрою до щільності пікселів пристрою з екраном mdpi, тобто medium dpi . Формула працює чудово і для 5-ти дюймових full HD екранів.

Якщо говорити конкретно про Qt, то в даному випадку необхідно помітити, що Qt не дає можливості завдання параметрів інтерфейсу відразу в dip. Необхідно проводити перерахунок щільності пікселів dpi у пікселі щодо dip. Тобто використовувати вище наведену формулу.

При розробці Scalable інтерфейсу на Qt Qml можна використовувати окремий об'єкт, який прийматиме Ваші dip пікселі та повертатиме їх еквівалент у фізичних пікселях екрану, як у програмному коді, наведеному нижче.

Функція pixelDenstity повертає щільність пікселів на мм, тому отриману величину Ми множимо на 25.4 щоб перевести в дюйми. І далі функція даного об'єкта, отримуючи dip пікселі, повертає вже масштабовану кількість фізичних пікселів на екрані цільового пристрою. При цьому я додав перевірку на щільність пікселів менше 120 dpi . Це необхідно для звичайних декстопів, як наприклад мій ноутбук з діагоналлю 15,6 дюйма та роздільною здатністю 1366 на 768 . У разі щільність дорівнює 72 dpi . І якщо цю величину ще й поділити на 160, тоді інтерфейс вийде дуже маленького розміру, що теж не прийнятно для настільного ПК. Тому для десктопів не проводиться переклад dip у px. dip у цьому випадку дорівнює 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);
        }
    }
}

Підсумок. Scalable інтерфейс

В результаті роботи функції даного об'єкта мені вдалося отримати наступне зображення програми, що розробляється на екрані смартфона Meizu m1 note з full HD екраном на 5,5" і на 15,6" екрані ноутбука

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.

Вам це подобається? Поділіться в соціальних мережах!

Коментарі

Only authorized users can post comments.
Please, Log in or Sign up
d
  • dsfs
  • 26 квітня 2024 р. 04:56

C++ - Тест 004. Указатели, Массивы и Циклы

  • Результат:80бали,
  • Рейтинг балів4
d
  • dsfs
  • 26 квітня 2024 р. 04:45

C++ - Тест 002. Константы

  • Результат:50бали,
  • Рейтинг балів-4
d
  • dsfs
  • 26 квітня 2024 р. 04:35

C++ - Тест 001. Первая программа и типы данных

  • Результат:73бали,
  • Рейтинг балів1
Останні коментарі
k
kmssr08 лютого 2024 р. 18:43
Qt Linux - Урок 001. Автозапуск програми Qt під Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
АК
Анатолий Кононенко05 лютого 2024 р. 01:50
Qt WinAPI - Урок 007. Робота з ICMP Ping в Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
EVA
EVA25 грудня 2023 р. 10:30
Boost - статичне зв&#39;язування в проекті CMake під Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
J
JonnyJo25 грудня 2023 р. 08:38
Boost - статичне зв&#39;язування в проекті CMake під Windows Сделал всё по-как у вас, но выдаёт ошибку [build] LINK : fatal error LNK1104: не удается открыть файл "libboost_locale-vc142-mt-gd-x64-1_74.lib" Хоть убей, не могу понять в чём дел…
G
Gvozdik18 грудня 2023 р. 21:01
Qt/C++ - Урок 056. Підключення бібліотеки Boost в Qt для компіляторів MinGW і MSVC Для решения твой проблемы добавь в файл .pro строчку "LIBS += -lws2_32" она решит проблему , лично мне помогло.
Тепер обговоріть на форумі
PS
Peter Son03 травня 2024 р. 17:57
Best Indian Food Restaurant In Cincinnati OH Ready to embark on a gastronomic journey like no other? Join us at App india restaurant and discover why we're renowned as the Best Indian Food Restaurant In Cincinnati OH . Whether y…
Evgenii Legotckoi
Evgenii Legotckoi02 травня 2024 р. 14:07
Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Добрый день. По моему мнению - да, но то, что будет касаться вызовов к функционалу Андроида, может создать огромные трудности.
IscanderChe
IscanderChe30 квітня 2024 р. 04:22
Во Flask рендер шаблона не передаётся в браузер Доброе утро! Имеется вот такой шаблон: <!doctype html><html> <head> <title>{{ title }}</title> <link rel="stylesheet" href="{{ url_…
G
Gar22 квітня 2024 р. 05:46
Clipboard Как скопировать окно целиком в clipb?
Павел Дорофеев
Павел Дорофеев14 квітня 2024 р. 02:35
QTableWidget с 2 заголовками Вот тут есть кастомный QTableView с многорядностью проект поддерживается, обращайтесь

Слідкуйте за нами в соціальних мережах