当前位置: 首页 > news >正文

【Qt 5.14.2 新手实战】QTC++入门筑基——10 分钟做个文本编辑器:QLineEdit + QTextEdit 核心用法

写课程报告时,是不是总觉得系统自带的记事本功能不够用?要是能有个更贴心的简易文本工具就好了。今天,咱们就用Qt 5.14.2 打造一个这样的文本编辑器,它不仅能满足基本的文本输入,还多了字体设置、内容清空等实用功能。而且,这个小项目代码量在100行以内,30分钟就能跑通,下次课程设计直接就能用,同时还能帮你吃透Qt 5.14.2 的核心输入控件。

一、环境配置清单

基于第一章搭建好的Qt 5.14.2环境,无需额外工具,咱们就可以开始啦。
【Qt 5.14.2 新手实战】QTC++入门筑基——QTC++新手必看:从安装到第一个窗口

二、核心控件拆解

(一)QLineEdit(单行输入)

  1. placeholderText属性设置

    • placeholderText是QLineEdit的一个很实用的属性,它可以在输入框内显示提示性文字,当用户点击输入框准备输入内容时,提示文字就会消失。比如我们可以设置为“请输入标题”。
    • 在Qt 5.14.2中,找到QLineEdit控件,右键点击选择“Properties Editor”(属性编辑器),在属性面板中找到“placeholderText”,输入提示内容即可,如图1所示。
  2. maxLength属性设置

    • maxLength属性用于限制用户在QLineEdit中输入的最大字符数。比如设置为50,就表示用户最多只能输入50个字符。
    • 同样在“Properties Editor”属性面板中找到“maxLength”,输入你想要限制的字符数,如图2所示。

(二)QTextEdit(多行输入)

  1. readOnly属性设置

    • readOnly属性决定了QTextEdit是否可编辑。如果设置为true,用户就只能查看其中的内容,不能进行修改。在属性面板中找到“readOnly”,勾选它就可以将QTextEdit设置为只读模式,如图3所示。
  2. lineWrapMode属性设置

    • lineWrapMode属性控制文本的换行方式。常见的取值有“WidgetWidth”,表示文本会根据QTextEdit的宽度自动换行。在属性面板的“lineWrapMode”下拉菜单中选择你需要的换行模式,如图4所示。

(三)信号槽连接

我们要实现按钮点击触发“清空内容”和“设置字体”功能,这里介绍两种连接方式:

  1. 可视化连接(设计模式右键)

    • 在设计模式下,右键点击用于“清空内容”的按钮(QPushButton),选择“Go to slot…”(转到槽函数),在弹出的对话框中选择“clicked()”信号,然后点击“OK”。

    • 这时候会自动生成一个槽函数框架,在这个函数里添加清空QTextEdit内容的代码:ui->textEdit->clear();

    • 同样的方法,为用于“设置字体”的按钮连接“clicked()”信号到槽函数,在槽函数里添加字体设置相关代码。

  2. 代码连接(connect()函数)

    • 在源文件中,找到合适的位置,比如构造函数里,使用connect()函数进行连接。
    • 以“清空内容”按钮为例,代码如下:
connect(ui->clearButton,&QPushButton::clicked,[=](){ui->textEdit->clear();});

这里ui->clearButton是指向“清空内容”按钮的指针,&QPushButton::clicked表示按钮的点击信号,[=]()是一个Lambda表达式,用于定义槽函数的行为,即清空QTextEdit的内容。
- 在Qt 5.14.2中,信号槽语法基本保持不变,使用起来和以往版本类似,大家可以放心使用。

三、完整代码

下面是实现这个文本编辑器的完整代码,包含输入、清空、字体选择、保存临时内容功能,并且适配Qt 5.14.2的头文件引用:

#include"mainwindow.h"#include"ui_mainwindow.h"#include<QFontDialog>#include<QFileDialog>#include<QMessageBox>MainWindow::MainWindow(QWidget*parent):QMainWindow(parent),ui(newUi::MainWindow){ui->setupUi(this);// 代码连接“清空内容”按钮connect(ui->clearButton,&QPushButton::clicked,[=](){ui->textEdit->clear();});// 代码连接“设置字体”按钮connect(ui->fontButton,&QPushButton::clicked,[=](){boolok;QFont font=QFontDialog::getFont(&ok,this);if(ok){ui->textEdit->setFont(font);}});// 代码连接“保存内容”按钮connect(ui->saveButton,&QPushButton::clicked,[=](){QString filePath=QFileDialog::getSaveFileName(this,tr("Save File"),"",tr("Text Files (*.txt)"));if(!filePath.isEmpty()){QFilefile(filePath);if(file.open(QIODevice::WriteOnly|QIODevice::Text)){QTextStreamout(&file);out<<ui->textEdit->toPlainText();file.close();}else{QMessageBox::warning(this,tr("Warning"),tr("Could not open file"));}}});}MainWindow::~MainWindow(){deleteui;}

