image-manipulation-image-magick
github/awesome-copilot
Process and manipulate images using ImageMagick with resizing, format conversion, and batch operations.
What is image-manipulation-image-magick?
This skill enables image processing tasks using ImageMagick across Windows, Linux, and macOS. Use it when you need to resize images, convert formats, create thumbnails, retrieve metadata, or batch process multiple images with specific criteria.
- Get image dimensions and detailed metadata
- Resize single or batch images while maintaining aspect ratios
- Convert between image formats
- Create thumbnails with specific dimensions
- Process images based on dimension criteria
- Filter and apply transformations to multiple files
How to install image-manipulation-image-magick
npx skills add https://github.com/github/awesome-copilot --skill image-manipulation-image-magick- ImageMagick installed on system and available as `magick` on PATH
- Windows: PowerShell with ImageMagick (or at C:\Program Files\ImageMagick-*\magick.exe)
- Linux/macOS: Bash with ImageMagick installed via package manager (apt, brew, etc.)
How to use image-manipulation-image-magick
- 1.Verify ImageMagick is installed and accessible via `magick` command
- 2.Store the magick executable path in a variable for cleaner code
- 3.Use `magick identify -format` to retrieve image dimensions and metadata
- 4.Apply resize operations with `magick input.jpg -resize WIDTHxHEIGHT output.jpg`
- 5.Wrap operations in loops (ForEach-Object for PowerShell, for loops for Bash) for batch processing
- 6.Quote all file paths to handle spaces and special characters correctly
Use cases
- Resizing wallpapers for different screen sizes
- Creating thumbnail galleries from image collections
- Batch converting images between formats
- Processing images larger than 1920x1080 to standard sizes
- Retrieving metadata for image organization workflows
- Image processing automation tasks
- Batch image workflow management
- Thumbnail generation pipelines
- Cross-platform image manipulation scripts
image-manipulation-image-magick FAQ
Windows (PowerShell), Linux (Bash), and macOS (Bash). Platform-specific examples are provided for each.
Yes, ImageMagick must be installed on your system and available as `magick` on PATH. On Windows, it's typically found at C:\Program Files\ImageMagick-*\magick.exe; on Linux/macOS, install via apt or brew.
Yes, the skill supports batch processing using loops. You can iterate over multiple files and apply transformations to each, with optional filtering based on dimensions or file type.
You can use standard resize syntax (WIDTHxHEIGHT), force exact dimensions with `!`, or specify minimum dimensions with `^`. Aspect ratios are maintained by default unless overridden.
Large batch operations may be memory-intensive depending on image size and quantity. Process in smaller batches if needed, and ensure sufficient system resources are available.
Full instructions (SKILL.md)
Source of truth, from github/awesome-copilot.
name: image-manipulation-image-magick
description: Process and manipulate images using ImageMagick. Supports resizing, format conversion, batch processing, and retrieving image metadata. Use when working with images, creating thumbnails, resizing wallpapers, or performing batch image operations.
compatibility: Requires ImageMagick installed and available as magick on PATH. Cross-platform examples provided for PowerShell (Windows) and Bash (Linux/macOS).
Image Manipulation with ImageMagick
This skill enables image processing and manipulation tasks using ImageMagick across Windows, Linux, and macOS systems.
When to Use This Skill
Use this skill when you need to:
- Resize images (single or batch)
- Get image dimensions and metadata
- Convert between image formats
- Create thumbnails
- Process wallpapers for different screen sizes
- Batch process multiple images with specific criteria
Prerequisites
- ImageMagick installed on the system
- Windows: PowerShell with ImageMagick available as
magick(or atC:\Program Files\ImageMagick-*\magick.exe) - Linux/macOS: Bash with ImageMagick installed via package manager (
apt,brew, etc.)
Core Capabilities
1. Image Information
- Get image dimensions (width x height)
- Retrieve detailed metadata (format, color space, etc.)
- Identify image format
2. Image Resizing
- Resize single images
- Batch resize multiple images
- Create thumbnails with specific dimensions
- Maintain aspect ratios
3. Batch Processing
- Process images based on dimensions
- Filter and process specific file types
- Apply transformations to multiple files
Usage Examples
Example 0: Resolve magick executable
PowerShell (Windows):
# Prefer ImageMagick on PATH
$magick = (Get-Command magick -ErrorAction SilentlyContinue)?.Source
# Fallback: common install pattern under Program Files
if (-not $magick) {
$magick = Get-ChildItem "C:\\Program Files\\ImageMagick-*\\magick.exe" -ErrorAction SilentlyContinue |
Select-Object -First 1 -ExpandProperty FullName
}
if (-not $magick) {
throw "ImageMagick not found. Install it and/or add 'magick' to PATH."
}
Bash (Linux/macOS):
# Check if magick is available on PATH
if ! command -v magick &> /dev/null; then
echo "ImageMagick not found. Install it using your package manager:"
echo " Ubuntu/Debian: sudo apt install imagemagick"
echo " macOS: brew install imagemagick"
exit 1
fi
Example 1: Get Image Dimensions
PowerShell (Windows):
# For a single image
& $magick identify -format "%wx%h" path/to/image.jpg
# For multiple images
Get-ChildItem "path/to/images/*" | ForEach-Object {
$dimensions = & $magick identify -format "%f: %wx%h`n" $_.FullName
Write-Host $dimensions
}
Bash (Linux/macOS):
# For a single image
magick identify -format "%wx%h" path/to/image.jpg
# For multiple images
for img in path/to/images/*; do
magick identify -format "%f: %wx%h\n" "$img"
done
Example 2: Resize Images
PowerShell (Windows):
# Resize a single image
& $magick input.jpg -resize 427x240 output.jpg
# Batch resize images
Get-ChildItem "path/to/images/*" | ForEach-Object {
& $magick $_.FullName -resize 427x240 "path/to/output/thumb_$($_.Name)"
}
Bash (Linux/macOS):
# Resize a single image
magick input.jpg -resize 427x240 output.jpg
# Batch resize images
for img in path/to/images/*; do
filename=$(basename "$img")
magick "$img" -resize 427x240 "path/to/output/thumb_$filename"
done
Example 3: Get Detailed Image Information
PowerShell (Windows):
# Get verbose information about an image
& $magick identify -verbose path/to/image.jpg
Bash (Linux/macOS):
# Get verbose information about an image
magick identify -verbose path/to/image.jpg
Example 4: Process Images Based on Dimensions
PowerShell (Windows):
Get-ChildItem "path/to/images/*" | ForEach-Object {
$dimensions = & $magick identify -format "%w,%h" $_.FullName
if ($dimensions) {
$width,$height = $dimensions -split ','
if ([int]$width -eq 2560 -or [int]$height -eq 1440) {
Write-Host "Processing $($_.Name)"
& $magick $_.FullName -resize 427x240 "path/to/output/thumb_$($_.Name)"
}
}
}
Bash (Linux/macOS):
for img in path/to/images/*; do
dimensions=$(magick identify -format "%w,%h" "$img")
if [[ -n "$dimensions" ]]; then
width=$(echo "$dimensions" | cut -d',' -f1)
height=$(echo "$dimensions" | cut -d',' -f2)
if [[ "$width" -eq 2560 || "$height" -eq 1440 ]]; then
filename=$(basename "$img")
echo "Processing $filename"
magick "$img" -resize 427x240 "path/to/output/thumb_$filename"
fi
fi
done
Guidelines
- Always quote file paths - Use quotes around file paths that might contain spaces
- Use the
&operator (PowerShell) - Invoke the magick executable using&in PowerShell - Store the path in a variable (PowerShell) - Assign the ImageMagick path to
$magickfor cleaner code - Wrap in loops - When processing multiple files, use
ForEach-Object(PowerShell) orforloops (Bash) - Verify dimensions first - Check image dimensions before processing to avoid unnecessary operations
- Use appropriate resize flags - Consider using
!to force exact dimensions or^for minimum dimensions
Common Patterns
PowerShell Patterns
Pattern: Store ImageMagick Path
$magick = (Get-Command magick).Source
Pattern: Get Dimensions as Variables
$dimensions = & $magick identify -format "%w,%h" $_.FullName
$width,$height = $dimensions -split ','
Pattern: Conditional Processing
if ([int]$width -gt 1920) {
& $magick $_.FullName -resize 1920x1080 $outputPath
}
Pattern: Create Thumbnails
& $magick $_.FullName -resize 427x240 "thumbnails/thumb_$($_.Name)"
Bash Patterns
Pattern: Check ImageMagick Installation
command -v magick &> /dev/null || { echo "ImageMagick required"; exit 1; }
Pattern: Get Dimensions as Variables
dimensions=$(magick identify -format "%w,%h" "$img")
width=$(echo "$dimensions" | cut -d',' -f1)
height=$(echo "$dimensions" | cut -d',' -f2)
Pattern: Conditional Processing
if [[ "$width" -gt 1920 ]]; then
magick "$img" -resize 1920x1080 "$outputPath"
fi
Pattern: Create Thumbnails
filename=$(basename "$img")
magick "$img" -resize 427x240 "thumbnails/thumb_$filename"
Limitations
- Large batch operations may be memory-intensive
- Some complex operations may require additional ImageMagick delegates
- On older Linux systems, use
convertinstead ofmagick(ImageMagick 6.x vs 7.x)
Related skills
More from github/awesome-copilot and the wider catalog.
git-commit
Execute semantic git commits with conventional message analysis and intelligent staging.
excalidraw-diagram-generator
Generate Excalidraw diagrams from natural language descriptions.
documentation-writer
Create structured technical documentation using the Diátaxis framework for tutorials, how-to guides, references, and explanations.
gh-cli
GitHub CLI comprehensive reference for repositories, issues, PRs, Actions, projects, releases, and all GitHub operations from the command line.
prd
Generate comprehensive Product Requirements Documents with executive summaries, user stories, technical specs, and risk analysis.
refactor
Surgical code refactoring to improve maintainability without changing behavior.