void Widget::on_pushButton_add_employee_clicked() { QString number=ui->lineEdit_employee_number->text(); QString name=ui->lineEdit_employee_name->text(); QString phone=ui->lineEdit_employee_phone->text(); if(number.isEmpty()||name.isEmpty()||phone.isEmpty()) { QMessageBox::information(this,"提示","请认真填写数据后再添加.", QMessageBox::Ok,QMessageBox::Ok); return; } //没有表就先创建 CreateStudentSurface(); //添加数据到表 //保存数据到数据库 QSqlQuery sql_query(database); //查询原数据库表里有没有重复数据 //查询全部数据 sql_query.prepare("select * from student"); if(!sql_query.exec()) { Log_Text_Display("员工数据库查询错误.\n"); } else { while(sql_query.next()) { //ID、工号、姓名、电话、状态 // int id = sql_query.value(0).toInt(); //ID QString find_number = sql_query.value(1).toString(); //工号 QString find_name = sql_query.value(2).toString(); //姓名 QString find_phone = sql_query.value(3).toString(); //电话 QString find_state = sql_query.value(4).toString(); //状态 //判断工号有没有冲突的 if(number==find_number) { QMessageBox::information(this,"提示","你输入的工号在数据库已经存在!\n请认真填写.", QMessageBox::Ok,QMessageBox::Ok); return; } } } //准备插入数据 //查询最大ID QString select_max_sql = "select max(id) from student"; int max_id = 0; sql_query.prepare(select_max_sql); if(!sql_query.exec()) { QMessageBox::information(this,"提示","员工表最大ID查找失败.", QMessageBox::Ok,QMessageBox::Ok); return; } else { while(sql_query.next()) { max_id = sql_query.value(0).toInt(); } Log_Text_Display(QString("data base max id:%1\n").arg(max_id)); } if(max_id>=300) { QMessageBox::information(this,"提示","指纹库已满,无法录入.", QMessageBox::Ok,QMessageBox::Ok); return; } //录入指纹 Lu_ru_zhi_weN_flag=1; ui->plainTextEdit_lu_ru->clear(); //串口发送指令,表示录入指纹 QString cmd=tr("$dev_cmd_lu_ru_zhi_wen:%1").arg(max_id); UART_Send(cmd.toUtf8()); }
时间: 2024-04-13 09:26:58 浏览: 134
这段代码是关于一个名为Widget的类中的一个槽函数on_pushButton_add_employee_clicked()的实现。该函数实现了添加员工信息的功能。
首先,函数通过调用ui对象的lineEdit_employee_number、lineEdit_employee_name和lineEdit_employee_phone方法获取输入的员工编号、姓名和电话号码。然后,它检查这些输入是否为空,如果有任何一个为空,则弹出一个提示框提醒用户认真填写数据,并返回。
接下来,函数调用CreateStudentSurface()方法创建一个表(如果表不存在),然后通过使用QSqlQuery对象执行SQL查询来检查数据库中是否存在相同的员工编号。如果存在相同的员工编号,则弹出一个提示框提醒用户输入的工号在数据库中已经存在,并返回。
如果没有重复的员工编号,函数将执行查询最大ID的SQL语句来获取当前数据库中最大的ID值,并将其存储在max_id变量中。接着,它检查max_id的值是否大于等于300,如果是,则弹出一个提示框告知指纹库已满无法录入,并返回。
最后,函数将设置Lu_ru_zhi_weN_flag变量为1,并清空plainTextEdit_lu_ru控件。然后,它构建一个发送给串口的指令cmd,表示录入指纹,并通过UART_Send方法发送该指令。
请注意,该代码片段中的一些函数(如CreateStudentSurface、Log_Text_Display和UART_Send)可能是自定义的函数,因此需要根据上下文进行实现或查找其实现。
相关问题
void Widget::on_pushButton_clicked() { tcpclient->connectToHost(ui->lineEdit->text(),ui->lineEdit_2->text().toInt()); } void Widget::on_pushButton_2_clicked() { QString str=ui->lineEdit_3->text(); QByteArray qbyte=str.toUtf8(); char *cstr=qbyte.data(); qDebug()<<cstr<<endl; tcpclient->write(cstr,100); }这段代码的作用
这段代码是一个基于Qt框架的TCP客户端程序的两个槽函数。第一个槽函数`on_pushButton_clicked()`会在用户点击`pushButton`按钮时被触发,它会根据用户在`lineEdit`和`lineEdit_2`输入框中的输入,使用`tcpclient`对象连接到指定的TCP服务器。
第二个槽函数`on_pushButton_2_clicked()`会在用户点击`pushButton_2`按钮时被触发,它会将用户在`lineEdit_3`输入框中输入的文本转换为UTF-8编码的字节数组,并将其发送给服务器端。具体地,它会首先调用`str.toUtf8()`将用户输入的文本转换为UTF-8编码的字节数组`qbyte`,然后通过`qbyte.data()`获取字节数组的指针,最后使用`tcpclient`对象的`write()`方法将指定长度的字节流发送给服务器端。在这里,指定的长度为100。同时,它还会在控制台输出发送的字节流。
void MainWindow::on_pushButton_4_clicked() { CalType=1;//+ Value1=Value1+(ui->lineEdit->text()).toFloat(); QString data= QString("%1").arg(Value1); ui->lineEdit->setText(data); dot=0; }解释一下
这是 MainWindow 类中的一个槽函数,该函数会在用户点击名为 pushButton_4 的按钮时被触发。该函数的主要作用是将用户在 QLineEdit 控件中输入的数值与 Value1 相加,并将结果显示在 QLineEdit 控件中。
具体来说,该函数通过将全局变量 CalType 的值设置为 1,在之后的计算中确定进行加法运算。然后,该函数从 QLineEdit 对象(ui->lineEdit)中获取用户输入的数值,并将其转换为浮点型。接着,该函数将该浮点型数值加上 Value1 的值,并将结果赋值给 Value1。
接下来,该函数将 Value1 转换为字符串类型,并通过 QString 类的 arg() 函数将其赋值给 data 变量。最后,该函数通过调用 QLineEdit 控件对象的 setText() 函数,将 data 显示在 QLineEdit 控件中。
最后,该函数将全局变量 dot 的值设置为 0,以便在用户输入新的数值时,能够正常添加小数点。
阅读全文
相关推荐
















