引言
当手机由竖屏切换成横屏时我们通常需要调整程序的UI布局以适应屏幕; 或者更进一步当手机的方向发生变化时,如果我们也想让程序的UI随之改变该怎么做呢?那么本文就为大家介绍一种思路。
使用sensor感知方向变化
现在QML中已经可以直接使用Sensor了,不需要我们自己再通过c++代码的方式间接访问。我们获得当前手机方向信息后,就把当前状态设置为对应状态,而后我吗就可以根据不同的状态进行布局了。
OrientationSensor {
id: orientation
active: true
onReadingChanged: {
if (reading.orientation == OrientationReading.TopUp)
content.state = "TopUp";
else if (reading.orientation == OrientationReading.TopDown)
content.state = "TopDown";
else if (reading.orientation == OrientationReading.LeftUp)
content.state = "LeftUp";
else if (reading.orientation == OrientationReading.RightUp)
content.state = "RightUp";
else if (reading.orientation == OrientationReading.FaceUp)
content.state = "FaceUp";
else if (reading.orientation == OrientationReading.FaceDown)
content.state = "FaceDown";
else
content.state = "";
}
}
切换布局
根据状态设置每一个矩形的宽度,从而适应屏幕的变化。
Flow {
anchors.top: parent.top
anchors.left: parent.left
anchors.right: parent.right
anchors.margins: 10
spacing: 4
Rectangle {
width: (content.state == "LeftUp" || content.state == "RightUp") ? (parent.width-8)/3 : (parent.width-4)/2
height: 60
color: "yellow"
Text {
text: "1"
color: "black"
font.pointSize: 10
anchors.centerIn: parent
}
}
// ...以下省略
程序截图
分享到:
相关推荐
QWidget嵌入Qml界面的小Demo,比较简单的代码,可以提供大家参考!但是还是有一些问题需要大家解决,如果有一些BUG能告知最好
自学QML边学边做了一个小例子,希望对大家学习有帮助!
QML 实现anroid风格的界面 主要是通过添加google的Material QML实现的类 通过Qt 编译 从而变成QML的第三方类
qml界面布局的小demo
Android 原生View显示到QML界面上
QWidget通过QQuickWidget嵌入QML界面,QWidget与QML界面互相发送信号进行交互
Qt 5.7 qml图片旋转拖动鼠标点击变化
实现了Qt 应用微信登录的接入,里面使用了java发送数据到QML界面,及QML调用java方法,使用时需要将android目录下的src/org/qtproject/base/Constants.java中的APP_ID和APP_SECRET切换成自己注册的即可使用
QML智能家居系统代码, 主要由Qt的QML语言写成;主要由欢迎界面、房间选择界面、灯光控制、窗帘控制、环境控制等界面构成.。
qml编写的播放器界面,列表功能,没有实现播放音乐功能,只是一个UI列表界面,读取音乐列表格式显示。
qml 实现的智能家居界面,可以在安卓平台上使用
在Qt quick中简单实现界面跳转和单选框的应用
Qt调用qml界面
QtQml开发 - 交互之从Qml界面访问Cpp方法
常用QML登录界面源码,一搬常用QML登录代码编写,有用户名和密码验证
用QML 写的一个界面,天蓝色,自我感觉良好,后续还要与c++交互
qml中treeview的用法,界面跟后端数据交互,简单的教学例子
QML和C++结合实现的图像处理功能的代码,带界面显示
Qt之360安全卫士纯qml实现界面
QT quick下机遇微信界面写的Demo。主要用QML写的界面