Qt-常用控件(3)-输入类

news2024/12/23 13:06:29

1. QLineEdit

QLineEdit 用来表示单行输入框.可以输入一段文本,但是不能换行

核心属性

属性说明
text输入框中的文本
inputMask输入内容格式约束
maxLength最大长度
frame是否添加边框
echoMode显示方式.
QLineEdit::Normal :这是默认值,文本框会显示输入的文本。
QLineEdit::Password:在这种模式下,输入的字符会被隐藏,通常用星号(*)或等号(=)代替。
QLineEdit::NoEcho:在这种模式下,文本框不会显示任何输入的字符。
cursorPosition光标所在位置
alignment文字对齐方式,设置水平和垂直方向的对齐
dragEnabled是否允许拖拽
readOnly是否是只读的(不允许修改)
placeHolderText当输入框内容为空的时候,显示什么样的提示信息
clearButtonEnabled是否会自动显示出“清除按钮"

核心信号

属性说明
void cursorPositionChanged(intold, int new)当鼠标移动时发出此信号,old为先前的位置,new为新位置。
void editingFinished()当按返回或者回车键时,或者行编辑失去焦点时,发出此信号。
void returnPressed()当返回或回车键按下时发出此信号
如果设置了验证器,必须要验证通过,才能触发
void selectionchanged()当选中的文本改变时,发出此信号。
void textChanged(constQString &text)当QLineEdit中的文本改变时,发出此信号,text是新的文本。
代码对文本的修改能够触发这个信号.
void textEdited(const Qstring&text))当QLineEdit中的文本改变时,发出此信号,text是新的文本。代码对文本的修改不能触发这个信号,

代码示例:录入个人信息

  1. 在界面上创建三个输入框和两个单选按钮,一个普通按钮
    三个输入框的 objectName 为lineEdit_name,lineEdit_passwordlineEdit_phone
    两个单选按钮的 objectName 为 radioButton_male,radioButton_female
    按钮的 objectName 为 pushButton
    在这里插入图片描述
  2. 编写 widget.cpp,在构造函数中编写初始化代码
Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    // 让用户输入个人信息
    ui->lineEdit_name->setPlaceholderText("请输入你的名字");
    ui->lineEdit_name->setClearButtonEnabled(true);

    // 输入密码
    ui->lineEdit_password->setPlaceholderText("请输入你的密码");
    ui->lineEdit_password->setClearButtonEnabled(true);
    // 显示密码的模式
    ui->lineEdit_password->setEchoMode(QLineEdit::Password);


    // 输入电话
    ui->lineEdit_phone->setPlaceholderText("请输入你的电话");
    ui->lineEdit_phone->setClearButtonEnabled(true);
    // 显示电话号码的格式
    ui->lineEdit_phone->setInputMask("000-0000-0000");

}
  1. 继续修改 widget.cpp,给按钮添加 slot 函数
void Widget::on_pushButton_submit_clicked()
{
    QString ate=ui->radioButton_man->isChecked() ? "男" : "女";

    qDebug()<<"姓名:"<< ui->lineEdit_name->text();
    qDebug()<<"密码:"<< ui->lineEdit_password->text();
    qDebug()<<"性别:"<< ate;
    qDebug()<<"电话:"<< ui->lineEdit_phone->text();
}
  1. 执行程序,可以看到,随着用户输入内容之后,点击按钮,就能打印到输入的信息
    在这里插入图片描述

inputMask 只能进行简单的输入格式校验,实际开发中,基于正则表达式的方式是更核心的方法

正则表达式,本质上就是一个带有特殊字符的字符串,特殊字符用来表示另一个字符串的特征此时就可以借助正则表达式来描述出一些具有一定特点的字符串.

代码示例:使用正则表达式验证输入框的数据此处要求在输入框中输入一个合法的电话号码(1 开头,11 位,全都是数字).如果验证不通过,则确定按钮无法点击.

  1. 在界面上创建输入框和一个按钮
    在这里插入图片描述
  2. 编写 widget.cpp,把按钮初始 enabled 设为 false.给输入框添加验证器,
    使用 QRegExp 创建一个正则表达式对象。“^1\d{10}$”表示"以1开头,后面跟上任意的10个十进制数字”.
    使用 QRegExpValidator 创建一个验证器对象.Qt 中内置了四个主要的验证器对象
    在这里插入图片描述
Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    // 验证正则表达式
    // 需要给单行输入框设置验证器,基于正则表达式完成验证
    QRegExp regexp("^1\\d{10}$");
    // 设置验证器
    ui->lineEdit->setValidator(new QRegExpValidator(regexp));

}

在这里插入图片描述

  1. 编写 widget.cpp,给 lineEdit 添加 textEdited 信号的 slot 函数
    on_lineEdit_textEdited 的参数是当前输入框的内容
    通过 lineEdit->validator()获取到内置的验证器
    通过 validate 方法验证文本是否符合要求,
    第一个参数填写的是要验证的字符串,由于参数要求是 QString&而不是 const。QString&,需要把这个变量复制一下,
    第二个参数是一个int&,是输出型参数,当验证的字符串不匹配时,返回这个字符串的长度.(没有。啥实质作用).
    返回值是一个枚举,QValidator::Acceptable 表示验证通过QValidator::Invalid 表示验证不通过
void Widget::on_lineEdit_textEdited(const QString &text)
{
    QString context=text;
    int pos=0;
    if (ui->lineEdit->validator()->validate(context,pos)==QValidator::Acceptable)
    {
        // 验证通过
        ui->pushButton->setEnabled(true);
    }
    else {
        // 验证不通过
        ui->pushButton->setEnabled(false);
    }

}
  1. 执行程序,观察效果,可以看到此时尝试输入字母是无法输入的,并且只有当输入的内容符合要求,确
    定按钮才能被使用.
    在这里插入图片描述

代码示例:验证两次输入的密码一致

  1. 在界面上创建两个输入框和一个label
    在这里插入图片描述
  2. 编写代码,设置两个输入框的 echoMode 为 Password
Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    // 验证两次输入的密码一致
    // 设置密码格式
    ui->lineEdit->setEchoMode(QLineEdit::Password);
    ui->lineEdit_2->setEchoMode(QLineEdit::Password);
}
  1. 给两个输入框设置 textEdited slot函数
void Widget::Compare()
{
    // 获取输入的密码
    QString s1 = ui->lineEdit->text();
    QString s2 = ui->lineEdit_2->text();

    if(s1.isEmpty() && s2.isEmpty())
    {
        ui->label->setText("密码为空");
    }
    else if(s1==s2)
    {
        ui->label->setText("输入的密码一致");
    }
    else
    {
        ui->label->setText("输入的密码不一致");
    }
}


void Widget::on_lineEdit_textEdited(const QString &arg1)
{
    Compare();
}

void Widget::on_lineEdit_2_textEdited(const QString &arg1)
{
    Compare();
}
  1. 执行程序,观察效果,可以看到当两个输入框内的密码相同时,就会提示密码相同
    在这里插入图片描述

代码示例:切换显示密码

  1. 创建一个输入框和一个复选按钮
    在这里插入图片描述
  2. 修改 widget.cpp,设置输入框的 echoMode为 Password
Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    // 用复选框点击改变密码的显示模式
    // 默认情况下
    ui->lineEdit->setEchoMode(QLineEdit::Password);

}
  1. 修改widget.cpp,给 checkBox 添加 slot 函数
void Widget::on_checkBox_toggled(bool checked)
{
    if(checked)
    {
        ui->lineEdit->setEchoMode(QLineEdit::Normal);
    }
    else
    {
        ui->lineEdit->setEchoMode(QLineEdit::Password);
    }
}
  1. 执行程序,可以看到切换复选框的状态,就可以控制输入框显示密码
    在这里插入图片描述

2. QTextEdit

QTextEdit 表示多行输入框,也是一个富文本&markdown 编辑器并且能在内容超出编辑框范围时自动提供滚动条

核心属性

