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

嵌入式-QT学习-小练习

1. 实现多窗口

2. 给按键增加图标

3. 动图展示

结果演示:

Mul_Con

main.cpp

#include "widget.h"#include <QApplication>int main(int argc, char *argv[])
{QApplication a(argc, argv);Widget w;w.show();return a.exec();
}

一、第一个窗口展示

ui界面布局:未运行前

运行后的界面展示

二、第二个窗口界面

ui界面设计

运行界面

第一个窗口实现代码

widget.cpp文件

#include "widget.h"
#include "ui_widget.h"
#include <QIcon>
#include <QDebug>
#include <QPixmap>
#include <QMovie>Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);this->setWindowTitle("KOKO");//构造第二个窗口w2 = new Dialog;//直接将窗口的show方法(本来就是一个槽函数),绑定到信号connect(w2, &Dialog::backWindow, this, &Widget::show);this->setFixedSize(this->size());//固定当前窗口大小//给button设置一个图标QIcon icon("/home/ubuntu/Pictures/avocado.jpg");//路径ui->pushButton->setIcon(icon);ui->pushButton->setIconSize(ui->pushButton->size() / 2);//设置快捷键ui->pushButton->setShortcut(QKeySequence(""));//控件ui->label->setText("hello");//设置lable显示图片QPixmap *map = new QPixmap("/home/ubuntu/Pictures/avocado.jpg");//图片大小qDebug()<<"图片大小=" << map->size();ui->label->setPixmap(*map);//设置图片缩放适应labelui->label->setScaledContents(true);//label适应图片// ui->label->resize(map->size());//ui->label->move(0,0);//this->resize(ui->label->size());//设置label在其他控件后面ui->label->lower();//放置在最后面的层ui->pushButton->raise();//放置在最前面的层//label显示一个数ui->label_2->setNum(125.125);//label显示动图GIFQMovie *movie = new QMovie("/home/ubuntu/Pictures/koko.gif");ui->label->setMovie(movie);//播放设置movie->start();//开始播放movie->setSpeed(100);//播放速度qDebug() << "move size=" << movie->scaledSize();//视频/图片适应labelui->label->setScaledContents(true);
}Widget::~Widget()
{delete ui;
}void Widget::ShowThisWind()
{this->show();
}void Widget::on_pushButton_clicked()
{qDebug("点击");//按钮按下状态if(ui->pushButton->isChecked() == true){qDebug("按下");}else {qDebug("弹起");}//显示第二个窗口w2->show();//模态方式显示//w2->exec();//非模态显示this->hide();
}

widget.h文件

#ifndef WIDGET_H
#define WIDGET_H
#include "dialog.h"
#include <QWidget>QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACEclass Widget : public QWidget
{Q_OBJECTpublic:Widget(QWidget *parent = nullptr);~Widget();private slots:void on_pushButton_clicked();public slots:void ShowThisWind();private:Ui::Widget *ui;Dialog *w2;
};
#endif // WIDGET_H

第二个窗口代码实现

dialog.cpp

#include "dialog.h"
#include "ui_dialog.h"
#include <QMovie>
#include <QDebug>
Dialog::Dialog(QWidget *parent) :QDialog(parent),ui(new Ui::Dialog)
{ui->setupUi(this);this->setWindowTitle("罗小黑");this->setFixedSize(this->size());//固定窗口大小//设置label在其他控件后面ui->label->lower();//放置在最后面的层ui->pushButton->raise();//放置在最前面的层//label显示动图GIFQMovie *movie = new QMovie("/home/ubuntu/Pictures/lxh.gif");ui->label->setMovie(movie);//播放设置movie->start();//开始播放movie->setSpeed(100);//播放速度qDebug() << "move size=" << movie->scaledSize();//视频/图片适应labelui->label->setScaledContents(true);}Dialog::~Dialog()
{delete ui;
}void Dialog::on_pushButton_clicked()
{//关闭this->close();//关闭窗口
}void Dialog::on_pushButton_2_clicked()
{this->hide();//返回上一个窗口emit backWindow();
}

dialog.h文件

#ifndef DIALOG_H
#define DIALOG_H#include <QDialog>namespace Ui {
class Dialog;
}class Dialog : public QDialog
{Q_OBJECTpublic:explicit Dialog(QWidget *parent = nullptr);~Dialog();signals:void backWindow();private slots:void on_pushButton_clicked();void on_pushButton_2_clicked();private:Ui::Dialog *ui;
};#endif // DIALOG_H

http://www.lryc.cn/news/441010.html

相关文章:

  • 使用 Flask-Limiter 和 Nginx 实现接口访问次数限制
  • 【数据结构】排序算法---冒泡排序
  • mysql数据库中事务锁的机制
  • 并发工具类-CountDownLatch
  • 进程的重要函数
  • python 实现average median平均中位数算法
  • HTML概述
  • 【FFT】信号处理——快速傅里叶变换【通俗易懂】
  • 电脑升级WIN11之后需要注意哪些东西
  • GEE 教程:利用sentinel-5p数据进行长时序CO一氧化碳的监测分析并结合夜间灯光数据分析
  • 【教程】鸿蒙ARKTS 打造数据驾驶舱---前序
  • Html css样式总结
  • 决策树基础概论
  • Spring Boot集成Akka Cluster快速入门Demo
  • django学习入门系列之第十点《A 案例: 员工管理系统10》
  • Unity实战案例全解析:PVZ 植物卡片状态分析
  • 判断变量是否为有限数字(非无穷大或NaN)math.isfinite() 判断变量是否为无穷大(正无穷大或负无穷大)math.isinf()
  • idea使用阿里云服务器运行jar包
  • 解决nginx代理SSE接口的响应没有流式返回
  • 11 - TCPClient实验
  • React框架搭建,看这一篇就够了,看完你会感谢我
  • 【rust】rust条件编译
  • 一键文本提示实现图像对象高质量剪切与透明背景生成
  • 游戏客服精华回复快捷语大全
  • 国内版Microsoft Teams 基础版部署方案
  • 计算机网络 ---- OSI参考模型TCP/IP模型
  • 在Windows环境下部署Java的Web项目集成工具的整体流程和详细步骤
  • 9.18作业
  • 【算法】滑动窗口—最小覆盖子串
  • “Fast-forward“ in git-pull result