Ответов (11)11
Resources Extract - еще один инструмент, который рекурсивно находит значки из множества DLL, очень удобный IMO.
Если вы работаете в Linux, вы можете извлекать значки из DLL Windows с помощью gExtractWinIcons . Он доступен в Ubuntu и Debian в gextractwinicons
пакете.
В этой статье блога есть снимок экрана и краткое объяснение .
Вы можете скачать бесплатную программу Resource Hacker и следовать инструкциям ниже:
- Откройте любой файл DLL, из которого вы хотите найти значки.
- Просматривайте папки, чтобы найти определенные значки.
- В строке меню выберите «действие», а затем «сохранить».
- Выберите место назначения для файла .ico.
Ссылка: http://techsultan.com/how-to-extract-icons-from-windows-7/
Мне нужно было извлечь значок # 238 из shell32.dll, и я не хотел загружать Visual Studio или Resourcehacker, поэтому я нашел пару сценариев PowerShell от Technet (спасибо Джону Гренфеллу и # https://social.technet.microsoft. com / Forums / windowsserver / en-US / 16444c7a-ad61-44a7-8c6f-b8d619381a27 / using-icons-in-powershell-scripts? forum = winserverpowershell ), который сделал нечто подобное и создал новый скрипт (ниже) в соответствии с моими потребностями .
Я ввел следующие параметры (путь к исходной DLL, имя целевого файла значка и индекс значка в файле DLL):
C: \ Windows \ System32 \ shell32.dll
C: \ Temp \ Restart.ico
238
Я обнаружил, что индекс значков, который мне нужен, был # 238 путем проб и ошибок, временно создав новый ярлык (щелкните правой кнопкой мыши на рабочем столе и выберите New -> Shortcut, введите calc и дважды нажмите Enter). Затем щелкните новый ярлык правой кнопкой мыши и выберите «Свойства», затем нажмите кнопку «Сменить значок» на вкладке «Ярлык». Вставьте путь C: \ Windows \ System32 \ shell32.dll и нажмите OK. Найдите значок, который хотите использовать, и определите его индекс. NB: Индекс №2 находится под №1, а не справа от него. Индекс значка № 5 находился в верхней части второго столбца на моем компьютере с Windows 7 x64.
Если у кого-то есть лучший метод, который работает аналогично, но получает значки более высокого качества, мне было бы интересно услышать об этом. Спасибо, Шон.
#Windows PowerShell Code###########################################################################
# http://gallery.technet.microsoft.com/scriptcenter/Icon-Exporter-e372fe70
#
# AUTHOR: John Grenfell
#
###########################################################################
<#
.SYNOPSIS
Exports an ico and bmp file from a given source to a given destination
.Description
You need to set the Source and Destination locations. First version of a script, I found other examples but all I wanted to do as grab and ico file from an exe but found getting a bmp useful. Others might find useful
No error checking I'm afraid so make sure your source and destination locations exist!
.EXAMPLE
.\Icon_Exporter.ps1
.Notes
Version HISTORY:
1.1 2012.03.8
#>
Param ( [parameter(Mandatory = $true)][string] $SourceEXEFilePath,
[parameter(Mandatory = $true)][string] $TargetIconFilePath
)
CLS
#"shell32.dll" 238
If ($SourceEXEFilePath.ToLower().Contains(".dll")) {
$IconIndexNo = Read-Host "Enter the icon index: "
$Icon = [System.IconExtractor]::Extract($SourceEXEFilePath, $IconIndexNo, $true)
} Else {
[void][Reflection.Assembly]::LoadWithPartialName("System.Drawing")
[void] [System.Reflection.Assembly]::LoadWithPartialName("System.Windows.Forms")
$image = [System.Drawing.Icon]::ExtractAssociatedIcon("$($SourceEXEFilePath)").ToBitmap()
$bitmap = new-object System.Drawing.Bitmap $image
$bitmap.SetResolution(72,72)
$icon = [System.Drawing.Icon]::FromHandle($bitmap.GetHicon())
}
$stream = [System.IO.File]::OpenWrite("$($TargetIconFilePath)")
$icon.save($stream)
$stream.close()
Write-Host "Icon file can be found at $TargetIconFilePath"
Также доступен этот ресурс, библиотека изображений Visual Studio, которая «может использоваться для создания приложений, визуально согласующихся с программным обеспечением Microsoft», предположительно при условии лицензирования, указанного внизу. https://www.microsoft.com/en-ca/download/details.aspx?id=35825
Вот обновленная версия решения выше. Я добавил недостающую сборку, которую закопал в ссылку. Новички этого не поймут. Этот образец будет работать без изменений.
<#
.SYNOPSIS
Exports an ico and bmp file from a given source to a given destination
.Description
You need to set the Source and Destination locations. First version of a script, I found other examples
but all I wanted to do as grab and ico file from an exe but found getting a bmp useful. Others might find useful
.EXAMPLE
This will run but will nag you for input
.\Icon_Exporter.ps1
.EXAMPLE
this will default to shell32.dll automatically for -SourceEXEFilePath
.\Icon_Exporter.ps1 -TargetIconFilePath 'C:\temp\Myicon.ico' -IconIndexNo 238
.EXAMPLE
This will give you a green tree icon (press F5 for windows to refresh Windows explorer)
.\Icon_Exporter.ps1 -SourceEXEFilePath 'C:/Windows/system32/shell32.dll' -TargetIconFilePath 'C:\temp\Myicon.ico' -IconIndexNo 41
.Notes
Based on https://answacode.com/questions/8435/how-do-you-get-the-icons-out-of-shell32-dll Version 1.1 2012.03.8
New version: Version 1.2 2015.11.20 (Added missing custom assembly and some error checking for novices)
#>
Param (
[parameter(Mandatory = $true)]
[string] $SourceEXEFilePath = 'C:/Windows/system32/shell32.dll',
[parameter(Mandatory = $true)]
[string] $TargetIconFilePath,
[parameter(Mandatory = $False)]
[Int32]$IconIndexNo = 0
)
#https://social.technet.microsoft.com/Forums/windowsserver/en-US/16444c7a-ad61-44a7-8c6f-b8d619381a27/using-icons-in-powershell-scripts?forum=winserverpowershell
$code = @"
using System;
using System.Drawing;
using System.Runtime.InteropServices;
namespace System
{
public class IconExtractor
{
public static Icon Extract(string file, int number, bool largeIcon)
{
IntPtr large;
IntPtr small;
ExtractIconEx(file, number, out large, out small, 1);
try
{
return Icon.FromHandle(largeIcon ? large : small);
}
catch
{
return null;
}
}
[DllImport("Shell32.dll", EntryPoint = "ExtractIconExW", CharSet = CharSet.Unicode, ExactSpelling = true, CallingConvention = CallingConvention.StdCall)]
private static extern int ExtractIconEx(string sFile, int iIndex, out IntPtr piLargeVersion, out IntPtr piSmallVersion, int amountIcons);
}
}
"@
If (-not (Test-path -Path $SourceEXEFilePath -ErrorAction SilentlyContinue ) ) {
Throw "Source file [$SourceEXEFilePath] does not exist!"
}
[String]$TargetIconFilefolder = [System.IO.Path]::GetDirectoryName($TargetIconFilePath)
If (-not (Test-path -Path $TargetIconFilefolder -ErrorAction SilentlyContinue ) ) {
Throw "Target folder [$TargetIconFilefolder] does not exist!"
}
Try {
If ($SourceEXEFilePath.ToLower().Contains(".dll")) {
Add-Type -TypeDefinition $code -ReferencedAssemblies System.Drawing
$form = New-Object System.Windows.Forms.Form
$Icon = [System.IconExtractor]::Extract($SourceEXEFilePath, $IconIndexNo, $true)
} Else {
[void][Reflection.Assembly]::LoadWithPartialName("System.Drawing")
[void] [System.Reflection.Assembly]::LoadWithPartialName("System.Windows.Forms")
$image = [System.Drawing.Icon]::ExtractAssociatedIcon("$($SourceEXEFilePath)").ToBitmap()
$bitmap = new-object System.Drawing.Bitmap $image
$bitmap.SetResolution(72,72)
$icon = [System.Drawing.Icon]::FromHandle($bitmap.GetHicon())
}
} Catch {
Throw "Error extracting ICO file"
}
Try {
$stream = [System.IO.File]::OpenWrite("$($TargetIconFilePath)")
$icon.save($stream)
$stream.close()
} Catch {
Throw "Error saving ICO file [$TargetIconFilePath]"
}
Write-Host "Icon file can be found at [$TargetIconFilePath]"
На этот вопрос здесь уже есть ответы, но для тех, кто не знает, как это сделать, я использовал 7Zip и перешел к нему %SystemRoot%\system32\SHELL32.dll\.rsrc\ICON
, а затем скопировал все файлы в желаемое место.
Если вам нужен предварительно извлеченный каталог, вы можете скачать здесь ZIP-архив .
Примечание. Я извлек файлы при установке Windows 8.1, поэтому они могут отличаться от файлов в других версиях Windows.
Другой вариант - использовать такой инструмент, как ResourceHacker . Он также обрабатывает гораздо больше, чем просто значки. Ваше здоровье!