QT開篇——一個簡單的文本查看器

2024-09-01 05:32

本文主要是介绍QT開篇——一個簡單的文本查看器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

打算趁着假期這幾天用QT寫一個簡單的計算器。所以便開始動手學習QT。所以這篇文章是我邊摸索邊寫的。其中肯定會有不對的地方。所以如果有哪位看我的博客的話,歡迎之出來錯誤。大家共同進步。
QT是一套跨平臺的應用程序開發框架,貌似遊戲爐石傳說就是用這個做出來的。
其實它和微軟年久失修的MFC都是MVC軟件設計模式的一種實現。至於MVC軟件設計模式,作爲一個剛入門的程序員我也說不清,我也說不了。大概意思就是是軟件的輸入,輸出,顯示分離開來。這樣的話有助維護程序的健壯性。具體的信息,你看Wiki吧。不要看那個什麼百度百科,Wiki簡直一部大教科書。
至於程序的安裝這裏就不介紹了,我用的是QT5+MingW4.8.1。因爲QT5貌似才發佈沒多久,所以我這種也是邊查資料,邊寫的。中文資料不太多,不過以前的QT4和這個差不多。其實看英文資料挺好的,想幹程序員這一行,不會英文是不行的。連我這種六級都過不了的都開始看英文資料了。各位看官,一起努力吧。

程序的運行結果截圖:

具體步驟如下:

1:創建TextFinder項目

選擇文件->新建文件或項目->應用程序->Qt Widgets Application如下圖:
这里写图片描述
名字這一項,改爲TextFinder
这里写图片描述
接下來,在Kits這一項,可以選擇是Debug版本還是Release版本,我這裏是連個都選擇了。
这里写图片描述
Details中把類名字改爲TextFinder,基類選擇QWidget
这里写图片描述
然後下一步,點擊完成即可。現在我們的一個項目新建完成。如果一切正常,在編輯菜單中你會發現以下幾個文件:
textfinder.h
TextFinder.pro
main.cpp
textfinder.cpp

具體實現

現在基本框架已經搭建好,剩下的就是寫實現代碼了。畢竟作爲一個程序員,多多少少要寫代碼的嘛。
首先就是设计用户接口部分。个人感觉这部分是属于MVC设计模式中的视图部分吧。
QT中点击设计
这里写图片描述
进入如下界面:
这里写图片描述
找到下列元素并拖放:
Label
Line Edit
Push Button
效果如下:

这里写图片描述
上述那些控件只需要找到之后拖放进去就行,这些控件很容易就能找到。实在不行也可以在边栏上的搜索框搜索即可。
这里写图片描述
接下来可以按Ctrl+A或者用鼠标选中这些部件,进行水平布局。为了美观嘛,在Linux和Windows上可以按Ctrl+H,据说在Mac OSX上是Ctrl+Shift+H
这里写图片描述
接下来,找到Text Edit部件,拖放到设计框中。
选中这些部件,然后进行垂直布局。Ctrl+L

信号槽机制

简单地介绍一下信号槽机制。这是QT种一种信号处理机制。例如当1个按钮被按下时,会传递一个信号。这个信号可以被一个槽捕获,然后相对应的槽便会对这个信号进行处理。好了,上述就是大概意思,肯定有不对的地方,欢迎拍砖。

现在为Push Button添加事件处理机制。

右键单击PushButton->转到槽->Click()->OK
这里写图片描述
这里写图片描述

此时如果OK,你会发现你的textfiner.h头文件会增加如下两个函数。
private slots:void on_pushButton_clicked();private:Ui::TextFinder *ui;void loadTextFile();  //这个函数为手动添加的

在textfinder.cpp中添加代码:

void TextFinder::loadTextFile()
{QFile inputFile(":/input.txt");inputFile.open(QIODevice::ReadOnly);QTextStream in(&inputFile);QString line = in.readAll();inputFile.close();ui->textEdit->setPlainText(line);QTextCursor cursor = ui->textEdit->textCursor();cursor.movePosition(QTextCursor::Start, QTextCursor::MoveAnchor, 1);
}

此时还要注意两个头文件:

#include <QFile>
#include <QTextStream>

on_pushButton_clicked() 添加代码

void TextFinder::on_findButton_clicked()
{QString searchString = ui->lineEdit->text();ui->textEdit->find(searchString, QTextDocument::FindWholeWords);
}

