VB6.0利用微软网格控件进行编辑输入.doc_第1页
VB6.0利用微软网格控件进行编辑输入.doc_第2页
VB6.0利用微软网格控件进行编辑输入.doc_第3页
VB6.0利用微软网格控件进行编辑输入.doc_第4页
免费预览已结束,剩余1页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

用微软网格控件进行编辑输入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上添加控件 Text1和MSFlexGrid1,根据表1设置其属性。表1 表单Form1的对象和属性对象属性设置Text1VisibleFalseText“”MSFlexGrid1Rows2Cols根据字段数目自行设置FixedCols0FixedRows1首先要实现文本框显示的时候,能与网格单元准确重合。ShowTextBox子例程便可以实现此功能。在此考虑网格本身的Top和Left值、网格单元的高度和宽度、分隔网格单元的边框的宽度。Sub ShowTextBox()With MSFlexGrid1隐藏文本框,设置高度和宽度Text1.Visible = FalseText1.Height = .RowHeight(.Row) - (Screen.TwipsPerPixelY) * 2Text1.Width = .ColWidth(.Col) 计算文本框左坐标Text1.Left = .CellLeft + .LeftText1.Top = .CellTop + .TopText1.Visible = TrueText1.SetFocusEnd WithEnd Sub当有按键触发网格单元时,则把单元中的内容保存到文本框中,然后显示文本框等待编辑。Private Sub MSFlexGrid1_KeyPress(KeyAscii As Integer)Dim char As StringIf KeyAscii = 13 ThenText1.Text = MSFlexGrid1.TextText1.SelStart = Len(Text1.Text)Elsechar = Chr$(KeyAscii)Text1.Text = charText1.SelStart = 1End IfShowTextBoxKeyAscii = 0End Sub当焦点离开一个网格单元时,先保存文本框中的内容到网格单元,然后检测离开单元是否在最大行第一列(可自己设第几列),如果是自动加一行。Private Sub MSFlexGrid1_LeaveCell()MSFlexGrid1.Text = Text1.TextIf MSFlexGrid1.Col = 0 And MSFlexGrid1.Row 0 And _MSFlexGrid1.Row = MSFlexGrid1.Rows - 1 And MSFlexGrid1.Text ThenMSFlexGrid1.Rows = MSFlexGrid1.Rows + 1End IfEnd Sub为了响应鼠标动作,添加以下代码。Private Sub MSFlexGrid1_MouseDown(Button As Integer, Shift As Integer, _x As Single, y As Single)Text1.Visible = FalseEnd Sub当网格单元发生变化时,取网格单元内容到文本框,等待编辑,从而保证文本框中的内容最新。Private Sub MSFlexGrid1_RowColChange()Text1.Text = MSFlexGrid1.TextEnd Sub双击网格单元可以对网格单元中内容进行编辑。Private Sub MSFlexGrid1_DblClick()If MSFlexGrid1.Row 0 And MSFlexGrid1.Col = 0 Then MSFlexGrid1_KeyPress 13End Sub文本框起输入编辑框的作用,模拟网格单元,输入到文本框的内容,经过处理送到网格中,当输入完后按回车键可以自动到下一列,若为最后一列,跳转到下一行的第一列等待输入。Private Sub Text1_KeyPress(KeyAscii As Integer)If KeyAscii = 13 ThenMSFlexGrid1.Text = Text1.TextText1.Visible = FalseMSFlexGrid1.SetFocusIf MSFlexGrid1.Col (MSFlexGrid1.Cols - 1) ThenMSFlexGrid1.Col = MSFlexGrid1.Col + 1ElseIf MSFlexGrid1.Row MSFlexGrid1.Rows - 1 ThenMSFlexGrid1.Row = MSFlexGrid1.Row + 1MSFlexGrid1.Col = 0End IfKeyAscii = 0End IfEnd Sub以上程序在VB6.0 (中文企业版

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论