属性说明
markdown输入框内持有的内容.支持 markdown 格式.能够自动的对markdown 文本进行渲染成 html
html输入框内持有的内容.可以支持大部分 html标签.包括 img和 table 等
placeHolderText输入框为空时提示的内容
readOnly是否是只读的
undoRedoEnable是否开启 undo/redo 功能
按下 ctrl+z触发 undo按下 ctrl+y触发 redo
autoFormating开启自动格式化.
tabstopWidth按下缩进占多少空间
overwriteMode是否开启覆盖写模式
acceptRichText是否接收富文本内容
verticalScrollBarPolicy垂直方向滚动条的出现策略
verticalScrollBarPolicy垂直方向滚动条的出现策略
Qt::ScrollBarAsNeeded:根据内容自动决定是否需要滚动条。这是默认值。
Qt::ScrollBarAlwaysOff:总是关闭滚动条。
Qt::ScrollBarAlwaysOn:总是显示滚动条。
horizontalScrollBarPolicy水平方向滚动条的出现策略
Qt::ScrollBarAsNeeded:根据内容自动决定是否需要滚动条。这是默认值。
Qt::ScrollBarAlwaysOff:总是关闭滚动条。
Qt::ScrollBarAlwaysOn:总是显示滚动条。

核心信号

信号说明
textChanged()文本内容改变时触发
selectionChanged()选中范围改变时触发
cursorPositionChanged()光标移动时触发
undoAvailable(bool)可以进行 undo 操作时触发
redoAvailable(bool)可以进行 redo 操作时触发
copyAvaiable(bool)文本被选中/取消选中时触发

代码示例: 获取多行输入框的内容

  1. 创建一个多行输入框和一个label
    在这里插入图片描述
  2. 给多行输入框添加 slot函数.处理 textChanged 信号
    通过 toPlainText 方法获取到内部的文本.
    类似的,QTextEdit 还提供了 toMarkdown 和 toHtml.根据需要我们调整不同的获取方式
void Widget::on_textEdit_textChanged()
{
	const QString& content = ui->textEdit->toPlainText();
	qDebug() << content;
	ui->label->setText(content);
}
  1. 执行程序,可以看到当输入框中的内容发生变化时,label 中的内容同步发生改变
    在这里插入图片描述

3. QComboBox

表示下拉框QComboBox

核心属性

属性说明
currentText当前选中的文本
currentindex当前选中的条目下标
从 0开始计算.如果当前没有条目被选中,值为-1
editable是否允许修改
设为 true 时,QComboBox 的行为就非常接近 QLineEdit,也可以设置 validator
iconSize下拉框图标(小三角)的大小
maxCount最多允许有多少个条目

核心方法

方法说明
addltem(const QString&)添加一个条目
currentindex()获取当前条目的下标
从 0开始计算.如果当前没有条目被选中,值为-1
currentText()获取当前条目的文本内容

核心信号

方法说明
activated(int)
activated(const QString & text)
当用户选择了一个选项时发出这个时候相当于用户点开下拉框,并且鼠标划过某个选项,此时还没有确认做出选择,
currentindexChanged(int)
currentindexChanged(const QString& text)
当前选项改变时发出.
此时用户已经明确的选择了一个选项
用户操作或者通过程序操作都会触发这个信号
editTextChanged(const QString & text)当编辑框中的文本改变时发出(editable 为 true 时有效)

代码示例:使用下拉框模拟麦当劳点餐

  1. 在界面上创建三个下拉框,和一个按钮,
    在这里插入图片描述
  2. 编写 widget.cpp,初始化三个下拉框的内容
Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    // 模拟麦当劳点餐
    // 给ComboBox添加
    ui->comboBox->addItem("鸡腿堡");
    ui->comboBox->addItem("巨无霸");
    ui->comboBox->addItem("培根书崔双层牛堡");

    ui->comboBox_2->addItem("中薯条");
    ui->comboBox_2->addItem("麦乐鸡块");
    ui->comboBox_2->addItem("麦辣鸡翅");

    ui->comboBox_3->addItem("可乐");
    ui->comboBox_3->addItem("雪碧");
    ui->comboBox_3->addItem("芬达");
}
  1. 编写 widget.cpp,给按钮添加 slot 函数
void Widget::on_pushButton_clicked()
{
    qDebug()<<ui->comboBox->currentText() <<", "<<ui->comboBox_2->currentText() <<", "<<ui->comboBox_3->currentText();
}
  1. 执行程序,可以看到,在点击确定按钮时,就能获取到当前下拉框中选中的内容
    在这里插入图片描述

