欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 财经 > 金融 > 【QT】控件8

【QT】控件8

2024/12/4 21:44:33 来源:https://blog.csdn.net/yyqzjw/article/details/144053769  浏览:    关键词:【QT】控件8

1.QDial

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
通过调节旋钮位置来控制窗口的不透明度:

void Widget::on_dial_valueChanged(int value)
{qDebug()<<value;this->setWindowOpacity((double)value/100);
}

效果演示:

2.Date/Time Edit

计算两个日期的差值
ui界面设计
在这里插入图片描述
计算按钮按下,计算两个时间的差值,然后显示显示在label上

void Widget::on_pushButton_clicked()
{QDateTime timeold=ui->dateTimeEdit->dateTime();//获取第一个时间QDateTime timenew=ui->dateTimeEdit_2->dateTime();//获取第二个时间qDebug()<<timeold<<timenew;//打印两个时间int day=timeold.daysTo(timenew);//第一个时间到第二个时间的差了多少天int sec=timeold.secsTo(timenew);//第一个时间到第二个时间差了多少秒int hour=(sec/3600)%24;//差了多少秒,算出差了多少天,超出的为差了多少秒ui->label->setText(QString("你生存了")+QString::number(day)+QString("天零")+QString::number(hour));}

但是上述的有一个问题
在这里插入图片描述
上面正确的时间应该是7个小时,我们可以查看一下文档
在这里插入图片描述
这里说从一天的23:55到第二天的0:05也算一天,我们可以直接通过秒来计算出天数即可

void Widget::on_pushButton_clicked()
{QDateTime timeold=ui->dateTimeEdit->dateTime();//获取第一个时间QDateTime timenew=ui->dateTimeEdit_2->dateTime();//获取第二个时间qDebug()<<timeold<<timenew;//打印两个时间// int day=timeold.daysTo(timenew);//第一个时间到第二个时间的差了多少天int sec=timeold.secsTo(timenew);//第一个时间到第二个时间差了多少秒int hour=(sec/3600)%24;//差了多少秒,算出差了多少天,超出的为差了多少秒int day=(sec/3600)/24;//根据差的秒数来计算天数ui->label->setText(QString("你生存了")+QString::number(day)+QString("天零")+QString::number(hour)+QString("小时"));}

在这里插入图片描述

3.QSlider

实现水平/竖直方向的滑动条控制窗口大小
在这里插入图片描述

Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);ui->verticalSlider->setMaximum(1000);//设置水平最大对应多少像素ui->verticalSlider->setMinimum(200);//设置水平最小对应多少像素ui->verticalSlider->setSingleStep(50);//设置调整一次会调整多少像素ui->verticalSlider->setValue(600);//设置水平起始位置ui->horizontalSlider->setMaximum(1000);//设置竖直最大对应多少像素ui->horizontalSlider->setMinimum(200);//设置竖直最小对应多少像素ui->horizontalSlider->setSingleStep(50);//设置调整一次会调整多少像素ui->horizontalSlider->setValue(800);//设置竖直起始位置
}

使用valuechanged槽函数实现窗口的大小变化

void Widget::on_horizontalSlider_valueChanged(int value)
{QRect rect=this->geometry();//获取到当前数据this->setGeometry(rect.x(),rect.y(),value,rect.height());//通过value修改窗口水平值
}void Widget::on_verticalSlider_valueChanged(int value)
{QRect rect=this->geometry();//获取到当前数据this->setGeometry(rect.x(),rect.y(),rect.width(),value);//通过value修改窗口水平值
}

视频演示:

通过自定义按钮实现滑动条的移动

Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);ui->horizontalSlider->setMaximum(1000);ui->horizontalSlider->setMinimum(200);ui->horizontalSlider->setSingleStep(50);ui->horizontalSlider->setValue(600);QShortcut* cut1=new QShortcut(this);//定义一个快捷键对象实现--cut1->setKey(QKeySequence("-"));//设置某个快捷键QShortcut* cut2=new QShortcut(this);//定义另外的快捷键对象++cut2->setKey(QKeySequence("="));//设置某个快捷键connect(cut1,&QShortcut::activated,this,&Widget::deal1);//当--,对应滑动条值--connect(cut2,&QShortcut::activated,this,&Widget::deal2);//当++,对应滑动条值++}
void Widget::deal1()
{int value=ui->horizontalSlider->value();//获取滑动条的值ui->horizontalSlider->setValue(value-5);//重设滑动条的值ui->label->setText(QString::number(value-5));//显示在标签上·}void Widget::deal2()
{int value=ui->horizontalSlider->value();//获取滑动条的值ui->horizontalSlider->setValue(value+5);//重设滑动条的值ui->label->setText(QString::number(value+5));//显示在标签上·}

效果演示:

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com