赞
踩
我们还是来结合小的案例,来进行边做边学;
目标图:
话不多说,直接来拖放
日历组件用Calender Widget
加一个格栅布局和垂直布局
可以将line Edit的可写关上
来,咱们开始先对日期转到槽:
用这个信号
得到日期,然后转到字符串,设置到line Edit,date可以直接设置到日历中
void Dialog::on_dateEdit_userDateChanged(const QDate &date)
{
QString ret=date.toString("yyyy年M月dd日");
ui->lineEdit->setText(ret);
ui->calendarWidget->setSelectedDate(date);
}
运行结果:
接下来,我们开始对calendar Widget去使用信号槽!
用这个信号,日历选择改变就发出信号
代码:
可以用selectedDate来拿出日历。
void Dialog::on_calendarWidget_selectionChanged()
{
QDate date=ui->calendarWidget->selectedDate();
ui->dateEdit->setDate(date);
QString ret=date.toString();
ui->lineEdit->setText(ret);
}
运行结果:
因为line Edit 需要的是QString 所以要对Date转字符串哦。
就是当我们需要每隔一段时间进行一次操作的时候,我们可以使用定时器。
首先我们来创建一个定时器,需要头文件 < QTimer >
#ifndef DIALOG_H #define DIALOG_H #include <QDialog> #include <QTimer>//定时器的头文件 QT_BEGIN_NAMESPACE namespace Ui { class Dialog; } QT_END_NAMESPACE class Dialog : public QDialog { Q_OBJECT public: Dialog(QWidget *parent = nullptr); ~Dialog(); private: Ui::Dialog *ui; QTimer* timer;//这里是定时器 }; #endif // DIALOG_H
在dialog.cpp中:
timer=new QTimer;//创建定时器
定时器是每隔一段时间进行操作,那我们间隔多少时间,需要我们自己来定义。
timer->setInterval(500);//是以ms为单位
定时器有3种类型:
我们一般用粗糙定时器:
timer->setTimerType(Qt::CoarseTimer);//设置为粗糙定时器
定时器有自己的一个信号就是timeout间隔时间一到,就会发出信号。
自己先添加一个槽函数,就是定时器时间一到要执行的操作。
connect(timer,SIGNAL(timeout()),this,SLOT(onTimeout()));
onTimeout是自己定义的槽函数哦,要加slots
private slots:
void onTimeout();
我们的想法是点击启动定时器就启动,进度条就开始移动,到了100又设置为0重新移动,暂停定时器就关闭。
拖放:
对启动按钮转到槽:
void Dialog::on_pushButtonStart_clicked()
{
timer->start();//打开定时器
}
对暂停案例转到槽:
void Dialog::on_pushButtonEnd_clicked()
{
timer->stop();//停止定时器
}
其实就是槽函数
void Dialog::onTimeout()
{
int value=ui->progressBar->value()+1;
if(value>100)
{
value=0;
}
ui->progressBar->setValue(value);
}
运行结果:
可惜不会动态的截图,你们可以自己去玩玩,感觉挺牛逼的。
Dialog::Dialog(QWidget *parent)
: QDialog(parent)
, ui(new Ui::Dialog)
{
ui->setupUi(this);
timer=new QTimer;//创建定时器
timer->setInterval(500);//是以ms为单位
timer->setTimerType(Qt::CoarseTimer);//设置为粗糙定时器
connect(timer,SIGNAL(timeout()),this,SLOT(onTimeout()));
}
对于定时器来言,主要是创建 设置间隔时间 和 类型 还有就是关联
永远相信美好的事情即将来临!
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。