Atlanta Custom Software Development 

 
   Search        Code/Page
 

User Login
Email

Password

 

Forgot the Password?
Services
» Web Development
» Maintenance
» Data Integration/BI
» Information Management
Programming
  Database
Automation
OS/Networking
Graphics
Links
Tools
» Regular Expr Tester
» Free Tools

SetFolderIcon - Associate an icon to a folder
[ All Languages » VB »  Windows]

Total Hit ( 1847)

Rate this article:     Poor     Excellent 

 Submit Your Question/Comment about this article

Rating


 


Click here to copy the following block
Private Declare Function SetFileAttributes Lib "kernel32" Alias _
  "SetFileAttributesA" (ByVal lpFileName As String, ByVal dwFileAttributes As _
  Long) As Long

' Associate an icon to a folder, by creating a desktop.ini file into it.
' Within Explorer the specified icon will be displayed instead of the standard
' folder icon
' Parameters:
'  sFolderPath: path of the folder to associate the icon to
'  sIconFile: icon file to associate. This can be a .ico, .exe or .dll file
'  iIconIndex: index of the icon in case the specified file contains more than
' one icon (such as shell32.dll)
'
' Example:
'  SetFolderIcon "C:\NiceFolder", "C:\Documents\TestIcon.ico"

Sub SetFolderIcon(ByVal sFolderPath As String, ByVal sIconFile As String, _
  Optional ByVal iIconIndex As Long = 0)
  Dim sContent As String
  Dim sDesktopFile As String
  Dim bExists As Boolean
  Dim handle As Integer
  
  On Error Resume Next
  ' test whether both the folder and the icon file exist
  bExists = (GetAttr(sFolderPath) And vbDirectory) <> 0 And (GetAttr _
    (sIconFile) And vbDirectory) = 0
  If bExists = False Or Err.Number <> 0 Then Exit Sub
  
  ' build the file content
  sContent = "[.ShellClassInfo]" & vbCrLf & "IconIndex=" & iIconIndex & _
    vbCrLf & "IconFile=" & sIconFile
  
  'make the path for the desktop.ini file
  sDesktopFile = sFolderPath & IIf(Right$(sFolderPath, 1) = "\", "", _
    "\") & "desktop.ini"
  
  ' open the file and write the content
  handle = FreeFile
  Open sDesktopFile For Output As #handle
  Print #handle, sContent;
  Close #handle
  
  ' make the file hidden and the folder read only
  SetFileAttributes sDesktopFile, vbHidden
  SetFileAttributes sFolderPath, vbReadOnly
  
End Sub


Submitted By : Nayan Patel  (Member Since : 5/26/2004 12:23:06 PM)

Job Description : He is the moderator of this site and currently working as an independent consultant. He works with VB.net/ASP.net, SQL Server and other MS technologies. He is MCSD.net, MCDBA and MCSE. In his free time he likes to watch funny movies and doing oil painting.
View all (893) submissions by this author  (Birth Date : 7/14/1981 )


Home   |  Comment   |  Contact Us   |  Privacy Policy   |  Terms & Conditions   |  BlogsZappySys

© 2008 BinaryWorld LLC. All rights reserved.