同时呢,构造函数也需要做一点小小的改变。

TextFinder::TextFinder(QWidget *parent): QWidget(parent), ui(new Ui::TextFinder)
{ui->setupUi(this);loadTextFile();
}

至此,程序基本算是完成。不过还有一个很简单的步骤。

创建资源

文件->新建文件或项目->Qt->Qt资源文件
这里写图片描述
名称改为textfinder
这里写图片描述
接着点解Next,默认完成即可。

在资源中:
添加->Add Prefix
并在Prefix中添加一个斜线(/)来代替默认的,并点击添加文件,把input.txt添加进去即可。
这里写图片描述
接下来只需要,编译运行你的程序就行啦。
OK,就酱紫。

这篇关于QT開篇——一個簡單的文本查看器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1126072

相关文章

Linux使用cut进行文本提取的操作方法

《Linux使用cut进行文本提取的操作方法》Linux中的cut命令是一个命令行实用程序,用于从文件或标准输入中提取文本行的部分,本文给大家介绍了Linux使用cut进行文本提取的操作方法,文中有详... 目录简介基础语法常用选项范围选择示例用法-f:字段选择-d:分隔符-c:字符选择-b:字节选择--c

Qt 中集成mqtt协议的使用方法

《Qt中集成mqtt协议的使用方法》文章介绍了如何在工程中引入qmqtt库,并通过声明一个单例类来暴露订阅到的主题数据,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一,引入qmqtt 库二,使用一,引入qmqtt 库我是将整个头文件/源文件都添加到了工程中进行编译,这样 跨平台

C#使用DeepSeek API实现自然语言处理,文本分类和情感分析

《C#使用DeepSeekAPI实现自然语言处理,文本分类和情感分析》在C#中使用DeepSeekAPI可以实现多种功能,例如自然语言处理、文本分类、情感分析等,本文主要为大家介绍了具体实现步骤,... 目录准备工作文本生成文本分类问答系统代码生成翻译功能文本摘要文本校对图像描述生成总结在C#中使用Deep

通过C#获取PDF中指定文本或所有文本的字体信息

《通过C#获取PDF中指定文本或所有文本的字体信息》在设计和出版行业中,字体的选择和使用对最终作品的质量有着重要影响,然而,有时我们可能会遇到包含未知字体的PDF文件,这使得我们无法准确地复制或修改文... 目录引言C# 获取PDF中指定文本的字体信息C# 获取PDF文档中用到的所有字体信息引言在设计和出

基于Qt Qml实现时间轴组件

《基于QtQml实现时间轴组件》时间轴组件是现代用户界面中常见的元素,用于按时间顺序展示事件,本文主要为大家详细介绍了如何使用Qml实现一个简单的时间轴组件,需要的可以参考下... 目录写在前面效果图组件概述实现细节1. 组件结构2. 属性定义3. 数据模型4. 事件项的添加和排序5. 事件项的渲染如何使用

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

python与QT联合的详细步骤记录

《python与QT联合的详细步骤记录》:本文主要介绍python与QT联合的详细步骤,文章还展示了如何在Python中调用QT的.ui文件来实现GUI界面,并介绍了多窗口的应用,文中通过代码介绍... 目录一、文章简介二、安装pyqt5三、GUI页面设计四、python的使用python文件创建pytho

Java操作xls替换文本或图片的功能实现

《Java操作xls替换文本或图片的功能实现》这篇文章主要给大家介绍了关于Java操作xls替换文本或图片功能实现的相关资料,文中通过示例代码讲解了文件上传、文件处理和Excel文件生成,需要的朋友可... 目录准备xls模板文件:template.xls准备需要替换的图片和数据功能实现包声明与导入类声明与

QT实现TCP客户端自动连接

《QT实现TCP客户端自动连接》这篇文章主要为大家详细介绍了QT中一个TCP客户端自动连接的测试模型,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录版本 1:没有取消按钮 测试效果测试代码版本 2:有取消按钮测试效果测试代码版本 1:没有取消按钮 测试效果缺陷:无法手动停

python解析HTML并提取span标签中的文本

《python解析HTML并提取span标签中的文本》在网页开发和数据抓取过程中,我们经常需要从HTML页面中提取信息,尤其是span元素中的文本,span标签是一个行内元素,通常用于包装一小段文本或... 目录一、安装相关依赖二、html 页面结构三、使用 BeautifulSoup javascript