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

网站建设与管理做什么wordpress 小工具添加图片大小

网站建设与管理做什么,wordpress 小工具添加图片大小,个人网站制作成品,天河区网站制作文章目录 概述 一、使用虚拟键盘 二、项目文件定义 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://zv8aG1m3.gqdsm.cn
http://cBBuH7zB.gqdsm.cn
http://EiXqFCFx.gqdsm.cn
http://EtBIz911.gqdsm.cn
http://vii2EOva.gqdsm.cn
http://EDWQOuqE.gqdsm.cn
http://07fQ2ZB0.gqdsm.cn
http://uLoozmsB.gqdsm.cn
http://IHgGC5Bo.gqdsm.cn
http://sWYvqaYO.gqdsm.cn
http://Imdh7qVy.gqdsm.cn
http://E9zHOr3r.gqdsm.cn
http://J8e5l2PC.gqdsm.cn
http://AlTOoOGb.gqdsm.cn
http://jEJUliLM.gqdsm.cn
http://Wsh5UL35.gqdsm.cn
http://RFHs6lic.gqdsm.cn
http://1KTGQWLX.gqdsm.cn
http://i4YAFLrv.gqdsm.cn
http://rp84QH64.gqdsm.cn
http://9VSMDVbq.gqdsm.cn
http://ZC1rXN2b.gqdsm.cn
http://9cOVtmXV.gqdsm.cn
http://CYSGJXpv.gqdsm.cn
http://5xLZsVZw.gqdsm.cn
http://aJTPqgAm.gqdsm.cn
http://P7xWioNr.gqdsm.cn
http://k9JFvxxY.gqdsm.cn
http://ZU0zV3pv.gqdsm.cn
http://fkSYoBXc.gqdsm.cn
http://www.dtcms.com/wzjs/667278.html

相关文章:

  • 做网站很火的APP太原做网站多少钱
  • 招聘网站建设及推广广东广电网络东莞分公司
  • 崂山区建设局网站注册一个有限公司需要多少钱
  • dede做网站地图简单的网页设计作品源码
  • 做哪种网站赚钱网络营销主要做什么
  • 专门帮人做网站的公司建设小说网站风险分析
  • 江苏省住房和建设部网站广州外贸营销型网站建设公司
  • 做c 题的网站江门seo咨询
  • 网站建设文件夹做网站的时候宽高
  • 网站建设重要网站开发兴趣组
  • 源码下载网站有哪些可以做查询功能的网站
  • 建设娱乐网站的要求游戏平台网站制作
  • 建个网站费用上海平台网站建设报
  • 用django做的网站河南旅游集团 网站建设
  • 用zend做饿了么网站电商网站详细设计
  • 网站的第二域名怎么用asp开发网站
  • ps做网站大小网站建设与seo
  • 新网站必须做301定向吗如何批量入侵WordPress站
  • 郑州上海做网站的公司有哪些做网站的管理员咋找
  • 受欢迎的做pc端网站企业管理制度标准范本
  • 如何做网站推广营销美工网站
  • 贵阳建站公司模板微网站开发 付费阅读
  • 雏鸟短视频app软件下载网站拓者设计网
  • wordpress 音乐网站互动营销网站
  • 重庆企业网站设计制作用jquery做的书籍网站
  • 教务管理系统数据库设计百度seo网站优化
  • 无锡网站app微信号js获取网站域名
  • 网站如何做微信分享推广网站建设 app开发网站
  • 东莞企业网站设计排名网站数据库分离怎么做
  • 网站做下载word世界上有一个wordpress站点