当前位置: 首页 > wzjs >正文

在建设政府门户网站时百度指数的基本功能

在建设政府门户网站时,百度指数的基本功能,厨之梦进口食品网站谁做的,门户网站创建文章目录 概述 一、使用虚拟键盘 二、项目文件定义 1.VirtualKeyboard.qml 2.main.qml 3.main.cpp 三、编译运行 1.编译 2.运行 3.运行效果 总结 概述 在 Qt 开发中,虚拟键盘是移动设备和嵌入式设备中常用的输入工具。本文将详细介绍如何通过 QML 修改虚拟键盘样式…

文章目录

概述

一、使用虚拟键盘

二、项目文件定义

1.VirtualKeyboard.qml

2.main.qml

3.main.cpp

三、编译运行

1.编译

2.运行

3.运行效果

总结


概述

在 Qt 开发中,虚拟键盘是移动设备和嵌入式设备中常用的输入工具。本文将详细介绍如何通过 QML 修改虚拟键盘样式,并实现从 QML 界面跳转到 QWidget 设计的 UI 界面并将Qt程序移植到嵌入式Linux开发板。


一、使用虚拟键盘

Qt 提供了虚拟键盘模块,只需在.pro文件中添加

QT += virtualkeyboard

再在main.cpp中添加

qputenv("QT_IM_MODULE", QByteArray("qtvirtualkeyboard"));

即可在输入框中使用虚拟键盘,在将程序移植到嵌入式linux开发板时,发现点击输入框时,虚拟键盘会覆盖整个显示屏,如下,于是使用qml来修改虚拟键盘的样式就非常有必要。

二、项目文件定义

Qt 提供了 QtQuick.VirtualKeyboard 模块,用于在 QML 中集成虚拟键盘。使用者可通过使用qml文件来对虚拟键盘的样式进行修改,如下即为项目目录:

其中 VirtualKeyboard.qml为虚拟键盘样式定义,在main.qml中定义了登陆界面,用户点击登陆后即可跳转到基于Qwidget的form.ui界面,

1.VirtualKeyboard.qml

定义一个虚拟键盘的输入面板,并设置了其样式和行为。它位于屏幕底部,默认是隐藏状态,当激活时会平滑地显示出来。

import QtQuick 2.12
import QtQuick.VirtualKeyboard 2.2
import QtQuick.VirtualKeyboard.Settings 2.2InputPanel {id: inputPanelz: 99y: parent.height // 默认隐藏width: parent.widthvisible: truestates: State {name: "visible"when: inputPanel.activePropertyChanges {target: inputPanely: parent.height - inputPanel.height}}transitions: Transition {from: ""to: "visible"reversible: trueParallelAnimation {NumberAnimation {properties: "y"duration: 250easing.type: Easing.InOutQuad}}}Component.onCompleted: {VirtualKeyboardSettings.styleName = "retro" // 复古样式VirtualKeyboardSettings.wordCandidateList.alwaysVisible = trueVirtualKeyboardSettings.activeLocales = ["zh_CN", "en_US"] // 改为中文和英文}
}

2.main.qml

代码中创建了一个简单的登录界面,在点击输入框时,会弹出修改样式之后的虚拟键盘并且虚拟键盘占显示屏幕的一半,点击登录按键后跳转到基于QWidget的form.ui界面。

import QtQuick 2.12
import QtQuick.Window 2.12
import QtQuick.Layouts 1.12
import QtQuick.Controls 2.5Window {id: rootvisible: truewidth: 800height: 480title: qsTr("Demo")signal loginClicked() // 定义信号ColumnLayout {anchors.top: parent.topanchors.topMargin: root.height * 0.2anchors.horizontalCenter: parent.horizontalCenterspacing: 25RowLayout {spacing: 25Text {text: qsTr("用户名:")font.family: "微软雅黑"font.pixelSize: 20}TextField {id: usernameFieldplaceholderText: "输入用户名.."font.family: "微软雅黑"font.pixelSize: 16Layout.preferredWidth: root.width * 0.25background: Rectangle {radius: 4border.color: parent.focus ? "#498ff8" : "#C4DBFC"}}}RowLayout {spacing: 25Text {text: qsTr("密   码:")font.family: "微软雅黑"font.pixelSize: 20}TextField {id: passwordFieldplaceholderText: "输入密码.."font.family: "微软雅黑"font.pixelSize: 16Layout.preferredWidth: root.width * 0.25background: Rectangle {radius: 4border.color: parent.focus ? "#498ff8" : "#C4DBFC"}}}// 添加登录按钮Button {text: qsTr("登录")font.family: "微软雅黑"font.pixelSize: 16Layout.alignment: Qt.AlignHCenteronClicked: {root.loginClicked() // 触发信号root.hide() // 隐藏当前窗口}}}// 嵌入虚拟键盘Loader {id: keyboardLoadersource: "VirtualKeyboard.qml"anchors.bottom: parent.bottomwidth: parent.width}
}

