转Delphi中Memo显示行号列号

http://www.alonely.com.cn/Delphi/20160814/8912.html

实例说明本例是个光标应用的简单技巧,希望通过这个例子的学习后能举一反三。Delphi中像这样简单而又实用的例子还有很多,只要平时多注意积累就能写出简洁、执行效率高的代码。编程思路直接向Memo组件发送消息EM_LineFromChar并检测返回值,即可获知此组件中光标所在的行号,向Memo组件发送消息EM_LineIndex并检测返回值即可获知此组件中光标所在的列号

实例说明

本例是个光标应用的简单技巧,希望通过这个例子的学习后能举一反三。Delphi中像这样简单而又实用的例子还有很多,只要平时多注意积累就能写出简洁、执行效率高的代码。

编程思路 直接向Memo组件发送消息EM_LineFromChar并检测返回值,即可获知此组件中光标所在的行号,向Memo组件发送消息EM_LineIndex并检测返回值即可获知此组件中光标所在的列号。

编程步骤 先在Form上放置三个Label组件,并在程序代码的前面声明下面这三个变量为整型数,即: VarLpos,Cpos,Linelength:integer; 其中Lpos是行的值(按照Memo的规定,第一行为O),Cpos是字符的位置,LineLength是当前行的字符总个数。然后,再将下面的七行程序代码分别加入Memo1的OnMouseDown和OnKeyDown的事件代码处即可。Lops:=SendMessage(Memo1.Handle,EM_LineFromChar,Memol.SelStart,0);Cpos:=SendMessage(Menol.Handle,EM_LineIndex,Lpos,0);LineLength:=SendMessage(Memol.Handle,EM_LineLength,Cpos,0);Cpos:=Memol.SelStart-CPos; Label1.Caption:=IntToStr(ipos);Label2.Caption:=IntToStr(cpos); Label3.Caption:=IntToStr(linelength); 完成后,在执行程序时,随着在Memo组件中的编辑操作,Labell、Label2和Label3就将显示出相对应的当前行值、字符位置与当前行的字符总个数了。

编程总结 请大家结合“获取RichEdit组件中光标所在的行号”一起学习,实际上两者极为相似。 附另一篇:

一、如何得知当前行号
  用RichEdit(或者memo)控件制作文本编辑器时,通过访问lines count属性可以得到总行数,但是若想知道光标当前所在行的行号就麻烦了,因为delphi没有提供这个属性。要实现这个编辑器必备功能,就须调用 em_ LineFromChar。请试试下面的程序。
  先在窗口中布置一个RichEdit或者memo(命名为editor),以及一个button。在button的onclick事件中写入下列代码。
  var
  CurrentLine:Integer;
  begin
  CurrentLine:=Editor Perform(em_ LineFromChar,SFFFF,0);
  Application MessageBox(PChar(′当前行号是′+IntToStr(CurrentLine)),′消息′,mb_ iconinformation);
  end;
  需要注意的是,第一行的行号为零。
  二、如何撤消操作(undo)
  对于memo来说,实现undo是不需编程的,只要让popupmenu属性为空,运行时就能用鼠标右键激活一个常用操作菜单,其中包括撤消、剪切、复制、粘贴、删除和全选六项。
  但可惜的是,这一招对于功能强大的RichEdit控件居然行不通,害得我们还要自己设计一个popupmemu。当你用 CutToClipBoard等语句轻松而顺利地完成了“剪切”等功能,接着便会无奈地发现,竟找不到undo或cancel之类的语句来执行“撤消”。
  这时你需要这样处理:
  RichEdit1 Perform(EM_UNDO,0,0);
  另外还应检查是否允许撤消,从而开启或关闭弹出菜单中的“撤消”项:
  Undo1 Enabled:=RichEdit Perform(EM_CANUNDO,0,0)<>0;
  以上程序在Delphi3中调试通过。

时间: 2024-10-08 02:57:15

转Delphi中Memo显示行号列号的相关文章