代码示例2: 从文件中加载下拉框的选项很多时候下拉框的选项并非是固定的,而是通过读取文件/读取网络获取到的

  1. 在界面上创建一个下拉框
    在这里插入图片描述
  2. 创建 E:/code/1.txt 文件
    在这里插入图片描述
  3. 修改 widget.cpp,从文件中读取选项
    使用 ifstream 打开文件
    使用 getline 读取每一行
    使用 QString::fromstdstring 把 std::string 转成 QString
Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    // 需要读取文件内容,把文件的每一行都读出来,作为一个ComboBox 的选项
    std::fstream file("E:/code/1.txt");

    // 判断文件是否被打开
    if(!file.is_open())
    {
        qDebug()<<"文件打开失败";
        return;
    }

    // 按行来读取文本
    std::string line;
    while(std::getline(file,line))
    {
        // 取到的每一行的内容,添加的下拉菜单中
        ui->comboBox->addItem(QString::fromStdString(line));

    }

    file.close();
}
  1. 执⾏程序, 可以看到⽂件内容已经被加载到下拉框中
    在这里插入图片描述

4. QSpinBox

使用 QSpinBox 或者 QDoubleSpinBox 表示"微调框",它是带有按钮的输入框.可以用来输入整数/浮点数.通过点击按钮来修改数值大小.
由于 SpinBox 和 QDoubleSpinBox 用法基本相同,就只介绍 SpinBox 的使用了
在这里插入图片描述

QSpinBox 关键属性

属性说明
value存储的数值.
singlestep每次调整的"步长".按下一次按钮数据变化多少
displayInteger数字的进制.例如 displayInteger 设为 10,则是按照 10 进制表示. 设为 2 则为 2进制表示.
minimum最小值
maximum最大值
suffix后缀
prefix前缀
wrapping是否允许换行
frame是否带边框
alignment文字对齐方式
readOnly是否允许修改
buttonSymbol按钮上的图标.
UpDownArrows 上下箭头形式
PlusMinus 加减号形式
NoButtons 没有按钮
accelerated(加速的)按下按钮时是否为快速调整模式
correctionMode输入有误时如何修正
1. QAbstractSpinBox::CorrectToPreviousValue:如果用户输入了一个无效的值(例如,在只能显示正整数的SpinBox中输入了负数),那么SpinBox会恢复为上一个有效值。例如,如果SpinBox的初始值是1,用户输入了-1(无效),然后SpinBox会恢复为1。
2. QAbstractSpinBox::CorrectToNearestValue:如果用户输入了一个无效的值,SpinBox会恢复为最接近的有效值。例如,如果SpinBox的初始值是1,用户输入了-1(无效),那么SpinBox会恢复为0。
keyboardTrack是否开启键盘跟踪.
设为 true,每次在输入框输入一个数字,都会触发一次 valueChanged() 和textChanged()信号.
设为 false,只有在最终按下 enter 或者输入框失去焦点,才会触发valueChanged()和textChanged()信号

核心信号

信号说明
textChanged(QString)微调框的文本发生改变时会触发参数 QString 带有 前缀 和 后缀
valueChanged(int)微调框的文本发生改变时会触发参数 int,表示当前的数值,

代码示例:调整麦当劳购物车中的份数

  1. 在界面上创建下列内容
    三个下拉框:objectName为comboBox到comboBox_3三个微调框:objectName为spinBox到spinBox_3-个按钮:objectName为pushButton
    在这里插入图片描述
  2. 编写代码,修改 widget.cpp,给下拉框设置初始值
Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    // 模拟实现麦当劳选餐,并且用微调框进行需要选择的个数

    // 先设置下拉框
    ui->comboBox->addItem("麦辣鸡腿堡");
    ui->comboBox->addItem("巨无霸");
    ui->comboBox->addItem("培根书崔双层牛堡");

    ui->comboBox_2->addItem("中薯条");
    ui->comboBox_2->addItem("麦乐鸡块");
    ui->comboBox_2->addItem("麦辣鸡翅");

    ui->comboBox_3->addItem("可乐");
    ui->comboBox_3->addItem("雪碧");
    ui->comboBox_3->addItem("芬达");


    // 设置微调框的范围
    ui->spinBox->setRange(1,5);
    ui->spinBox_2->setRange(1,5);
    ui->spinBox_3->setRange(1,5);

    // 设置初始值
    ui->spinBox->setValue(1);
    ui->spinBox_2->setValue(1);
    ui->spinBox_3->setValue(1);

}
  1. 编写代码,给按钮添加 slot 函数
