Private Sub Command1_Click() MsgBox Data1.Database.Recordsets.Count End Sub
Private Sub Form_Load() '初始化数据 click = False lastrow = 1 lastcol = 1
'初始化data控件,进行绑定显示的初始化 Data1.DatabaseName = App.Path & "\db1.mdb" Data1.RecordSource = "成绩表"
'进行非绑定显示 Data1.Refresh Data1.Recordset.MoveFirst MSFlexGrid2.Rows = Data1.Database.Recordsets.Count + 1 '设置总行数 MSFlexGrid2.Cols = Data1.Recordset.Fields.Count + 1 '设置总列数 MSFlexGrid2.GridColor = vbBlue '网格颜色 MSFlexGrid2.ForeColor = vbRed '字体颜色 MSFlexGrid2.GridLines = 1 '设置网格线的属性 MSFlexGrid2.GridLineWidth = 2 '设置网格线的粗细程序,默认为1 MSFlexGrid2.ToolTipText = "非绑定显示" '设置工具提示文本 MSFlexGrid2.BackColorSel = vbGreen '单元格被选中的颜色 Dim i% Dim j% '设置列头文本 For i = 1 To MSFlexGrid2.Cols - 1 MSFlexGrid2.TextMatrix(0, i) = Data1.Recordset.Fields(i - 1).Name Next i '设置数据 For i = 1 To MSFlexGrid2.Rows - 1 '控制行
For j = 1 To MSFlexGrid2.Cols - 1 '控制列 MSFlexGrid2.TextMatrix(i, j) = Data1.Recordset.Fields(j - 1).Value Next j Data1.Recordset.MoveNext Next i '设置当前单元格的图象信息 MSFlexGrid2.Col = 0 MSFlexGrid2.Row = 2 Set MSFlexGrid2.CellPicture = LoadPicture(App.Path & "\cell.bmp") End Sub '实现鼠标点击一个单元格的背景颜色的改变功能 Private Sub MSFlexGrid2_Click() MSFlexGrid2.Row = lastrow MSFlexGrid2.Col = lastcol MSFlexGrid2.CellBackColor = vbWhite MSFlexGrid2.Row = MSFlexGrid2.MouseRow MSFlexGrid2.Col = MSFlexGrid2.MouseCol MSFlexGrid2.CellBackColor = vbCyan lastrow = MSFlexGrid2.Row lastcol = MSFlexGrid2.Col End Sub
要在不绑定数据的情况下实现编辑修改的功能,如果对控件不进行改进是无法达到目的的。这里实现的思路是首先判断光标(或者说焦点)在哪个单元格上,然后在在单元格的范围内动态创建一个文本框(不过在vb平台下,可以考虑先在设计时放置一个不可见的文本框,然后通过move方法将其放置到当前单元格并且显示它即可达到相同的目的),其大小正好可以把此单元格给覆盖掉,然后就可以把原来的文本信息附给该文本框,这样就可以直接在文本框内进行编辑修改操作,从而实现了单元格的编辑修改功能,依据这个思想来可以在单元格里面创建下拉列表框,复选框等控件。其实现的核心代码如下:
'实现编辑功能 Private Sub MSFlexGrid3_DblClick() Text1.Visible = False '如果初次双击,那么就执行如下代码 If firstclick = True Then lastclickrow = MSFlexGrid3.Row lastclickcol = MSFlexGrid3.Col Text1.Text = MSFlexGrid3.TextMatrix(lastclickrow, lastclickcol) End If '将文本框放置到当前单元格处 Dim LeftOfText% '文本框的left属性 Dim TopOfText% '文本框的top属性 Dim selrow% '当前行 Dim selcol% '当前列 selrow = MSFlexGrid3.Row selcol = MSFlexGrid3.Col LeftOfText = Frame3.Left + MSFlexGrid3.Left + MSFlexGrid3.ColPos(selcol) + 45 TopOfText = Frame3.Top + MSFlexGrid3.Top + MSFlexGrid3.RowPos(selrow) + 45
上一篇:ADO三大对象的属性、方法、事件及常数
下一篇:ActiveX控件的创建
|