一、效果展示
两个RichTextBox同步滚动
二、winuser提供的API
GetScrollPos 函数 (winuser.h)
获得指定滚动条中的滚动框(滑块)的当前位置。
GetScrollRange 函数 (winuser.h)
获得指定滚动条的当前最小和最大滚动框(滑块)的位置。
SetScrollPos 函数 (winuser.h)
设置在指定的滚动条中的滚动框(滑块)的位置。
SetScrollRange 函数 (winuser.h)
设置指定的滚动条的最小和最大的滚动框位置。
三、获取RichTextBox行高
RichTextBox
中没有直接获得行高的方法API,但是还有其他招。
- 先获得
RichTextBox
滚动框的范围 - 除以
RichTextBox
的行数 - 即可得到
RichTextBox
的行高
[DllImport("user32.dll")]
private static extern int GetScrollPos(IntPtr hWnd, Int32 nBar);
[DllImport("user32.dll")]
private static extern bool GetScrollRange(IntPtr hWnd, int nBar, out int lpMinPos, out int lpMaxPos);
private const Int32 SB_VERT = 0x00000001;
int scrollRange = 0;
int lineHeight = 0;
private void Form1_Load(object sender, EventArgs e)
{
Console.WriteLine("Form1_Load");
int min, max;
if(GetScrollRange(richTextBox2.Handle, SB_VERT, out min, out max))
{
scrollRange = max - min;
lineHeight = scrollRange / richTextBox2.Lines.Length;
Console.WriteLine("min = " + min);
Console.WriteLine("max = " + max);
Console.WriteLine("scrollRange = " + scrollRange);
Console.WriteLine("lineHeight = " + lineHeight);
}
}
四、获取当前位置行号
GetScrollPos
获得指定滚动条中的滚动框(滑块)的当前位置- 除以
RichTextBox
行高 - 即可得到
RichTextBox
当前滚动的行号
int pos = GetScrollPos(richTextBox2.Handle, SB_VERT);
int line = (int)(pos / (lineHeight));
Console.WriteLine("richTextBox2 line = " + line);
五、滚动到指定行号位置
GetFirstCharIndexFromLine
检索给定行第一个字符的索引SelectionStart
设置该索引到文本框中的选定文本的起始点ScrollToCaret
将控件内容滚动到当前插入符号位置
int index = richTextBox2.GetFirstCharIndexFromLine(line);
richTextBox1.SelectionStart = index;
richTextBox1.SelectionLength = 0;
richTextBox1.ScrollToCaret();
六、实现两个RichTextBox同步滚动
private void richTextBox2_VScroll(object sender, EventArgs e)
{
int pos = GetScrollPos(richTextBox2.Handle, SB_VERT);
int line = (int)(pos / (lineHeight));
Console.WriteLine("richTextBox2 line = " + line);
int index = richTextBox2.GetFirstCharIndexFromLine(line);
richTextBox1.SelectionStart = index;
richTextBox1.SelectionLength = 0;
richTextBox1.ScrollToCaret();
}
这个方法全网都没有,也是折腾了大半天才弄出来的哦
觉得好,就一键三连呗(点赞+收藏+关注)
版权声明:本文为kangweijian原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。