void Widget::on_pushButton_clicked()
{
    qDebug()<<"当前下单的内容"
            <<ui->comboBox->currentText()<<","<<ui->spinBox->value()
            <<ui->comboBox_2->currentText()<<","<<ui->spinBox_2->value()
           << ui->comboBox_3->currentText()<<","<<ui->spinBox_3->value();
}
  1. 执行程序,可以看到当用户选择不同的内容时,点击按钮就能获取到对应的结果,同时我们也无法输入一些超出范围的非法值.
    在这里插入图片描述

5. QDateTimeEdit

使⽤ QDateEdit 作为⽇期的微调框
在这里插入图片描述

使用 QTimeEdit 作为时间的微调框
在这里插入图片描述

使用 ODateTimeEdit 作为时间日期的微调框
在这里插入图片描述
这几个控件用法非常相似,我们以 QDateTimeEdit 为例进行介绍

QDateTimeEdit 核⼼属性

属性说明
dateTime时间日期的值.形如 2000/1/1 0:00:00
date单纯日期的值.形如 2001/1/1
time单纯时间的值.形如0:00:00
displayFormat时间日期格式.形如 yyyy/M/d H:mm
  • y 表示年份
  • M 表示月份
  • d 表示日期
  • H 表示小时
  • m 表示分钟
  • s 表示秒
    注意:这里的格式化符号的含义,不要记忆,不同语言/库的设定规则是存在差异的.一定是用的时候再去查,
minimumDateTime最小时间日期
maximumDateTime最大时间日期
timeSpec
  • Qt::LocalTime :显示本地时间。
  • Qt::UTC:显示协调世界时(UTC)。
  • Qt::0ffsetFromUTc:显示相对于UTC的偏移量(时差)

核⼼信号

信号说明
dateChanged(QDate)⽇期改变时触发.
timeChanged(QTime)时间改变时触发.
dateTimeChanged(QDateTime)时间⽇期任意⼀个改变时触发.

代码示例: 实现日期计算器

  1. 在界面上创建两个 QDateTimeEdit 和一个按钮,一个label
    ODateTimeEdit的objectName 为dateTimedit old 和 dateTimeEdit new
    在这里插入图片描述
    2)编写计算按钮的 slot 函数
  • 使用 daysTo 函数可以计算两个日期的天数
  • 使用 secsTo
  • 函数可以计算两个时间的秒数
  • 通过(秒数 /3600)换算成小时数,再余上 24 得到零几个小时使用 Qstring::number 把整数转成 QString 进行拼接
void Widget::on_pushButton_clicked()
{
    // 首先获取两个日期的当前日期
    QDateTime dateOld = ui->dateTimeEdit->dateTime();
    QDateTime dateNew = ui->dateTimeEdit_2->dateTime();
    qDebug()<<dateOld<<dateNew;

    // 计算两个日期的差值天数
    //int days=dateOld.daysTo(dateNew);// 会有缺陷,如果差值小于24小时,会多算一天

    // 计算两个日期的差值秒数
    int seconds=dateOld.secsTo(dateNew);


    // 计算多余的小时
    int hours=(seconds/3600)%24;
    int days=(seconds/3600)/24;

    // 把计算结果输出到label中
    ui->label->setText(QString("持续爱你已经")+ QString(days)+QString("天")
                       +QString(hours)+ QString("小时"));
}
  1. 执⾏程序, 观察结果
    在这里插入图片描述

6. QDial

使用 QDial 表示一个 旋钮
在这里插入图片描述

核心属性

