Qt文本高亮控件Qscitinlla的用法

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/e_one/article/details/71037103

背景

平常要是叫我们自己写高亮的文本编辑器我们肯定会先想到用QTextEdit然后用正则表达式匹配指定位置着色,但是这样子写个简单的着色还好,要是复杂点,比如要对某个编程语言的各种关键字,字符串,注释等这些着色,用正则很麻烦不说,还容易出错,而且难以写出高效率着色的代码。所以,本文的主角Qscitinlla就闪亮登场了。

Qscitinlla介绍

Qscitinlla的前身是Scintilla,一个非常强大的文本编辑器控件,我们常用的Notepad++就是基于这个库开发的,官网:http://www.scintilla.org,Qscitinlla是用在Qt开发平台上的Scintilla的移植版本。

Qscitinlla配置

Qscitinlla下载地址: https://riverbankcomputing.com/software/qscintilla/download

根据平台下载后解压,进入Qt4Qt5目录,用QtCreator打开qscintilla.pro,构建项目,稍等片刻,编译完成,会在解压目录下的build-qscintilla-Desktop_Qt****/release生成qscintilla2.lib或者qscintilla2.a文件,这主要是取决于你用什么编译器。然后创建一个Qt桌面应用,将刚才生成的静态链接库导入到工程中,并将解压目录下的Qt4Qt5中的Qsci目录拷贝到新创建的工程目录下。到这,Qscitinlla就配置好了。

Qscitinlla的使用

QsciScintilla是QWidget的非直接子类,所以,它也是个控件。在使用之前,要引入QsciScintilla控件的头文件 

#include <Qsci/qsciscintilla.h>
 
 

1.创建一个QsciScintilla实例并填满主窗口


 
 
  1. QsciScintilla *editor= new QsciScintilla( this);
  2. setCentralWidget(editor);

这样,一个文本编辑器控件创建好了。

2.实现代码高亮

QsciScintilla自带有多种语言的词法分析器,所以它支持多种语言的代码高亮,在这里,我们使用Lua语言的词法分析器来做例子,首先,引入Lua词法分析器类的头文件#include <Qsci/qscilexerlua.h>,然后给QsciScintilla设置词法分析器。


 
 
  1. QsciLexerLua *textLexer = new QsciLexerLua; //创建一个词法分析器
  2. editor->setLexer(textLexer); //给QsciScintilla设置词法分析器

3.显示行号

QsciScintilla左边可显示页边(Margins)和标记(Markers)。

页边是位于文本显示区左边的一竖条区域,它可以用于显示行号、书签、断点标记等, Scintilla最多可以有5个页边(从左到右的编号为0~4)。

标记是用于标记文本的位置。(参考:http://www.cnblogs.com/superanyi/archive/2011/04/07/2008636.html

那我们如何显示行号呢,看下面的代码:


 
 
  1. editor->setMarginType( 0,QsciScintilla::NumberMargin); //设置编号为0的页边显示行号。
  2. editor->setMarginLineNumbers( 0, true); //对该页边启用行号
  3. editor->setMarginWidth( 0, 50); //设置页边宽度


4.实现代码提示

代码提示功能依靠QsciAPIs类实现,QsciAPI类定义在Qsci/qsciapis.h中,如果你要提示的词不多,可以使用add方法往添加关键词,添加完后调用prepare方法。


 
 
  1. QsciAPIs *apis = new QsciAPIs(textLexer);
  2. apis->add(QString( "local"));
  3. apis->prepare();

但是如果你要提示的关键字很多,那就考虑把关键字存到文件,每个关键词为一行,然后调用load方法从文件加载了。


 
 
  1. QsciAPIs*apis = new QsciAPIs(textLexer);
  2. if(!apis->load(QString( "D://api.txt")))
  3. QMessageBox::warning(this,QString( "提示"),QString( "读取文件失败"));
  4. else
  5. apis->prepare();

还可以对代码提示配置其他选项。


 
 
  1. editor->setAutoCompletionSource(QsciScintilla::AcsAll); //设置源
  2. editor->setAutoCompletionCaseSensitivity( true); //设置自动补全大小写敏感
  3. editor->setAutoCompletionThreshold( 1); //设置每输入一个字符就会出现自动补全的提示


5.设置字体

editor->setFont(QFont("Courier New"));
 
 

6.设置编码

Scintilla默认编码是ANSI ,所以刚开始输入中文字符会出现乱码,我们可以给它设置为UTF-8,这样中文也可以正常显示了

editor->SendScintilla(QsciScintilla::SCI_SETCODEPAGE,QsciScintilla::SC_CP_UTF8);//设置编码为UTF-8
 
 

7. SendScintilla函数

SendScintilla是外界与Scintilla交互的通道,通过SendScintilla函数,可以给QScintilla控件发送各种消息来操作它。SendScintilla函数有很多个重载形式。各种可以发送的消息被定义在qsciscintillabase.h这个头文件中。各种消息的用法,请参考QsciScintillaBase类的文档,它位于解压目录的doc下html-Qt4Qt5目录。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值