对应的头文件mainwindow.h内容如下:

#ifndefMAINWINDOW_H#defineMAINWINDOW_H#include<QMainWindow>QT_BEGIN_NAMESPACEnamespaceUi{classMainWindow;}QT_END_NAMESPACEclassMainWindow:publicQMainWindow{Q_OBJECTpublic:MainWindow(QWidget*parent=nullptr);~MainWindow();private:Ui::MainWindow*ui;};#endif// MAINWINDOW_H

运行效果:

四、常见报错解决方案

(一)报错1:“QTextEdit内容无法清空”

原因:在Qt 5.14.2信号槽连接时“sender对象”未选中,导致信号无法正确传递到对应的槽函数,从而不能执行清空操作。

解决步骤
- 检查代码连接方式下,connect()函数中的对象指针是否正确指向“清空内容”按钮和包含QTextEdit的窗口对象。

(二)报错2:“字体选择对话框不弹出”

原因:未添加#include <QFontDialog>头文件,导致程序找不到字体选择对话框相关的定义。

解决方法:在源文件顶部添加#include <QFontDialog>头文件。

(三)报错3:UI界面重命名后无法使用

原因:因为QT的UI保存没有生效。

解决步骤
- 需要取消勾选“构建目录”

五、拓展任务

大家可以尝试添加“内容字数统计”功能,利用QTextEdit::toPlainText().length()就可以获取QTextEdit中纯文本的字符数。实现思路是:在界面上添加一个QLabel用于显示字数,然后通过按钮点击或者文本内容变化信号触发一个槽函数,在槽函数中获取QTextEdit的字数并更新QLabel的显示内容。

只需19.9元,就能解锁25个Qt 5.14.2可复现项目,这个文本编辑器可直接作为课程作业素材,为你节省时间和精力。后续还有23个实用项目等你解锁,带你一步步掌握Qt 5.14.2开发技能,是不是很期待呢?赶紧行动起来吧!

http://www.cnnetsun.cn/news/101399.html

相关文章:

  • 区块链智能合约测试方法论与实践路径
  • 椭圆曲线的群、子群和阶
  • EmotiVoice如何确保克隆声音不侵犯原声权?
  • 【Java毕设全套源码+文档】基于springboot的人力资源管理系统的设计与实现(丰富项目+远程调试+讲解+定制)
  • 【Java毕设全套源码+文档】基于Java的贫困地区儿童资助系统的设计与实现(丰富项目+远程调试+讲解+定制)
  • jQuery EasyUI 应用 - 创建展开行明细编辑表单的 CRUD 应用
  • 9、量子计算在供应链实时路线优化中的应用
  • 【JVS更新日志】物联网、低代码、项目管理12.17更新说明!
  • 网络安全证书合集,看这一篇就够啦!
  • 打卡信奥刷题(2549)用C++实现信奥 P2113 看球泡妹子
  • 四天学会一本书的公司靠谱吗
  • 低成本高质量:为何越来越多团队选择EmotiVoice?
  • EmotiVoice与主流语音框架对比:兼容性与扩展性优势
  • 2025年网络安全人员薪酬趋势
  • EmotiVoice是否支持方言合成?当前进展说明
  • EmotiVoice语音合成系统灰度总结报告撰写框架
  • EmotiVoice语音合成系统负载均衡部署方案探讨
  • 基于SSM框架的后台管理系统设计与实现
  • Python基础练习5.按顺序输出整数
  • 毕设救星:Spring Boot + Vue 打造“数字非遗”——中华传统文化展示与文创众筹平台
  • 政策模型出现再平衡:美联储主席遴选路径反转,哈塞特在“联储独立性约束条件”下明确立场
  • 医院信息科经常听到的那些话
  • 校园实验室|基于springboot 校园实验室管理系统(源码+数据库+文档)
  • AI的下一个十年,属于Agent!读懂这篇,你就抓住了未来十年的最大红利!
  • 基于springboot + vue律师咨询系统(源码+数据库+文档)
  • 基于springboot + vue动物园管理系统(源码+数据库+文档)
  • 锐捷网络设备(盒式交换机,路由器,EG网关,无线AC、AP)恢复出厂设置
  • 锐捷RG-AP220-E胖模式配置
  • 2026毕设ssm+vue基于框架的临时摊位管理系统论文+程序
  • 重磅推出!郑老师团队26年22门统计课程,发文即可退款