属性说明
value持有的数值,
minimum最小值
maximum最大值
singleStep按下方向键的时候改变的步长
pageStep按下 pageUp/pageDown 的时候改变的步长
sliderPosition界面上旋钮显示的 初始位置
tracking外观是否会跟踪数值变化
默认值为 true.一般不需要修改
wrapping是否允许循环调整
即数值如果超过最大值,是否允许回到最小值,(调整过程能否"套圈")
notchesVisible是否显示 刻度线
notchTarget刻度线之间的相对位置
数字越大,刻度线越稀疏

核心信号

属性说明
valueChanged(int)数值改变时触发
rangeChanged(int, int)范围变化时触发

代码示例:调整窗口透明度

  1. 在界面上创建一个旋钮和一个label
    在这里插入图片描述
  2. 编写 widget.cpp,对旋钮初始化
Widget::Widget(QWidget *parent)
	: QWidget(parent)
	, ui(new Ui::Widget)
{
	ui->setupUi(this);
	// 设置可以循环旋转
	ui->dial->setWrapping(true);
	// 设置刻度线可⻅
	ui->dial->setNotchesVisible(true);
	// 设置最⼤值为
	ui->dial->setMaximum(100);
	// 设置最⼩值为
	ui->dial->setMinimum(0);
	// 设置初始值为
	ui->dial->setValue(100);
}
  1. 编写 widget.cpp,设置旋钮的 valuechanged slot函数
void Widget::on_dial_valueChanged(int value)
{
	ui->label->setText(QString("当前不透明度为: ") + QString::number(value));
	this->setWindowOpacity((double)value / 100);
}
  1. 运行程序,观察效果,可以看到随着拖动旋钮旋转,不透明度发生明显变化
    在这里插入图片描述

7. QSlider

使⽤ QSlider 表⽰⼀个滑动条.
在这里插入图片描述

QSlider 和 QDial 都是继承自 QAbstractslider,因此用法上基本相同

核心属性

属性说明
value持有的数值.
minimum最小值
maximum最大值
singleStep按下方向键的时候改变的步长,
pageStep按下pageUp/pageDown 的时候改变的步长,
sliderPosition滑动条显示的 初始位置
tracking外观是否会跟踪数值变化,
默认值为 true.一般不需要修改.
orientation滑动条的方向是水平还是垂直
invertedAppearance是否要翻转滑动条的方向
tickPosition刻度的位置.
tickinterval刻度的密集程度

核心信号

属性说明
valueChanged(int)数值改变时触发
rangeChanged(int, int)范围变化时触发

代码示例: 通过自定义快捷键调整滑动条位置设置 -减小 value,设置=增加 value.默认情况下滑动条****可以通过 方向键 或者 pageUp/pageDown 调整大小.

  1. 在界面上创建滑动条和 label
    在这里插入图片描述
  2. 编写 Widget.cpp 代码
Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    // 使用快捷键,- 和 =(也就相当于+),来调节滚动条

    // 1.设置快捷键
    QShortcut *st1=new QShortcut(this);
    st1->setKey(QKeySequence("-"));

    QShortcut *st2=new QShortcut(this);
    st2->setKey(QKeySequence("="));

    // 2.用connect函数进行信号与槽的连接
    connect(st1,&QShortcut::activated,this,&Widget::mudValue);
    connect(st2,&QShortcut::activated,this,&Widget::addValue);

}

void Widget::addValue()
{
    // 获取当前的数值
    int value=ui->horizontalSlider->value();
    if(value>=ui->horizontalSlider->maximum())
    {
        return;
    }

    ui->horizontalSlider->setValue(value+5);
}

void Widget::mudValue()
{
    // 获取当前的数值
    int value=ui->horizontalSlider->value();

    if(value<=ui->horizontalSlider->minimum())
    {
        return;
    }

    ui->horizontalSlider->setValue(value-5);

}


