windows-icons

Crates.iowindows-icons
lib.rswindows-icons
version
sourcesrc
created_at2024-09-07 00:18:12.361798+00
updated_at2025-03-11 04:07:43.312733+00
descriptionA simple library to extract icons from files on Windows
homepage
repository
max_upload_size
id1366807
Cargo.toml error:TOML parse error at line 21, column 1 | 21 | autolib = false | ^^^^^^^ unknown field `autolib`, expected one of `name`, `version`, `edition`, `authors`, `description`, `readme`, `license`, `repository`, `homepage`, `documentation`, `build`, `resolver`, `links`, `default-run`, `default_dash_run`, `rust-version`, `rust_dash_version`, `rust_version`, `license-file`, `license_dash_file`, `license_file`, `licenseFile`, `license_capital_file`, `forced-target`, `forced_dash_target`, `autobins`, `autotests`, `autoexamples`, `autobenches`, `publish`, `metadata`, `keywords`, `categories`, `exclude`, `include`
size0
Zach Connelly (zmconnelly)

documentation

README

Windows Icons

A simple Rust library to extract icons from files and running processes on Windows platforms.

Features

  • Retrieve icons by file path or process id
  • Save as a PNG or base64 encoded string

Installation

Add to your Cargo.toml:

[dependencies]
windows-icons = "0.2.1"

Usage

// Get icon as an image from a file path
let icon = get_icon_image_by_path("C:\\Windows\\System32\\notepad.exe").unwrap();
icon.save("notepad.png").unwrap();

// Get icon as a base64 string from a file path
let base64 = get_icon_base64_by_path("C:\\Windows\\System32\\calc.exe").unwrap();
println!("Calculator icon: {}", base64);

// Get icon as an image from dll
let folder = DllIcon::new().with_shell32(5);
let icon = get_icon_by_dll(folder).unwrap();
icon.save("output/folder.png").unwrap();

// Get icon as a base64 string frome dll
let explorer = DllIcon::new().with_explorer(1);
let base64 = get_icon_base64_by_dll(explorer).unwrap();
println!("Explorer: {}", base64);

// Get icon as an image from a process ID
let process_id = 1234;

let icon = get_icon_image_by_process_id(process_id).unwrap();
icon.save("process.png").unwrap();

// Get icon as a base64 encoded string from a process ID
let base64 = get_icon_base64_by_process_id(process_id).unwrap();
println!("Process {} icon: {}", process_id, base64);

For more examples, check the examples.

Cargo run --example icon

Cargo run --example process

Cargo run --example dll

Requirements

This library is designed to work on Windows systems only.

License

This project is licensed under the MIT License - see the LICENSE for details.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

Acknowledgements

This library uses the following crates:

  • image for image processing
  • base64 for base64 encoding
  • glob for matching file paths
  • windows for Windows API interactions

Disclaimer

This library uses unsafe Rust code to interact with the Windows API. While efforts have been made to ensure safety, use it at your own risk.

Commit count: 0

cargo fmt