比较两个文本文档的不同,并显示第一出不同的行号列号

比较两个文本文档的区别,并打印出第一处不同点的行号列号 #!/usr/bin/env python#coding=utf-8file1=raw_input("please input the firest filename:")            //输入第一个文件名file2=raw_input("please input the second filename:")         //输入第二个文件名myfile1=open(file1)         

清空dataset中的某行某列的数据

string tempSFZH = ""; foreach (DataRow rs in ds.Tables[0].Rows) {     tempSFZH = rs[ht["身份证号码"].ToString()].ToString();     foreach (DataRow rs1 in ds_stuAll.Tables[0].Rows)    {         foreach (DataColumn dc in ds_stuAll.Tables[0].Co

[原创]关于设置linux中vim 显示行号

1.更改所有账户配置 直接更改/etc/vimrc vim /etc/vimrc 在vimrc文件的最后添加 set nu 即可 wq退出. 这样,不论使用哪个账号登陆,vim打开后都显示行号 2.为当前用户配置环境 找到当前用户的vimrc文件.若无此文件,建立此文件即可. vim ~/.vimrc 打开文件后,在最后添加 set nu wq退出. 再次用vim打开即可显示行号 以上方式设置后,在下一次启动vim编辑器的时候,就会自动的显示行号 3.每次手动的设置行号(不建议) 进入vim 输

Delphi中统一显示表格字段名的高效方法

问题描述:在开发数据库程序时,我们经常要使用很多的表格显示组件DBGrid.当DBGrid显示某表格的数据时,其字段标题默认的就是后台数据库中的表格的字段名称.而为了数据库开发方便,后台数据库中的表格的字段标题通常是用英文表示的,如用Employees表中的EmployeesID表示雇员编号.但是我们开发给用户的程序必须以汉字显示字段标题,即我们要以‘雇员编号’显示给用户.假设我们是用ADOQuery组件(此处为了说明清楚只使用ADOQuery组件,实际可以是其它数据库组件)query1来加载E

用JavaScript,获取Table中指定的行、列

<html> <head runat="server"> <title>演示获取Table的值</title> <script type ="text/javascript" language ="javascript" > // Description: 演示用JavaScript,获取Table中指定行.列元素值 // CopyRight: http://www.cnblogs.co

SQL Server中使用PIVOT行转列

1.建表及插入数据 1 USE [AdventureDB] 2 GO 3 /****** Object: Table [dbo].[Score] Script Date: 11/25/2016 4:30:50 PM ******/ 4 SET ANSI_NULLS ON 5 GO 6 7 SET QUOTED_IDENTIFIER ON 8 GO 9 10 CREATE TABLE [dbo].[Score]([Name] [varchar](50) NULL,[Subject] [varcha

Bootstrap3基础 栅格系统 列中有行,行中有列

? 内容 参数 ??OS ??Windows 10 x64 ??browser ??Firefox 65.0.2 ??framework?? ??Bootstrap 3.3.7 ??editor ??Visual Studio Code 1.32.1?? ??typesetting ??Markdown ? code <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="U

在GridView的RowDataBound事件中获取某行某列的值!

protected void gdvOrders_RowDataBound(object sender, GridViewRowEventArgs e)   {               if (e.Row.RowType == DataControlRowType.DataRow)       {           DataRowView drv = (DataRowView)e.Row.DataItem ;           if (drv.Row["Status"].ToS

Java 插入、隐藏/显示、删除Excel行或列

概述操作Excel工作表时,对表格中的行或列数据可执行,包括插入.隐藏.显示.删除等在内的多种操作需求,本文将通过Java代码示例演示每种操作的具体实现方法.文中方法使用了Java Excel类库(Free Spire.XLS for Java 免费版),可通过官网下载包,解压,并将lib文件中的jar文件导入Java程序:或者通过maven仓库导入.导入效果如下: Java代码示例1. 插入行或列 import com.spire.xls.*; public class InsertRowAn