有历史记录功能的菜单

有历史记录功能的菜单
董文涛
  
- 我们经常见到一些软件,如office系列,visual家族等等,他们的打开菜单里常常记载了上次所进行的任务,这样就方便了我们的操作,实际我们也能用vb实现这一功能,现在以常见的含有最多五个添加值为例给大家演示这一功能,并且此程序不需要具api 函数调用,直接使用vb自身携带的函数即可,主要使用getsetting,savesetting和 deletesetting函数,具体步骤如下:

---- 1.打开vb,选择标准窗口,在工具菜单里选择编辑菜单器,各项设置如下:

————————————————————————
caption          name       index
  visible   indentation
———————————————————————
file         mnufile        空       true    0
Open            mnuopen       空       true    1
-         mnudesh        空       true       1
空       mnufilename       1       false      1
空       mnufilename 2 false    1
空       mnufilename 3 false    1
空       mnufilename 4 false    1
空       mnufilename 5 false    1
abc       mnufilename 6 false    1

---- (注:一定要在最后一项的caption设一虚值,这样做的原因是为了后面在菜单项未满时添加文件名做判断,并没有实际意义)
---- 2.在窗体中加载一对话框,对话框的name为commongdialog1

---- 3.源程序如下:

---- 在通用里声明:

Const k1 = "记忆菜单"
Const k2 = "文件名"
Function addfilename(filename)注释:添加文件名
DIM I,G AS INTEGER
For I = 5 To 1 Step -1注释:从第五项开始向第一项
If mnufilename(1).Caption <  > filename And
mnufilename(2).Caption <  > filename
And mnufilename(3).Caption <  > filename And
mnufilename(4).Caption <  > filename
And mnufilename(5).Caption <  > filename
Then 注释:判断所选的文件是否已存在
     If mnufilename(I).Caption = "" And
mnufilename(I + 1).Caption <  > ""
Then 注释:此处初使化菜单,利用了虚设菜单项
SaveSetting k1, k2, I, filename注释:在注册表里保存
     Else
       If mnufilename(1).Caption <  > ""
Then 注释:表明菜单已满
         DeleteSetting k1, k2, 5
注释:按先入先出规则,删除最后一项
         For G = 4 To 1 Step -1 注释:一至四项依次后移
         n = GetSetting(k1, k2, G)注释:从注册表里取其值
         SaveSetting k1, k2, (G + 1), n注释:顺延到下一项
         Next
         SaveSetting k1, k2, 1, filename
        Exit Function
       End If
     End If
End If
Next
End Function
Function display()注释:显现各项文件名
DIM I AS INTEGER
For I = 5 To 1 Step -1
l = GetSetting(k1, k2, I)

If l <  > "" Then
mnufilename(I).Visible = True
mnufilename(I).Caption = l
Else
mnufilename(I).Visible = False
mnufilename(I).Caption = ""
End If
Next
End Function

Private Sub Form_Load()

Call display

End Sub

Private Sub mnuopen_Click()
DIM FILENAME
Commondialog1.ShowOpen
filename = Commondialog1.filename

Call addfilename(filename)

Call display

End Sub

---- 有兴趣的读者还可以把此程序稍加修改加入你的工程,增添你的工程的实用性。利用getsetting,savesetting和deletesetting函数,还可为你的程序加密等  
posted @ 2007-01-12 15:04  TangHuawei  阅读(355)  评论(0编辑  收藏  举报