moosicbox_image 0.2.0

MoosicBox image package
Documentation
# MoosicBox Image Helper

Image processing library and command-line tool for resizing, converting, and optimizing images with support for multiple formats.

## Overview

MoosicBox Image provides both a library API and CLI tool (`image_helper`) for image processing operations including:

- **Image Resizing**: Resize images while maintaining aspect ratio
- **Format Conversion**: Convert between JPEG and WebP formats
- **Quality Control**: Configurable compression quality settings
- **Smart Resizing**: Automatic aspect ratio calculation
- **libvips Integration**: High-performance image processing (Linux/macOS only; Rust bindings unavailable on Windows)

## Installation

### As a Library Dependency

Add to your `Cargo.toml`:

```toml
[dependencies]
moosicbox_image = "0.1.4"

# Or with specific features:
moosicbox_image = { version = "0.1.4", features = ["image", "libvips"] }
```

Available features:

- `image` - Pure Rust image processing (default, cross-platform)
- `libvips` - High-performance libvips backend (default, Linux/macOS only)
- `build-binary` - Build the `image_helper` CLI tool

### From Source

```bash
# Linux/macOS (with libvips support)
cargo install --path packages/image --features "build-binary,image,libvips"

# Windows (libvips Rust crate has build issues)
cargo install --path packages/image --features "build-binary,image"
```

### Dependencies

System dependencies for optimal performance:

- **libvips** (recommended, for high-performance processing)
    - Ubuntu/Debian: `sudo apt-get install libvips-dev`
    - macOS: `brew install vips`
    - Windows: See [libvips Windows installation]https://www.libvips.org/install.html

## Library Usage

The package provides both a library API and a CLI tool.

### Using the Image Module

The `image` module provides pure Rust image processing:

```rust
use moosicbox_image::{Encoding, image::{try_resize_local_file, try_resize_local_file_async}};

// Sync resize
let bytes = try_resize_local_file(
    800,  // width
    600,  // height
    "input.jpg",
    Encoding::Jpeg,
    85    // quality
)?;

// Async resize
let bytes = try_resize_local_file_async(
    800,  // width
    600,  // height
    "input.jpg",
    Encoding::Jpeg,
    85    // quality
).await?;
```

### Using the libvips Module

The `libvips` module provides high-performance processing (Linux/macOS only):

```rust
use moosicbox_image::libvips::{get_error, resize_local_file, resize_bytes};

// Resize from file path
let bytes = resize_local_file(800, 600, "input.jpg")?;

// Resize from bytes
let resized = resize_bytes(800, 600, &image_bytes)?;

// Read and clear the backend error buffer after failures
let last_error = get_error();
```

### Encoding Types

```rust
use moosicbox_image::Encoding;

let encoding = Encoding::Jpeg;  // or Encoding::Webp
```

## CLI Usage

### Basic Usage

Resize an image to specific dimensions:

```bash
image_helper input.jpg --output output.jpg --width 800 --height 600
```

### Maintain Aspect Ratio

Resize by width only (height calculated automatically):

```bash
image_helper input.png --output output.png --width 1024
```

Resize by height only (width calculated automatically):

```bash
image_helper large.jpg --output thumbnail.jpg --height 200
```

### Format Conversion

Convert between formats:

```bash
image_helper photo.png --output photo.jpg --encoding JPEG --quality 85
```

### Quality Control

Set compression quality (0-100):

```bash
image_helper input.jpg --output output.jpg --width 800 --quality 95
```

### Complete Example

```bash
image_helper \
  /path/to/input.png \
  --output /path/to/output.webp \
  --width 1200 \
  --height 800 \
  --encoding WEBP \
  --quality 90
```

## Command Line Options

