如何以编程方式更改有效的Windows图标
本文关键字:有效 Windows 图标 方式更 编程 | 更新日期: 2023-09-27 18:06:58
我需要创建像10k不同的图标进行测试,可以在c#或powershell。我实际上有10k个不同名称的相同图标文件,我认为我可以很容易地读取二进制图标,转换为字节注入一些随机数并写回文件,但它并不像我看到的那样工作。
$fi = @(Get-ChildItem D:'icons -rec | ForEach-Object -Process {$_.FullName}) # | select -first $amount)
$no = 0
foreach($i in $fi)
{
$array = Read-FileByte $i;
$array = $array + [System.Text.Encoding]::UTF8.GetBytes($no)
[System.IO.File]::WriteAllBytes($i, $array)
$no++
}
在此代码之后,运行图标仍然被windows认为是相同的。
另一种方法是通过编程创建有效的10k图标,有办法做到这一点吗?由于
您可以使用此代码生成任意数量的随机图标:
using System;
using System.Linq;
using System.Drawing;
using System.IO;
static class Program
{
[STAThread]
static void Main()
{
var gen = new RandomIconGenerator(32);
var dir = new DirectoryInfo(@"C:'RandIcons'");
if (!dir.Exists) dir.Create();
for (int it = 0; it < 1000; it++)
using (var s = new FileStream(@"C:'RandIcons'" + "icon-" + it + ".ico", FileMode.Create))
gen.MakeRandomIcon().Save(s);
}
}
/// <summary>
/// Generates random icons using various colored shapes and lines, using available brushes and pens.
/// </summary>
public class RandomIconGenerator
{
Random r = new Random();
Pen[] pens = typeof(Pens).GetProperties().Select(p => (Pen)p.GetValue(null, null)).ToArray();
Brush[] brushes = typeof(Brushes).GetProperties().Select(p => (Brush)p.GetValue(null, null)).ToArray();
int size;
public RandomIconGenerator(int size) { this.size = size; }
public Icon MakeRandomIcon()
{
using (Bitmap bmp = new Bitmap(size, size))
using (Graphics g = Graphics.FromImage(bmp))
{
for (int it = 0; it < 20; it++) this.GetRandomPainter()(g);
g.Flush();
return Icon.FromHandle(bmp.GetHicon());
}
}
private Pen GetRandomPen() { return this.pens[this.r.Next(this.pens.Length)]; }
private Brush GetRandomBrush() { return this.brushes[this.r.Next(this.brushes.Length)]; }
private Action<Graphics> GetRandomPainter()
{
switch (r.Next(5))
{
case 0: return g => g.DrawLine(this.GetRandomPen(), this.GetRandomPoint(), this.GetRandomPoint());
case 1: return g => g.DrawRectangle(this.GetRandomPen(), this.GetRandomRect());
case 2: return g => g.DrawEllipse(this.GetRandomPen(), this.GetRandomRect());
case 3: return g => g.FillRectangle(this.GetRandomBrush(), this.GetRandomRect());
case 4: return g => g.FillEllipse(this.GetRandomBrush(), this.GetRandomRect());
default: throw new Exception();
}
}
private Rectangle GetRandomRect()
{
var p0 = this.GetRandomPoint();
return new Rectangle(p0, new Size(this.GetRandomPoint()) - new Size(p0));
}
private int GetRandomPos() { return this.r.Next(this.size); }
private Point GetRandomPoint() { return new Point(this.GetRandomPos(), this.GetRandomPos()); }
}
//fixed
[DllImport("user32.dll", SetLastError = true)] static extern bool DestroyIcon(IntPtr hIcon);
public Icon MakeRandomIcon()
{
using (Bitmap bmp = new Bitmap(size, size))
using (Graphics g = Graphics.FromImage(bmp))
{
for (int it = 0; it < 20; it++) this.GetRandomPainter()(g);
g.Dispose();
IntPtr hIcon = bmp.GetHicon();
Icon temp = Icon.FromHandle(hIcon);
Icon ico = (Icon)temp.Clone();
temp.Dispose();
DestroyIcon(hIcon);
return ico;
}
}
//thanks Miguel again.