Scintilla使用指南(2) - 全文检索和修改
来自http://blog.csdn.net/skyremember/archive/2008/09/27/2985512.aspx
在Scintilla中,每个字符后面,都跟有一个表示字符样式的字节,字符字节和样式字节一起组成一个字符单元。样式字节的8个bit,分为两部分:字符样式和字符指示器。通过SCI_INDICATORFILLRANGE消息可以设置一段文本的字符指示器。默认低5位为字符样式,高3位为字符指示器。因此,可以有32种字符样式。3个互相独立的字符指示器,可以用来指示语法错误、不赞成的名字和坏的缩进等信息。可以使用SCI_SETSTYLEBITS消息设置字符样式位最大到7个bit位,剩下的将被分配给字符指示器。
Position指示了Scintilla中的字符或字符前空白点的位置。第一个字符的position是0,第二个是1,依此类推。假如文档包含了nLen个字符,则最后一个字符的position是nLen – 1。光标存在于两个字符之间,能够被定位到第一个字符之前(0)和最后一个字符之后(nLen)。
当两个字符被当作一个字符处理时,光标是无法存在于两个字符之间的。这种情况,通常发生在中文等多字节字符或行结束符为CRLF时。常量INVALID_POSITION(-1)表示一个非法位置。
出于性能考虑,所有文本行具有相同的高度:当前样式中最大字体的高度。
SCI_GETTEXT, SCI_SETTEXT
1) SCI_GETTEXT(int length, char *text)
获取文本:
(1) 当text为0时,返回整个文档长度len + 1;
(2) 当length为0时,返回0;
(3) 当text不为0且length大于0时,返回length – 1,text被填充为从位置0开始的length – 1个字符和一个0终结符。如果length大于文档长度,多出的位置将被填充为空字符0。
unsigned int len = SendMessage(SCI_GETTEXT, 0, 0);
char *chText = new char[len];
SendMessage(SCI_GETTEXT, len, (LPARAM)chText);
…
delete [] chText;
2) SCI_SETTEXT(<unused>, const char *text)
设置文档文本为text,text是以0结尾的常量字符串。如果text为0,返回FALSE(0),否则返回TRUE(1)。
SCI_SETSAVEPOINT
SCI_SETSAVEPOINT
设置保存点,文档状态将变为unmodified,返回TRUE(1)。SCI_SETSAVEPOINT消息将会触发SCN_SAVEPOINTREACHED事件通知。当文档状态变为modified时,将会触发SCN_SAVEPOINTLEFT事件通知。
SCI_GETLINE
SCI_GETLINE(int line, char *text)
获取指定行文本,返回指定行文本长度(包括行结束符)。行号line从0开始,如果行号大于最大行号,将返回0。当text为0时,直接返回指定行文本长度;当text不为0时,text将被填充为指定行文本,但并不会自动设置结束符0。
unsigned int len = SendMessage(SCI_GETLINE, 1, 0);
char *chText = new char[len + 1];
memset(chText, 0, len + 1);
SendMessage(SCI_GETLINE, 1, (LPARAM)chText);
…
delete [] chText;
SCI_REPLACESEL
SCI_REPLACESEL(<unused>, const char *text)
替换选择文本,text是以0结尾的常量字符串。当没有文本被选择时,将在当前位置插入文本。替换后,光标将处于插入文本之后,并自动滚动视图,以使文本可见。当text为0时,返回FALSE(0),否则返回TRUE(1)。
SCI_SETREADONLY, SCI_GETREADONLY
1) SCI_SETREADONLY(bool readOnly)
设置文档为只读,返回TRUE(1)。文档处于只读状态时,当文档发生修改,将会触发SCN_MODIFYATTEMPTRO事件通知。
2) SCI_GETREADONLY
获取文档只读状态,返回TRUE(1)或FALSE(0)。
SCI_GETTEXTRANGE
SCI_GETTEXTRANGE(<unused>, TextRange *tr)
获取指定范围文本,如果tr为0,返回0,否则返回文本长度(不包括0终结符),并填充tr.lpstrText为指定范围的文本和一个0终结符。当tr.chrg.cpMax为-1时,表示到文档结束位置。你必须确保tr.lpstrText字符缓冲区足够大((tr.chrg.cpMax - tr.chrg.cpMin) + 1)。
SCI_GETSTYLEDTEXT
SCI_GETSTYLEDTEXT(<unused>, TextRange *tr)
获取指定范围样式文本,与SCI_GETTEXTRANGE类似,但所需字符缓冲区大小是SCI_GETTEXTRANGE的2倍(2 * (tr.chrg.cpMax - tr.chrg.cpMin) + 2)。Scintilla将会自动追加2个0终结符到tr.lpstrText尾部。
SCI_ALLOCATE
SCI_ALLOCATE(int bytes, <unused>)
分配足够大的缓冲区,以容纳指定大小的字节,返回TRUE(1)。只有当指定大小大于当前缓冲区大小时,才会重新分配缓冲区,否则不做任何处理。
SCI_ADDTEXT
SCI_ADDTEXT(int length, const char *s)
在当前位置插入指定文本的指定长度,s是以0结尾的常量字符串,返回0。插入文本后,当前位置处于插入文本之后,但视图并不会自动进行滚动,以使其可见。
SCI_ADDSTYLEDTEXT
SCI_ADDSTYLEDTEXT(int length, cell *s)
在当前位置插入样式文本,处理方式和SCI_ADDTEXT相似,返回0。
SCI_APPENDTEXT
SCI_APPENDTEXT(int length, const char *s)
在文档尾部插入文本,处理方式和SCI_ADDTEXT相似,返回0。
SCI_INSERTTEXT
SCI_INSERTTEXT(int pos, const char *text)
在指定位置插入文本,处理方式和SCI_ADDTEXT相似,返回0。当pos为-1时,表示在当前位置插入。
SCI_CLEARALL
SCI_CLEARALL
除非文档只读,否则删除文档所有字符,返回0。
SCI_CLEARDOCUMENTSTYLE
SCI_CLEARDOCUMENTSTYLE
清除文档所有样式信息,返回0。这通常用在需要重新设置文档样式的时候。
SCI_GETCHARAT
SCI_GETCHARAT(int position)
返回指定位置的字符。当position小于0或大于文档结束位置时,返回0。
SCI_GETSTYLEAT
SCI_GETSTYLEAT(int position)
返回指定位置的样式。当position小于0或大于文档结束位置时,返回0。
SCI_SETSTYLEBITS, SCI_GETSTYLEBITS
1) SCI_SETSTYLEBITS(int bits)
设置字节中样式位宽,返回TRUE(1)。默认为5个bit,最大可以设置为7位,剩余的bit位将被用来表示字符指示器。
2) SCI_GETSTYLEBITS
返回字节中样式位宽。
SCI_TARGETASUTF8 *
SCI_TARGETASUTF8(<unused>, char *s)
将目标字符串转换为UTF8编码格式,返回编码文本长度,并将编码后的字节填充到s中。此消息只在GTK+平台提供。
SCI_ENCODEDFROMUTF8 *
SCI_ENCODEDFROMUTF8(const char *utf8, char *encoded)
将UTF8格式字符串转换为文档编码格式,返回转换后的字节长度,并将转换后的字节填充到encoded中。此消息只在GTK+平台提供。
SCI_SETLENGTHFORENCODE
SCI_SETLENGTHFORENCODE(int bytes)
设置文档编码长度,返回0。
分享到:
相关推荐
2. **Scintilla控件的使用** - 首先,你需要在项目中包含Scintilla库,这可能涉及下载源码,编译生成动态或静态库,然后链接到你的应用程序。 - 创建Scintilla控件,通常是在用户界面上添加一个窗口控件,然后将其...
### Scintilla开源库使用指南知识点详述 #### 一、Scintilla简介与特性 Scintilla 是一款免费的源代码编辑控件,具备高度的可移植性,支持多种操作系统平台,例如 Windows 和 Unix/Linux 等。该编辑器完全开放源...
2. **API推荐**:早期版本模仿了标准Windows Edit和RichEdit控件定义的API,但后来更倾向于使用Scintilla自己的API,以保持一致性。 3. **语法样式控制**:除了基本的编辑功能外,Scintilla还允许开发者控制语法样式...
6. "Scintilla使用指南(一) - sky的技术天空 - CSDNBlog.txt" 和 "Scintilla使用指南(二) - sky的技术天空 - CSDNBlog.txt":这两篇指南深入介绍了Scintilla的使用,包括了如何集成到自定义编辑器中,以及如何利用其...
总的来说,Scintilla是一个强大且灵活的源代码编辑控件,它以其开源、跨平台和高度可配置的特性,赢得了开发者的广泛认可和使用。无论是在大型IDE还是小型文本编辑器中,Scintilla都能提供专业级的代码编辑体验。
Scintilla控件是一款强大的文本编辑组件,广泛用于各种代码编辑器、IDE(集成开发环境)和其他需要文本处理的应用程序中。它以其高度可定制性和丰富的特性集而著名,允许开发者自定义语法高亮、代码折叠、自动完成等...
基于对话框和Scintilla控件的C++源代码编辑器,使用了MFC对话框,使用了Scintilla控件,实现了新建、打开、保存功能,实现了撤消、剪切、复制、粘贴、删除、查找、全选功能,可以实现代码关键字高亮
- "Using-Scintilla-for-syntax-coloring-in-MFC.pdf"可能是详细的步骤指南或示例代码,阅读它可以帮助你更好地理解和实现Scintilla在MFC中的应用。 总之,将Scintilla集成到MFC项目中,可以为你的应用程序提供...
"与Scintilla一起使用" 表明 Lexilla 是 Scintilla 编辑组件的扩展或补充,提供更强大的语言支持和服务。 **描述分析:** 描述简单明了,直指 Lexilla 的核心功能——作为 Scintilla 的配套库。这暗示了 Lexilla ...
Scintilla4Web 是 Scintilla-Text-Editor 的一个小包装。 它提供了一个 Mozilla 插件和一个 ActiveX 控件(IE 支持),可以通过 OBJECT 或 EMBED 标签将 Scintilla-Editor 嵌入到 HTML 页面中。
在提供的链接(http://blog.chinaunix.net/uid-24517893-id-3014393.html)中,可能有更详细的使用指南和示例代码,可以帮助你开始使用Scintilla 3.72。 总之,Scintilla是一个强大且灵活的文本编辑组件,广泛应用...
在本案例中,“scintilla的MFC封装”是指将Scintilla组件与MFC框架相结合,以便在基于MFC的应用程序中方便地使用Scintilla的功能。 Scintilla 1.77是这个封装所基于的版本,这可能包含了一些改进和修复,使其更适合...
Scintilla-Sharp 是一个专为 .NET 和 Mono 平台设计的开源项目,它提供了对 Scintilla 编辑器组件的 gtk-sharp 绑定。Scintilla 是一个功能强大的文本编辑器控件,广泛用于源代码编辑器、IDE(集成开发环境)和其他...
本文档介绍的是基于 **Scintilla 3.24** 版本,在 **Microsoft Foundation Classes (MFC)** 框架下的使用方式。这里提到的 **NC编辑控件**(CNcEditWnd)是对Scintilla进行了一层封装的类,旨在简化Scintilla在MFC...
Scintilla是一款开源的文本编辑组件,主要由C++编写,设计目的是提供一个高质量的文本编辑器基础,供开发者在各种应用程序中使用。它不仅具备基本的文本编辑功能,如文本选择、剪切、复制、粘贴等,还支持语法高亮、...
通过这些文件,你可以使用合适的编译工具(如GCC或Visual Studio)编译和链接Scintilla库,然后将其集成到你的应用程序中。 总之,Scintilla是一个功能强大的文本编辑组件,它的开源特性使得开发者可以自由地对其...
Scintilla的设计目标是跨平台,可以在多种操作系统上运行,如Windows、Linux和macOS等,这使得开发者能够在不同环境下都能使用到一致的编辑器界面和功能。它的可移植性是其受欢迎的一个重要原因。 语法高亮是...
在实际开发中,Scintilla通常与一个图形用户界面库(如wxWidgets或Qt)结合使用,以构建完整的编辑器应用程序。开发者可以利用这些库提供的窗口和布局管理功能,同时结合Scintilla的强大文本处理能力,创建出美观且...
在这个项目中,可能是MIT、Apache 2.0或其他开源许可证,允许用户自由使用、修改和分发源代码,但可能需要遵循特定的条款,如保留原有版权信息。 3. `README.md`:这是项目的重要文档,通常包含了项目的简介、安装...