| Option       | Short | Description                 | Default                    |
| ------------ | ----- | --------------------------- | -------------------------- |
| `--width`    | `-w`  | Target width in pixels      | Auto-calculated            |
| `--height`   | `-h`  | Target height in pixels     | Auto-calculated            |
| `--encoding` | `-e`  | Output format (JPEG, WEBP)  | Auto-detect from extension |
| `--output`   | `-o`  | Output file path            | Required                   |
| `--quality`  | `-q`  | Compression quality (0-100) | 80                         |

## Supported Formats

### Input Formats

The tool supports various input formats through the `image` crate, including:

- **JPEG** (.jpg, .jpeg)
- **PNG** (.png)
- **WebP** (.webp)
- **TIFF** (.tiff, .tif)
- **BMP** (.bmp)
- **GIF** (.gif) - static images only
- **ICO** (.ico)

### Output Formats

- **JPEG** (.jpg, .jpeg) - Good compression, lossy
- **WebP** (.webp) - Modern format, excellent compression

## Aspect Ratio Handling

The tool intelligently handles aspect ratios:

### Both Dimensions Specified

```bash
# Resize to exact dimensions (may distort image)
image_helper input.jpg --output output.jpg --width 800 --height 600
```

### Width Only

```bash
# Height calculated to maintain aspect ratio
image_helper input.jpg --output output.jpg --width 800
```

### Height Only

```bash
# Width calculated to maintain aspect ratio
image_helper input.jpg --output output.jpg --height 600
```

### Neither Dimension

```bash
# Original dimensions preserved, format/quality change only
image_helper input.png --output output.jpg --encoding JPEG --quality 85
```

## Quality Guidelines

### JPEG Quality Settings

- **60-70**: Good for web thumbnails, small file size
- **75-85**: Good balance of quality and file size
- **85-95**: High quality for photos
- **95-100**: Maximum quality, larger files

### WebP Quality Settings

- **50-70**: Excellent compression for web use
- **70-85**: High quality with good compression
- **85-100**: Maximum quality

## Examples

### Create web thumbnails

```bash
# Create small thumbnail
image_helper photo.jpg --output thumb.jpg --width 150 --quality 75

# Create medium preview
image_helper photo.jpg --output preview.jpg --width 400 --quality 80
```

### Convert to modern formats

```bash
# Convert PNG to WebP for better compression
image_helper large.png --output optimized.webp --quality 85

# Convert old JPEG to high-quality WebP
image_helper old-photo.jpg --output new-photo.webp --quality 90
```

### Batch processing script

```bash
#!/bin/bash
# The CLI processes one image at a time, but can be used in scripts
mkdir -p thumbnails
for img in *.jpg; do
  image_helper "$img" --output "thumbnails/${img%.jpg}_thumb.jpg" --width 200 --quality 80
done
```

### Album artwork optimization

```bash
# Standard album cover size
image_helper cover.png --output cover.jpg --width 1000 --height 1000 --quality 90

# High-res album cover
image_helper cover.png --output cover_hd.jpg --width 1400 --height 1400 --quality 95
```

## Performance

### libvips vs Image Crate

- **libvips**: Faster processing, better memory usage (Linux/macOS only)
- **image crate**: Pure Rust, easier deployment, fewer dependencies, cross-platform

### Memory Usage

- Optimized for large images
- libvips provides better memory management for very large files

### Processing Speed

- Efficient algorithms for common operations like resizing
- libvips offers superior performance for high-volume processing

## Error Handling

Common errors and solutions:

1. **Unsupported format**: Check input file format is supported
2. **Permission denied**: Verify read/write permissions for files
3. **Out of memory**: Reduce image size or enable libvips for better memory usage
4. **Invalid dimensions**: Ensure width/height values are positive integers

## Integration

The image helper is used by other MoosicBox components:

- **Server**: Automatic album artwork optimization
- **Web Interface**: Dynamic image resizing for different screen sizes
- **Mobile App**: Thumbnail generation for better performance

## See Also

- [MoosicBox Server]../server/README.md - Uses image processing for album artwork
- [MoosicBox Files]../files/README.md - File handling utilities
- [libvips Documentation]https://www.libvips.org/ - High-performance image processing library