编程思路:按一定格式在文件夹中建立Desktop.ini文件并将文件夹的属性设置为系统属性即可自定义文件夹的图标。文件的建立不难,关键是更改文件夹属性,得用上VB的内部函数Attributes来实现。
Desktop.ini文件格式:
[.ShellClassInfo]
IconIndex=0
iconfile=Icon图标所在的驱动器我 路径名 文件名
下面是完整的程序代码。使用前请给工程添加一个按钮、一个公共对话框、一个DriveListBox和一个DirListBox。
OptionExplicit
DimsPathAsString'文件夹变量
PrivateSubDir1_Click()
DimiAsInteger
Command1.Enabled=True
i=Dir1.ListIndex
sPath=Dir1.List(i)
EndSub
PrivateSubDrive1_Change()
Dir1.Path=Drive1.Drive
EndSub
PrivateSubForm_Load()
Command1.Caption="定义文件夹图标"
Command1.Enabled=False
EndSub
PrivateSubCommand1_Click()
ChangeFolderInfosPath'更改目录为系统文件
DimsAsString'图标文件路径、名称变量
WithCommonDialog1
.Filter="(*.ico)|*.ico"
.DialogTitle="查找图标"
.ShowOpen
s=.FileName
EndWith
OpensPath "\" "desktop.ini"ForOutputAs#1
Print#1,"[.ShellClassInfo]" vbCrLf "IconIndex=0" vbCrLf "iconfile=" s
Close#1
ChangeFileInfo(sPath "\" "desktop.ini")
EndSub
'赋予文件夹系统属性子程序
PrivateSubChangeFolderInfo(folderspec)
Dimfs,f
Setfs=CreateObject("Scripting.FileSystemObject")
Setf=fs.GetFolder(folderspec)
f.Attributes=4'用Attributes函数设置文件夹属性
EndSub
'赋予Desktop.ini文件隐藏属性
PrivateSubChangeFileInfo(filespec)
Dimfs,f
Setfs=CreateObject("Scripting.FileSystemObject")
Setf=fs.GetFile(filespec)
f.Attributes=2'用Attributes属性设置文件属性
EndSub
运行程序,打开"我的电脑"找到更改了图标的文件夹看看,效果如何?->