void Widget::on_horizontalSlider_valueChanged(int value)
{
    ui->label->setText("当前的数值为:"+ QString::number(value));
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2114512.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

物联网之流水LED灯、正常流水灯、反复流水灯、移动流水灯

MENU 硬件电路设计软件程序设计正常流水LED灯反复流水LED灯移动流水LED灯 硬件电路设计 材料名称数量直插式LED1kΩ电阻杜邦线(跳线)若干面包板1 每一个LED的正极与开发板一个GPIO引脚相连&#xff0c;并串联一个电阻&#xff0c;负极接GND。 当然也可以选择只使用一个电阻。 软…

DELTA_IA-ASD_ASDA-A2简明教程

该文章仅供参考&#xff0c;编写人不对任何实验设备、人员及测量结果负责&#xff01;&#xff01;&#xff01; 0 引言 文章主要介绍电机的硬件连接、软件配置、转动调试以及软件控制。文章中提到的内容在产品手册中都有说明&#xff0c;强烈建议在操作前通读产品手册&#…

1-17 平滑处理——中值滤波 opencv树莓派4B 入门系列笔记

目录 一、提前准备 二、代码详解 cv2.medianBlur函数用于对图像进行中值滤波。中值滤波是一种去噪声的技术&#xff0c;可以有效地去除图像中的盐和胡椒噪声。函数的两个参数如下&#xff1a; 三、运行现象 四、完整代码贴出 一、提前准备 1、树莓派4B 及 64位系统 2、提前…

【2024 版】最新 kali linux 入门及常用简单工具介绍(非常详细)

一、介绍 kali Linux Kali Linux 是一个基于 Debian 的 Linux 发行版&#xff0c;主要用于数字取证和渗透测试。它预装了大量的安全审计和渗透测试工具&#xff0c;被广泛应用于网络安全领域。 &#xff08;一&#xff09;特点 工具丰富&#xff1a;集成了数百种用于渗透测试…

华为eNSP:NAT Server(端口映射)

一、拓扑图 二、配置过程 此处省略设备地址以及路由配置过程 1、服务器开启ftp服务 2、路由器配置nat server [r4]int g0/0/2#进入流量出接口 [r4-GigabitEthernet0/0/2]nat server protocol tcp global 192.168.3.11 ftp inside 192.168.2.1 ftp# …

Java数组(详解版)

数组的定义&#xff1a; 什么是数组&#xff1a; 数组&#xff1a;可以看成是相同类型元素的一个集合。在内存中是一段连续的空间。 1. 数组中存放的元素其类型相同 2. 数组的空间是连在一起的 3. 每个空间有自己的编号&#xff0c;其实位置的编号为 0 &#xff0c;即数组…

Nuxt3入门:过渡效果(第5节)

你好同学&#xff0c;我是沐爸&#xff0c;欢迎点赞、收藏、评论和关注。 Nuxt 利用 Vue 的 <Transition> 组件在页面和布局之间应用过渡效果。 一、页面过渡效果 你可以启用页面过渡效果&#xff0c;以便对所有页面应用自动过渡效果。 nuxt.config.js export defaul…

冒泡排序——基于Java的实现

简介 冒泡排序&#xff08;Bubble Sort&#xff09;是一种简单的排序算法&#xff0c;适用于小规模数据集。其基本思想是通过重复遍历待排序的数组&#xff0c;比较相邻的元素并交换它们的位置&#xff0c;以此将较大的元素逐步“冒泡”到数组的末尾。算法的名称源于其运行过程…

动手学习RAG: 向量模型

在世界百年未有之变局与个人自暴自弃的间隙中&#xff0c;我们学一点RAG。 RAG是一种独特的应用&#xff0c;“一周写demo&#xff0c;优化搞半年”&#xff0c;我甚至听说它能破解幻术。 为了理解其优化中的关键一环&#xff0c;我们先看下文本向量。文本向量除了是RAG检索的…

# 键盘字母上有下标数字,输入时怎么一键去掉,关闭键盘上的下标数字。‌

键盘字母上有下标数字&#xff0c;输入时怎么一键去掉&#xff0c;关闭键盘上的下标数字。‌ 一、问题描述&#xff1a; 如下图&#xff0c;有的笔记本电脑键盘上&#xff0c;没有数字小键盘&#xff0c;数字小键盘会和字母混和在一起&#xff0c;这样打字时&#xff0c;不容…

AI在医学领域:MASL多模态辅助诊断声带麻痹

声带麻痹&#xff08;Vocal Cord Paralysis, VP&#xff09;&#xff0c;也称为喉瘫痪&#xff0c;是指由于支配声带的神经受损导致声带运动障碍的疾病。这种状况可以是单侧或双侧的&#xff0c;通常由脑部、颈部、胸部的肿瘤、外伤、炎症&#xff0c;以及各种全身疾病引起。这…

复数随机变量(信号)的方差和协方差矩阵的计算

怎么计算复数随机变量的方差和协方差矩阵&#xff1f; 使得其与MATLAB中var函数和cov函数的结果一致。 前言 复信号在信号处理中随处可见&#xff0c;关于复信号&#xff08;复随机变量&#xff09;的方差和协方差矩阵该如何计算呢&#xff1f;本文给出了复信号的方差和协方差矩…

什么是大数据、有什么用以及学习内容

目录 1.什么是大数据&#xff1f; 2.大数据有什么用&#xff1f; 2.1商业与营销&#xff1a; 2.2医疗与健康&#xff1a; 2.3金融服务&#xff1a; 2.4政府与公共服务&#xff1a; 2.5交通与物流&#xff1a; 2.6教育与个性化学习&#xff1a; 3.学习大数据需要学习哪…

C++笔试强训12、13、14

文章目录 笔试强训12一、选择题1-5题6-10题 二、编程题题目一题目二 笔试强训13一、选择题1-5题6-10题 二、编程题题目一题目二 笔试强训14一、选择题1-5题6-10题 二、编程题题目一题目二 笔试强训12 一、选择题 1-5题 引用&#xff1a;是一个别名&#xff0c;与其被引用的实…

认知杂谈54

I I 内容摘要&#xff1a; 这篇内容主要有以下几个要点&#xff1a;首先&#xff0c;沟通不在一个调时可学习人际交往心理学知识、线上课程及关注名师来改善。其次&#xff0c;挑房子、工作、搭档和人生伴侣要谨慎&#xff0c;找心灵相通能共同进步的人。再者&#xff0c;远离…

AI周报(9.1-9.7)

AI应用-Tidal 引领海洋养殖革命 Tidal团队&#xff0c;一个源自Alphabet X的创新项目&#xff0c;今年七月顺利从X实验室毕业&#xff0c;成为一家独立的公司。Tidal正在通过人工智能技术改变海洋养殖&#xff0c;特别是鲑鱼养殖。Tidal的总部位于挪威特隆赫姆&#xff0c;他们…

Java-数据结构-栈和队列-Stack和Queue (o゚▽゚)o

文本目录&#xff1a; ❄️一、栈(Stack)&#xff1a; ▶ 1、栈的概念&#xff1a; ▶ 2、栈的使用和自实现&#xff1a; ☑ 1&#xff09;、Stack(): ☑ 2&#xff09;、push(E e): ☑ 3&#xff09;、empty(): ☑ 4&#xff09;、peek(E e): ☑ 5&#xff09;、pop(E e): …

将添加功能的抽屉剥离,在父组件调用思路

一、新建组件 新建AddRoleEditerDrawer.vue<template><div><el-drawer v-model"dialog" title"添加角色" :before-close"handleClose" direction"rtl" colse"cancelForm"class"demo-drawer" moda…

基于UE5和ROS2的激光雷达+深度RGBD相机小车的仿真指南(五):Blender锥桶建模

前言 本系列教程旨在使用UE5配置一个具备激光雷达深度摄像机的仿真小车&#xff0c;并使用通过跨平台的方式进行ROS2和UE5仿真的通讯&#xff0c;达到小车自主导航的目的。本教程默认有ROS2导航及其gazebo仿真相关方面基础&#xff0c;Nav2相关的学习教程可以参考本人的其他博…

MQ-2烟雾传感器详解(STM32)

目录 一、介绍 二、传感器原理 1.原理图 2.引脚描述 3.工作原理介绍 三、程序设计 main.c文件 mq2.h文件 mq2.c文件 四、实验效果 五、资料获取 项目分享 一、介绍 MQ-2气体传感器是一种常用的气体传感器&#xff0c;用于检测空气中的烟雾浓度。工作原理是基于半导…