王朝网络
分享
 
 
 

开发手记(九)——在文件菜单中记录最近使用过的文件(mi6236)

王朝other·作者佚名  2006-02-01
宽屏版  字体: |||超大  

开发手记(九)——在文件菜单中记录最近使用过的文件

-为保证文章完整性,谢绝对某篇而非全部手记的转载(mi6236)

Word的“文件”菜单最下面列出了最近使用过的文件名及路径,文件名及路径会随着用户的使用不断地发生变化,这符合统计学中“最近使用”最大可能是“经常使用”的原则,方便了用户,提高了效率。它的实现方法有很多,我举一例,供大家参考。

一、在工作目录下创建一个LastFile.ini文件,其中第一行为历史文件的总数,以下行是历史文件的全路径。当然您也可以使用数据表存储,那样编程时也许更方便一些。

LastFile.ini文件内容如:4

"D:\程序实例\slzj\slzj源代码\2004.11.18水利造价\示例.mdb"

"C:\WINDOWS\Desktop\111\111.mdb"

"D:\程序实例\slzj\slzj源代码\2004.11.18水利造价\示例.mdb"

"D:\程序实例\slzj\slzj源代码\2004.11.3\2004.11.3\2004.11.3\2004.11.3\示例(审查).mdb"

二、在Form_Load中编写如下代码,达到在文件菜单中显示历史文件的效果

'**************显示以往打开的文件记录***************************

'对配置文件不存在的情况下,作出操作。

If Dir(App.Path & "\lastfile.ini") = "" Then

Open App.Path & "\lastfile.ini" For Output As #1

Write #1, 0

Close #1

End If

'打开lastfile.ini文件

Open App.Path & "\lastfile.ini" For Input As #1

Dim strLastfile2 As String

'获取历史文件的数目

Line Input #1, strLastfile2

iMaxLastfile = Int(strLastfile2)

Dim i As Integer

'添加历史文件到ActiveBar菜单,先在ActiveBar中预设4各Command和一个分割线。并把他们的Visible=False

For i = 1 To iMaxLastfile

Line Input #1, strLastfile2

strLastfile(i - 1) = Mid(strLastfile2, 2, Len(strLastfile2) - 2)‘去引号

AABar.Bands("MenuFile").Tools.item(i + 10).Caption = strLastfile(i - 1)

AABar.Bands("MenuFile").Tools.item(i + 10).Visible = True

Next

'关闭文件

Close #1

'设置分隔条

If iMaxLastfile <> 0 Then

AABar.Bands("MenuFile").Tools.item(15).Visible = True

End If

三、在Form_Unload中添加如下代码,将打开文件记录写入配置文件。

Open App.Path & "\LastFile.ini" For Output As #1

Dim i As Integer

Write #1, iMaxLastfile‘写入历史文件总数

For i = 0 To iMaxLastfile - 1

Write #1, strLastfile(i)‘写入历史文件路径

Next

Close #1

四、在需要更新菜单中文件历史记录的地方使用下面函数(如:打开一个文件,新建并打开一个文件等)

Private Sub UpdateLastFile(ByVal strPath As String)

On Error GoTo SaveErr:

Dim strDuan As String

strDuan = strPath

'判断要添加的文件是否时列表中的第一个文件

If strDuan <> AABar.Bands("MenuFile").Tools.item(11).Caption Then

'将列表中的文件依次下移一位,空出第一位

Dim i As Integer

For i = 3 To 1 Step -1

strLastfile(i) = strLastfile(i - 1)

AABar.Bands("MenuFile").Tools.item(11 + i).Caption = AABar.Bands("MenuFile").Tools.item(10 + i).Caption

Next

'将头一位设置为当前操作的文件路径

strLastfile(0) = strDuan

AABar.Bands("MenuFile").Tools.item(11).Caption = strDuan

'如果列表文件数小于最大文件数则加一

If iMaxLastfile < 4 Then

iMaxLastfile = iMaxLastfile + 1

End If

'设置新移动的列表项可见

AABar.Bands("MenuFile").Tools.item(iMaxLastfile + 10).Visible = True

End If

'如果列表不为空则下方的分隔条可见

If iMaxLastfile <> 0 Then

AABar.Bands("MenuFile").Tools.item(15).Visible = True

Else

AABar.Bands("MenuFile").Tools.item(15).Visible = False

End If

Exit Sub

SaveErr:

dbEncrypt.SaveError "MDIForm1-UpdateLastFile"

End Sub

五、单击文件历史记录时调用如下函数。

Private Sub MenuLastfile(ByVal strName As String, Index As Integer)

On Error GoTo SaveErr:

'如果文件已不存在则提示

If Dir(strName) = "" Then

MsgBox "文件不存在,请确认后再次打开!", vbOKOnly + vbInformation, "打开文件"

Exit Sub

End If

'设置当前打开文件为列表中的选择文件

strConnection = strName

'**************重新设置历史文件列表顺序*****************

Dim i As Integer

For i = Index To 12 Step –1 '把列表中选择文件的位置之上的文件依次下移

strLastfile(i - 11) = strLastfile(i - 12)

AABar.Bands("MenuFile").Tools.item(i).Caption= AABar.Bands("MenuFile").Tools.item(i - 1).Caption

Next

strLastfile(0) = strName

'将选择的文件的放在列表中的首位

AABar.Bands("MenuFile").Tools.item(11).Caption = strConnection

CloseWnd‘自定义过程,用于关闭系统中打开的除MDI窗口外的所有窗口

strConnection = strName

Me.Caption = "水利造价管理系统" & "-" & strConnection

ShowMenu

Exit Sub

SaveErr:

dbEncrypt.SaveError "MDIForm1-MenuLastFile"

End Sub

Private Sub CloseWnd()

On Error GoTo SaveErr:

Dim i As Integer

For i = Forms.count - 1 To 1 Step -1

If Forms(i).Name <> "FrmDaoHang1" And Forms(i).Name <> "FrmDaoHang2" And Forms(i).Name <> "FrmToolSearch" Then

Unload Forms(i) '关闭到倒数第二个窗体

End If

Next

Exit Sub

SaveErr:

dbEncrypt.SaveError "MDIForm1-CloseWnd"

End Sub

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
>>返回首页<<
推荐阅读
 
 
频道精选
 
静静地坐在废墟上,四周的荒凉一望无际,忽然觉得,凄凉也很美
© 2005- 王朝网络 版权所有