200分!如何让VB6文本框滚动条总在上面?
VB6文本框text1.text输入内容,提交后,放到了文本框text2.text中,问题:text2.text满框后如何让滚动条始终置于最上面,也即是实现总是在text...
VB6文本框text1.text输入内容,提交后,放到了文本框text2.text中,
问题:
text2.text满框后如何让滚动条始终置于最上面,也即是实现总是在text2.text最下方显示最新提交的内容?
请写出代码. 展开
问题:
text2.text满框后如何让滚动条始终置于最上面,也即是实现总是在text2.text最下方显示最新提交的内容?
请写出代码. 展开
9个回答
展开全部
LZ你好,我觉得应该是这样:
当Text1中的内容提交到Text2中的时候,如果Text1.text的长度小于Text2的显示区域的话,的确可以用
text2.selstart=len(text2)
但是问题是如果Text1.text的长度大于Text2的显示区域的话,用text2.selstart=len(text2)就会把插入点(光标)移到Text2的最末尾,从面向用户设计的角度来说这样并不是最亲切的(一般来说用户都需要在Text1.text提交以后在Text2的文本框里显示所最新插入的Text1.text的首位置)
而要实现在Text1.text提交以后在Text2的文本框里显示所最新插入的Text1.text的首位置,可以用一个模块级变量intSum记录所有提交Text1.text的总字数,当提交Text1的内容后将Text2的插入点位于intSum所在的字符后。
代码如下:
dim intSum as integer
Private Sub Command1_Click() '当点击提交按钮时
Text2.text=Text2.text & Text1.text
Text2.selstart=intSum
intSum=len(Text2)
End Sub
因为我这里没有VB,无法调试,但个人理论就是这样了。
希望能够帮到LZ。
衷心希望LZ的问题能够早日得到解决——
当Text1中的内容提交到Text2中的时候,如果Text1.text的长度小于Text2的显示区域的话,的确可以用
text2.selstart=len(text2)
但是问题是如果Text1.text的长度大于Text2的显示区域的话,用text2.selstart=len(text2)就会把插入点(光标)移到Text2的最末尾,从面向用户设计的角度来说这样并不是最亲切的(一般来说用户都需要在Text1.text提交以后在Text2的文本框里显示所最新插入的Text1.text的首位置)
而要实现在Text1.text提交以后在Text2的文本框里显示所最新插入的Text1.text的首位置,可以用一个模块级变量intSum记录所有提交Text1.text的总字数,当提交Text1的内容后将Text2的插入点位于intSum所在的字符后。
代码如下:
dim intSum as integer
Private Sub Command1_Click() '当点击提交按钮时
Text2.text=Text2.text & Text1.text
Text2.selstart=intSum
intSum=len(Text2)
End Sub
因为我这里没有VB,无法调试,但个人理论就是这样了。
希望能够帮到LZ。
衷心希望LZ的问题能够早日得到解决——
展开全部
'添加窗体Form1,按钮Command1,文本框Text1,Text2,并将Text1和Text2的MultiLine设为True,ScrollBars设为Both,然后复制如下代码:
Private Sub Form_Load()
Dim n As Integer
For n = 1 To 10
Text1.Text = Text1.Text & CStr(n) & vbCrLf
Next
Command1.Caption = "提交"
End Sub
Private Sub Command1_Click()
Text2.Text = Text1.Text
Text2.SetFocus
Text2.SelStart = Len(Text2.Text)
End Sub
Private Sub Form_Load()
Dim n As Integer
For n = 1 To 10
Text1.Text = Text1.Text & CStr(n) & vbCrLf
Next
Command1.Caption = "提交"
End Sub
Private Sub Command1_Click()
Text2.Text = Text1.Text
Text2.SetFocus
Text2.SelStart = Len(Text2.Text)
End Sub
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
注释: 让一个窗体总是处于最前的例子
注释:-------------------------------------------
注释:程序说明:
注释:本例应用SetWindowPos函数,设置窗体的显示属性
注释:来实现让一个窗体总是处于其他窗体的前面而不会
注释:被其他窗体所遮住。
注释:-------------------------------------------
Option Explicit
注释:【VB声明】
注释: Private Declare Function SetWindowPos Lib "user32" (ByVal hwnd As Long, ByVal hWndInsertAfter As Long, ByVal x As Long, ByVal y As Long, ByVal cx As Long, ByVal cy As Long, ByVal wFlags As Long) As Long
注释:【说明】
注释: 这个函数能为窗口指定一个新位置和状态。它也可改变窗口在内部窗口列表中的位置。该函数与DeferWindowPos函数相似,只是它的作用是立即表现出来的(在vb里使用:针对vb窗体,如它们在win32下屏蔽或最小化,则需重设最顶部状态。如有必要,请用一个子类处理模块来重设最顶部状态
注释:【返回值】
注释: Long,非零表示成功,零表示失败。会设置GetLastError
注释:【备注】
注释: 窗口成为最顶级窗口后,它下属的所有窗口也会进入最顶级。一旦将其设为非最顶级,则它的所有下属和物主窗口也会转为非最顶级。Z序列用垂直于屏幕的一根假想Z轴量化这种从顶部到底部排列的窗口顺序
注释:【参数表】
注释: hwnd ----------- Long,欲定位的窗口
注释: hWndInsertAfter - Long,窗口句柄。在窗口列表中,窗口hwnd会置于这个窗口句柄的后面。也可能选用下述值之一:
注释: HWND_BOTTOM 将窗口置于窗口列表底部
注释: HWND_TOP 将窗口置于Z序列的顶部;Z序列代表在分级结构中,窗口针对一个给定级别的窗口显示的顺序
注释: HWND_TOPMOST 将窗口置于列表顶部,并位于任何最顶部窗口的前面 -1
注释: HWND_NOTOPMOST 将窗口置于列表顶部,并位于任何最顶部窗口的后面 -2
注释: x -------------- Long,窗口新的x坐标。如hwnd是一个子窗口,则x用父窗口的客户区坐标表示
注释: y -------------- Long,窗口新的y坐标。如hwnd是一个子窗口,则y用父窗口的客户区坐标表示
注释: cx ------------- Long,指定新的窗口宽度
注释: cy ------------- Long,指定新的窗口高度
注释: wFlags --------- Long,包含了旗标的一个整数,是下列之一:
注释: SWP_DRAWFRAME 围绕窗口画一个框
注释: SWP_HIDEWINDOW 隐藏窗口
注释: SWP_NOACTIVATE 不激活窗口 &H10
注释: SWP_NOMOVE 保持当前位置 (x和y设定将被忽略) &H2
注释: SWP_NOREDRAW 窗口不自动重画
注释: SWP_NOSIZE 保持当前大小 (cx和cy会被忽略) &H1
注释: SWP_NOZORDER 保持窗口在列表的当前位置 (hWndInsertAfter将被忽略)
注释: SWP_SHOWWINDOW 显示窗口 &H40
注释: SWP_FRAMECHANGED 强迫一条WM_NCCALCSIZE消息进入窗口,即使窗口的大小没有改变
Private Declare Function SetWindowPos Lib "user32" ( _
ByVal hwnd As Long, _
ByVal hWndInsertAfter As Long, _
ByVal x As Long, ByVal y As Long, _
ByVal cx As Long, ByVal cy As Long, _
ByVal wFlags As Long _
) As Long
Const HWND_TOPMOST = -1
Const SWP_SHOWWINDOW = &H40
Private Sub Form_load()
Dim retValue As Long
注释:将窗体设置为处于所有窗口的顶层,注意在 VB 中运行时,
’可能不行,但编译成EXE后就可以了
retValue = SetWindowPos(Me.hwnd, HWND_TOPMOST, Me.CurrentX,
Me.CurrentY, 300, 300, SWP_SHOWWINDOW
注释:-------------------------------------------
注释:程序说明:
注释:本例应用SetWindowPos函数,设置窗体的显示属性
注释:来实现让一个窗体总是处于其他窗体的前面而不会
注释:被其他窗体所遮住。
注释:-------------------------------------------
Option Explicit
注释:【VB声明】
注释: Private Declare Function SetWindowPos Lib "user32" (ByVal hwnd As Long, ByVal hWndInsertAfter As Long, ByVal x As Long, ByVal y As Long, ByVal cx As Long, ByVal cy As Long, ByVal wFlags As Long) As Long
注释:【说明】
注释: 这个函数能为窗口指定一个新位置和状态。它也可改变窗口在内部窗口列表中的位置。该函数与DeferWindowPos函数相似,只是它的作用是立即表现出来的(在vb里使用:针对vb窗体,如它们在win32下屏蔽或最小化,则需重设最顶部状态。如有必要,请用一个子类处理模块来重设最顶部状态
注释:【返回值】
注释: Long,非零表示成功,零表示失败。会设置GetLastError
注释:【备注】
注释: 窗口成为最顶级窗口后,它下属的所有窗口也会进入最顶级。一旦将其设为非最顶级,则它的所有下属和物主窗口也会转为非最顶级。Z序列用垂直于屏幕的一根假想Z轴量化这种从顶部到底部排列的窗口顺序
注释:【参数表】
注释: hwnd ----------- Long,欲定位的窗口
注释: hWndInsertAfter - Long,窗口句柄。在窗口列表中,窗口hwnd会置于这个窗口句柄的后面。也可能选用下述值之一:
注释: HWND_BOTTOM 将窗口置于窗口列表底部
注释: HWND_TOP 将窗口置于Z序列的顶部;Z序列代表在分级结构中,窗口针对一个给定级别的窗口显示的顺序
注释: HWND_TOPMOST 将窗口置于列表顶部,并位于任何最顶部窗口的前面 -1
注释: HWND_NOTOPMOST 将窗口置于列表顶部,并位于任何最顶部窗口的后面 -2
注释: x -------------- Long,窗口新的x坐标。如hwnd是一个子窗口,则x用父窗口的客户区坐标表示
注释: y -------------- Long,窗口新的y坐标。如hwnd是一个子窗口,则y用父窗口的客户区坐标表示
注释: cx ------------- Long,指定新的窗口宽度
注释: cy ------------- Long,指定新的窗口高度
注释: wFlags --------- Long,包含了旗标的一个整数,是下列之一:
注释: SWP_DRAWFRAME 围绕窗口画一个框
注释: SWP_HIDEWINDOW 隐藏窗口
注释: SWP_NOACTIVATE 不激活窗口 &H10
注释: SWP_NOMOVE 保持当前位置 (x和y设定将被忽略) &H2
注释: SWP_NOREDRAW 窗口不自动重画
注释: SWP_NOSIZE 保持当前大小 (cx和cy会被忽略) &H1
注释: SWP_NOZORDER 保持窗口在列表的当前位置 (hWndInsertAfter将被忽略)
注释: SWP_SHOWWINDOW 显示窗口 &H40
注释: SWP_FRAMECHANGED 强迫一条WM_NCCALCSIZE消息进入窗口,即使窗口的大小没有改变
Private Declare Function SetWindowPos Lib "user32" ( _
ByVal hwnd As Long, _
ByVal hWndInsertAfter As Long, _
ByVal x As Long, ByVal y As Long, _
ByVal cx As Long, ByVal cy As Long, _
ByVal wFlags As Long _
) As Long
Const HWND_TOPMOST = -1
Const SWP_SHOWWINDOW = &H40
Private Sub Form_load()
Dim retValue As Long
注释:将窗体设置为处于所有窗口的顶层,注意在 VB 中运行时,
’可能不行,但编译成EXE后就可以了
retValue = SetWindowPos(Me.hwnd, HWND_TOPMOST, Me.CurrentX,
Me.CurrentY, 300, 300, SWP_SHOWWINDOW
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
Private Sub Command1_Click()
Text2.Text = Text2.Text + Text1.Text '将Text1的文本复制到Text2中
Text2.SelStart = Len(Text2.Text) '实现text2总是最下方显示最新提交的内容
End Sub
Text2.Text = Text2.Text + Text1.Text '将Text1的文本复制到Text2中
Text2.SelStart = Len(Text2.Text) '实现text2总是最下方显示最新提交的内容
End Sub
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
Private Sub Command1_Click()
Text2.Text = Text2.Text & vbCrLf & Text1.Text
Text1.SetFocus
End Sub
这样就行 新添加的在最下面 滚动条在最顶上
Text2.Text = Text2.Text & vbCrLf & Text1.Text
Text1.SetFocus
End Sub
这样就行 新添加的在最下面 滚动条在最顶上
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询