3.main.cpp

通过Qt框架整合了QML界面与后台逻辑,实现了高DPI支持、虚拟键盘的启用,并通过信号和槽机制连接了QML的交互与C++的业务逻辑。

#include <QApplication> // 替换 QGuiApplication
#include <QQmlApplicationEngine>
#include <QQuickWindow>
#include "form.h"int main(int argc, char *argv[])
{QCoreApplication::setAttribute(Qt::AA_EnableHighDpiScaling);// 启用虚拟键盘模块qputenv("QT_IM_MODULE", QByteArray("qtvirtualkeyboard"));QApplication app(argc, argv); // 使用 QApplicationQQmlApplicationEngine engine;const QUrl url(QStringLiteral("qrc:/main.qml"));QObject::connect(&engine, &QQmlApplicationEngine::objectCreated,&app, [url](QObject *obj, const QUrl &objUrl) {if (!obj && url == objUrl)QCoreApplication::exit(-1);}, Qt::QueuedConnection);engine.load(url);// 获取 QML 主窗口QObject *rootObject = engine.rootObjects().first();QQuickWindow *mainWindow = qobject_cast<QQuickWindow*>(rootObject);// 创建 Form 界面Form form;QObject::connect(&form, &Form::backToLogin, [mainWindow, &form]() {form.hide();mainWindow->show();});// 连接 QML 登录按钮信号槽QObject::connect(rootObject, SIGNAL(loginClicked()), &form, SLOT(show()));return app.exec();
}

三、编译运行

1.编译

使用qmake,make对该项目进行编译并通过使用scp将执行文件挂载到IMX6ULL中,

2.运行

在嵌入式设备中执行该文件:

3.运行效果


总结

在 Qt 中使用虚拟键盘,并通过 QML 修改其样式,解决了虚拟键盘在嵌入式设备中覆盖全屏的问题。同时,实现了从 QML 界面跳转到 QWidget 设计的 UI 界面,并将程序成功移植到嵌入式 Linux 开发板。

http://www.dtcms.com/wzjs/531001.html

相关文章:

  • vue做的网站大全中央网站seo
  • 更换网站需要怎么做北京网站开发
  • design设计网站怎么注册个人网站
  • 怎么做能让网站收录的快seo深度优化公司
  • 做网站需要php吗俄罗斯搜索引擎入口
  • 网站建设模板代码竞价恶意点击犯法吗
  • 物联网网站设计山东搜索引擎优化
  • 专业的网站建设官网合肥推广外包公司
  • dw怎么把网站做的漂亮青岛seo推广公司
  • 做营利网站的风险推广软文范例100字
  • 公司网站建设管理意见免费投放广告平台
  • wordpress 定时显示威海百度seo
  • 网站后台关键词链接怎样做个人网站免费推广
  • 学网站开发跟那个专业最相近禁止搜索引擎收录的方法
  • 免费的网站有哪些平台小广告公司如何起步
  • 网站模板免费推荐推广普通话手抄报内容大全
  • 什么是wordpress主题杭州网站优化公司哪家好
  • python+网站开发实例教程网络营销与直播电商
  • 关于建设校园网站申请百度引流怎么推广
  • 制作网页的网站湖南seo网站多少钱
  • 做名片用哪个网站热狗网站关键词优化
  • 数据库修改网站管理员密码上海排名优化seo
  • wordpress做电商安全吗seo的培训班
  • vi设计整套济南网站seo优化
  • 织梦网站如何做301跳转域名注册网
  • 聊城住房建设局网站线上宣传的方式
  • 网站建设 自适应seo攻略
  • 物流企业网站织梦模板怀化网络推广
  • 搜搜网站提交入口windows优化大师
  • 网站建设地域名游戏推广平台有哪些