快捷搜索:  as  2018  FtCWSyGV  С˵  test  xxx  Ψһ  w3viyKQx

澳门新葡新京是真的吗:利用微软网格控件进行编辑输入



Visual Basic中供给了许多标准控件和定制控件,每一个控件都可以供给一组特殊的用户界面和编程能力。充分使用每一个控件的特点和措施,可以使编程事情加倍轻易、简单。

微软网格控件MSFlexGrid是个定制控件。应用微软网格控件,可以按行列顺序显指正文、数字和图片,就象电子表格一样。网格的高度、宽度和其它特点都可以进行调剂,而且网格的行和列可以单个地或成组地进行操作。MSFlexGrid控件对包孕在内的单元内容可进行分类、合并以及款式化,并且可以与数据库控件相绑定。MSFlexGrid控件具有50多种属性,比其它网格控件功能更强大年夜,机动性更强。

然则MSFlexGrid控件同其它Grid网格控件一样,用户不能编辑网格单元中的内容,在要求对其内容进行改动时,这可能是一个缺陷。虽然可以对DBGrid控件进行编程完成编辑的功能,但其功能不如MSFlexGrid强大年夜。当在录入事情量对照大年夜时,假如使用MSFlexGrid进行输入,代替Text或其它控件,从而避免了界面的反复刷新和赓续地操作按钮,录入速率和效率会得以大年夜大年夜前进。

在利用法度榜样中应用 MSFlexGrid 之前,应先将 MSFlxGrd.ocx 文件添加到工程中。

实现编辑网格单元的规划

为了仅仅要求实现能够对网格单元进行输入,可以在MSFlexGrid的KeyPress事故中加入以下代码,然则改动编辑输入后的内容还好不轻易。

Sub MSFLexGrid1_KeyPress(KeyAscii As Integer)

MSFlexGrid1.Text=MSFlexGrid1.Text & Chr$(KeyAscii)

End Sub

别的一种措施是文本框和网格相结合,用户编辑操作文本框中的内容,操作完后移至网格单元中。在这个历程中,应该实现以下几个功能:

(1)文本框能准确定位,与待编辑网格单元相重合(2)日常平凡文本框不显示,当进行编辑操作时显示(3)在输入完一行后能自动判断并加一新行(4)按回车键确认并自动到下一列(5)双击网格单元可显示文本框进行编辑(6)文本框消掉后,把文本框内容移到网格单元中。

编辑网格单元的详细实现

建立一个新工程,在Form1上添加控件 Te澳门新葡新京是真的吗xt1和MSFlexGrid1,根据表1设置其属性。

表1 表单Form1的工具和属性

工具

属性

设置

Text1

Visible

False

Text

“”

MSFlexGrid1

Rows

2

Cols

根据字段数目自行设置

FixedCols

0

FixedRows

1

首先要实现文本框显示的时刻,能与网格单元准确重合。ShowTextBox子例程便可以实现此功能。在此斟酌网格本身的Top和Left值、网格单元的高度和宽度、分隔网格单元的边框的宽度。

Sub ShowTextBox()

With MSFlexGrid1

'暗藏文本框,设置高度和宽度

Text1.Visible = False

Text1.Height = .RowHeight(.Row) - (Screen.TwipsPerPixelY) * 2

Text1.Width = .ColWidth(.Col)

' 谋略文本框左坐标

Text1.Left = .CellLeft + .Left

Text1.Top = .CellTop + .Top

Text1.Visible = True

Text1.SetFocus

End With

End Sub

当有按键触发网格单元时,则把单元中的内容保存到文本框中,然后显示文本框等待编辑。

Private Sub MSFlexGrid1_KeyPress(KeyAscii A澳门新葡新京是真的吗s Integer)

Dim char As String

If KeyAscii = 13 Then

Te澳门新葡新京是真的吗xt1.Text = MSFlexGrid1.Text

Text1.SelStart = Len(Text1.Text)

Else

char = Chr$(KeyAscii)

Text1.Text = char

Text1.SelStart = 1

End If

ShowTextBox

KeyAscii = 0

End Sub

当焦点脱离一个网格单元时,先保存文本框中的内容到网格单元,然后检测脱离单元是否在最大年夜行第一列(可自己设第几列),假如是自动加一行。

Private Sub MSFlexGrid1_LeaveCell()

MSFlexGrid1.Text = Text1.Text

If MSFlexGrid1.Col = 0 And MSFlexGrid1.Row"" Then

MSFlexGrid1.Rows = MSFlexGrid1.Rows + 1

End If

End Sub

为了相应鼠标动作,添加以下代码。

Private Sub MSFlexGrid1_MouseDown(Button As Integer, Shift As Integer, _

x As Single, y As Single)

Text1.Visible = False

End Sub

当网格单元发生变更时,取网格单元内容到文本框,等待编辑,从而包管文本框中的内容最新。

Private Sub MSFlexGrid1_RowColChange()

Text1.Text = MSFlexGrid1.Text

End Sub

双击网格单元可以对网格单元中内容进行编辑。

Private Sub MSFlexGrid1_DblClick()

If MSFlexGrid1.Row > 0 And MSFlexGrid1.Col = 0 Then MSFlexGrid1_KeyPress 13

End Sub

文本框起输入编辑框的感化,模拟网格单元,输入到文本框的内容,颠末处置惩罚送到网格中,当输入完后按回车键可以自动到下一列,若为着末一列,跳转到下一行的第一列等待输入。

Private Sub Text1_KeyPress(KeyAscii As Integer)

If KeyAscii = 13 Then

MSFlexGrid1.Text = Text1.Text

Text1.V澳门新葡新京是真的吗isible = False

MSFlexGrid1.SetFocus

If MSFlexGrid1.Col

以上法度榜样在VB6.0 (中文企业版)下运行经由过程,实现了对MSFlexGrid网格单元的输入编辑。当然还可以添加一些代码完成对一些击键的相应,如按Tab自动到下一列,按Ese键取消输入等,这都很轻易做到,在此不再论述。假如您应用VB6.0 (中文企业澳门新葡新京是真的吗版),还可以用MSHFlexGrid控件来完成编辑输入的功能。

您可能还会对下面的文章感兴趣: