МихаилллApril 8, 2019, 8:05 a.m.
Как в QML сделать растягивающийся интерфейс
Добрый день.
Как в QML сделать растягивающийся интерфейс?
В Qt дизайнере можно регулировать отношение виджитов на экране через соотношение сгрупированных лэйаутов на экране. Хорошо это описанно
тут
Но как это можно реализовать в QML?
Вот пример страницы, на которой тринируюсь
import QtQuick 2.4 import QtQuick.Controls 2.4 Item { id: page2element width: 400 height: 600 property alias page2Button0: page2Button0 property alias page2Button1: page2Button1 property alias page2Button2: page2Button2 property alias page2Button3: page2Button3 property alias page2ButtonMenu: page2ButtonMenu property alias page2Label1: page2Label1 property alias page2Label2: page2Label2 Button { id: page2ButtonMenu x: 150 y: 493 text: qsTr("МЕНЮ") anchors.horizontalCenter: parent.horizontalCenter font.pointSize: 18 } Label { id: page2labe0 x: 57 y: 49 width: 286 height: 33 text: qsTr("Выберете красный цвет") anchors.horizontalCenterOffset: 0 anchors.horizontalCenter: parent.horizontalCenter font.family: "Verdana" horizontalAlignment: Text.AlignHCenter font.pixelSize: 22 font.weight: Font.Thin } Label { id: page2Label1 x: 122 y: 343 width: 156 height: 56 text: qsTr("Побед: ") anchors.horizontalCenter: parent.horizontalCenter horizontalAlignment: Text.AlignHCenter font.pointSize: 20 } Label { id: page2Label2 x: 122 y: 419 width: 156 height: 56 text: qsTr("1 из 20") anchors.horizontalCenter: parent.horizontalCenter horizontalAlignment: Text.AlignHCenter font.pointSize: 20 } Row { id: row x: 29 y: 102 spacing: 50 anchors.horizontalCenter: parent.horizontalCenter Button { id: page2Button0 width: 100 height: 100 Image { id: page2image1 width: 100 height: 100 anchors.rightMargin: 0 anchors.bottomMargin: 0 anchors.fill: parent source: "qrc:/images/images/close.png" fillMode: Image.Stretch } } Button { id: page2Button1 width: 100 height: 100 Image { id: page2image2 width: 100 height: 100 anchors.rightMargin: 0 anchors.bottomMargin: 0 anchors.fill: parent source: "qrc:/images/images/close.png" fillMode: Image.Stretch } } } Row { id: row1 x: 57 y: 220 spacing: 50 anchors.horizontalCenter: parent.horizontalCenter Button { id: page2Button2 width: 100 height: 100 Image { id: page2image3 width: 100 height: 100 anchors.leftMargin: 0 anchors.topMargin: 0 anchors.rightMargin: 0 anchors.bottomMargin: 0 anchors.fill: parent source: "qrc:/images/images/close.png" fillMode: Image.Stretch } } Button { id: page2Button3 width: 100 height: 100 Image { id: page2image4 width: 100 height: 100 anchors.rightMargin: 0 anchors.bottomMargin: 0 anchors.fill: parent source: "qrc:/images/images/close.png" fillMode: Image.Stretch } } } states: [ State { name: "Page2State1" PropertyChanges { target: page2image1 source: "qrc:/images/images/red.png" } PropertyChanges { target: page2image2 source: "qrc:/images/images/black.png" } PropertyChanges { target: page2image3 source: "qrc:/images/images/black.png" } PropertyChanges { target: page2image4 source: "qrc:/images/images/black.png" } }, State { name: "Page2State2" PropertyChanges { target: page2image1 source: "qrc:/images/images/black.png" } PropertyChanges { target: page2image2 source: "qrc:/images/images/red.png" } PropertyChanges { target: page2image3 source: "qrc:/images/images/black.png" } PropertyChanges { target: page2image4 source: "qrc:/images/images/black.png" } }, State { name: "Page2State3" PropertyChanges { target: page2image1 source: "qrc:/images/images/black.png" } PropertyChanges { target: page2image2 source: "qrc:/images/images/black.png" } PropertyChanges { target: page2image3 source: "qrc:/images/images/red.png" } PropertyChanges { target: page2image4 source: "qrc:/images/images/black.png" } }, State { name: "Page2State4" PropertyChanges { target: page2image1 source: "qrc:/images/images/black.png" } PropertyChanges { target: page2image4 source: "qrc:/images/images/red.png" } PropertyChanges { target: page2image2 source: "qrc:/images/images/black.png" } PropertyChanges { target: page2image3 source: "qrc:/images/images/black.png" } }, State { name: "Page2State0" } ] }
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.Do you like it? Share on social networks!
AD
- Akiv Doros
- Nov. 11, 2024, 10:58 p.m.
C ++ - Test 004. Pointers, Arrays and Loops
- Result:50points,
- Rating points-4
m
- molni99
- Oct. 26, 2024, 8:37 a.m.
C ++ - Test 004. Pointers, Arrays and Loops
- Result:80points,
- Rating points4
m
- molni99
- Oct. 26, 2024, 8:29 a.m.
C ++ - Test 004. Pointers, Arrays and Loops
- Result:20points,
- Rating points-10
Last comments
Django - Tutorial 055. How to write auto populate field functionality Freckles because of several brand names retin a, atralin buy generic priligy
QML - Tutorial 035. Using enumerations in QML without C ++ priligy cvs 24 Together with antibiotics such as amphotericin B 10, griseofulvin 11 and streptomycin 12, chloramphenicol 9 is in the World Health Organisation s List of Essential Medici…
Qt/C++ - Lesson 052. Customization Qt Audio player in the style of AIMP It decreases stress, supports hormone balance, and regulates and increases blood flow to the reproductive organs buy priligy online safe Promising data were reported in a PDX model re…
Heap sorting algorithm The role of raloxifene in preventing breast cancer priligy precio
PyQt5 - Lesson 006. Work with QTableWidget buy priligy 60 mg 53 have been reported by Javanovic Santa et al
Now discuss on the forum
добавить qlineseries в функции buy priligy senior brother Chu He, whom he had known for many years
Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
IscanderCheOct. 31, 2024, 10:43 p.m.
Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
ИМ
Реализация навигации по разделам Спасибо Евгений!
Игорь МаксимовOct. 3, 2024, 11:05 a.m.
у тебя все элементы имеют точку привязки (х,у), используй соотношение елементов друг к другу
А как это сделать. Нужно узнавать ширину и высоту дисплея?
суть. я думаю поймете, а там експеременты все покажут
и ознакомьтесь с этим
Спасибо. Статью читал. К сожалению этот вариант страницы не запускается в скомпилированной программе. Но по такому принципу сделал нижиприведенный код. Но при этом не получилось достичь масштабируемости. Помогите пожалуйста решить это:
а что не понравилось в моем коде выше? там ваш код который маштабируется
Кажется я понял, нужно похоже так делать, тогда пропорции сохраняются
QML достаточно гибок, чтоб достичь желаемого разными способами, достаточно включить фантазию
Но есть ли возможности в дизайнере это сделать, без лишнего кода?
А Ваш код ошибок не выдовал, но программа просто не открывала эту страницу
учитесь делать рауками