QT5基础操作(一)

  说明:代码框上面是对操作描述,代码框内部具体操作

运行时界面字体显示不全(分辨率问题)

//解决办法:在主函数(main.cpp)的QApplication a(argc,argv)前加入一行:
QCoreApplication::setAttribute(Qt::AA_EnableHighDpiScaling);

代码方式建立组件

.h文件中private 声明指针,在.cpp文件中new实例化对象,后可在cpp中以指针方式使用

代码方式进行组件布局(其实这步可以在qt designer中完成)

1.定义QGridLayout/水平/竖直对象a
2.a->addWidget(部件名,0,0) //添加组件,后面是对应组件x,y坐标,都从0开始

QTextEdit设置文字存储格式

    QTextEdit *textLeft = new QTextEdit();
    textLeft->setAlignment(Qt::AlignCenter);
    /*
     * setAlignment为设置中文字对齐方式
     * 包括AlignLeft 左对齐
     *      AlignRight 右对齐
     *      AlignCenter 中心对齐
     *      AlignUp 文字与顶部对齐
     *      AlignBottom 文字与底部对齐
     */

窗口显示拖拽条

  QSplitter *splitterRight = new QSplitter();
  splitterRight->setOpaqueResize(false); //用于显示拖拽条,flase不显示,true显示

设置当前窗口标题(其实不加tr,直接双引号也可以。A是当前界面的对象名)

A->setWindowTitle(tr("Splitter"));

显示当前窗口(A是当前界面的对象名)

A->show();

关闭当前窗口(A是当前界面的对象名,如果是在自己的CPP文件内使用可以用this)

A->close();;

设置可移动窗口

    QDockWidget *dock = new QDockWidget(tr("DockWindow1"), this);
    //可移动
    dock->setFeatures(QDockWidget ::DockWidgetMovable);
    dock->setAllowedAreas(Qt::LeftDockWidgetArea|Qt::RightDockWidgetArea);

将Label设置成镶嵌类型

OtherLabel->setFrameStyle(QFrame::Panel|QFrame::Sunken);//设置控件的风格,镶嵌阴影型

引用图像作为控件(比如照片)

    HeadIconLabel = new QLabel;
    QPixmap icon("123.jpg");//引用图像时可放置于build目录下
    HeadIconLabel->setPixmap(icon);

代码调整控件大小(a为任意控件对象)

a->resize(x,y);

如果需要显示抽屉效果,每层抽屉又分N个按键(例如QQ聊天列表)

QToolBox

QToolButton中setToolButtonStyle各个参数设置

    /*
     * setToolButtonStyle用来设置图标和文字的位置
     * 包括:
     * ToolButtonIconOnly 只显示图标
     * ToolButtonTextOnly 只显示文字
     * ToolButtonTextBesidesIcon 文字在图标旁边
     * ToolButtonTextUnderIcon 文字在图标下面
     */
    toolBtn1_1->setToolButtonStyle(Qt::ToolButtonTextBesideIcon);

设计进度框(像windows下删除大文件下进度条)

QProgressDialog

设置窗口置顶(A为界面对象名)

A->setWindowFlags(Qt::FramelessWindowHint);

设置窗口透明度(A为界面对象名)

    //设置透明度为0.5
A->setWindowOpacity(0.5);

鼠标移动事件

//调用时鼠标移动使用的应该是->buttons()而不是->button
//以下两个函授完成时钟随着鼠标移动的功能
void DigiClock::mousePressEvent(QMouseEvent *event)
{
    if (event->buttons() == Qt::LeftButton)
    {
        //以左上角为标准计算拖动距离
        //globalPos代表全局坐标,以整个屏幕为界面显示
        dragPosition = event->globalPos()-frameGeometry().topLeft();
        event->accept();
    }
    if (event->buttons() == Qt::RightButton)
    {
        close();
    }
}

void DigiClock::mouseMoveEvent(QMouseEvent *event)
{
    if (event->buttons() & Qt::LeftButton)
    {
        move(event->globalPos()-dragPosition);
        event->accept();
    }
}

按键:按下去变色,松开后恢复(使用QTime实现)

//(注意:基本思想是修改样式表的背景,所以要保证前后字体大小统一。样式表的话推荐选择border-image,background的图案会显示不全)
    this->ui->P_back->setStyleSheet("QPushButton{border-image: url(:/tubiao/14.png);color: rgb(255, 255, 255);font: 14pt 楷体;}");
    //使用等待效果,让图标变换有显示
    QTime dieTime= QTime::currentTime().addMSecs(300);
    while (QTime::currentTime() < dieTime)
        QCoreApplication::processEvents(QEventLoop::AllEvents, 100);
    this->close();
    this->ui->P_back->setStyleSheet("QPushButton{border-image: url(:/tubiao/10.png);color: rgb(255, 255, 255);font: 14pt 楷体;}");

读取TXT文件内的数据

  int i = 1;
    QFile file("xxx.txt");    //文件路径,最好是绝对路径
     if (!file.open(QIODevice::ReadOnly | QIODevice::Text))
     {
          qDebug()<<"Can't open the file!";
          return;
     }
     QTextStream in(&file);  //文件流
     QString line = in.readLine() ;   //读取一行
     while (!line.isNull())
     {
         line = in.readLine();
         a[i] = line.toFloat();
         i = i+1;
     }

当前时钟,动态变化

  //主函数
    QTimer *timer = new QTimer();
    connect(timer,SIGNAL(timeout()),this,SLOT(showtime_1()));
    timer->start(1000);//1s改变一次

    //槽函数showtime_1
    QDateTime *datatime = new QDateTime(QDateTime::currentDateTime());
    QString str = datatime->toString("yyyy-MM-dd hh:mm:ss ddd");
    ui->D_time->setText(str);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值