Create from Images
Convert images into PDF documents. Each image becomes a page, sized to fit the image while maintaining its aspect ratio. Supports JPEG and PNG formats.
Quick Example
Python
from pdf_oxide import Pdf
# Single image
pdf = Pdf.from_image("photo.jpg")
pdf.save("photo.pdf")
# Multiple images
pdf = Pdf.from_images(["page1.jpg", "page2.png", "page3.jpg"])
pdf.save("album.pdf")
WASM
import { WasmPdf } from "pdf-oxide-wasm";
import { readFileSync, writeFileSync } from "fs";
// Single image from bytes
const imageData = new Uint8Array(readFileSync("photo.jpg"));
const pdf = WasmPdf.fromImageBytes(imageData);
writeFileSync("photo.pdf", pdf.toBytes());
// Multiple images
const images = ["page1.jpg", "page2.png", "page3.jpg"]
.map(f => new Uint8Array(readFileSync(f)));
const album = WasmPdf.fromMultipleImageBytes(images);
writeFileSync("album.pdf", album.toBytes());
Rust
use pdf_oxide::api::Pdf;
// Single image
let pdf = Pdf::from_image("photo.jpg")?;
pdf.save("photo.pdf")?;
// Multiple images
let pdf = Pdf::from_images(&["page1.jpg", "page2.png", "page3.jpg"])?;
pdf.save("album.pdf")?;
Go
package main
import (
"log"
pdfoxide "github.com/yfedoseev/pdf_oxide/go"
)
func main() {
// Single image
pdf, err := pdfoxide.FromImage("photo.jpg")
if err != nil { log.Fatal(err) }
_ = pdf.Save("photo.pdf")
pdf.Close()
// From bytes (for in-memory images)
data, _ := os.ReadFile("photo.jpg")
pdf2, _ := pdfoxide.FromImageBytes(data)
_ = pdf2.Save("photo.pdf")
pdf2.Close()
}
C# support. The C#
Pdf.FromMarkdown,Pdf.FromHtml, andPdf.FromText— image-to-PDF creation is not yet wrapped in the public C# API. Call through the Rust CLI (pdf-oxide from-image photo.jpg) or bridge to Go/Python when generating PDFs from images in a C# pipeline.
Full API Reference
Pdf::from_image(path) – Single Image
Creates a single-page PDF from an image file. The page is sized to fit the image within the configured page dimensions while preserving aspect ratio.
Rust:
use pdf_oxide::api::Pdf;
let pdf = Pdf::from_image("diagram.png")?;
pdf.save("diagram.pdf")?;
Python:
pdf = Pdf.from_image("diagram.png")
pdf.save("diagram.pdf")
Pdf::from_image_bytes(data) – Image from Bytes
Creates a PDF from raw image bytes. The image format (JPEG or PNG) is auto-detected from the byte content.
Rust:
use pdf_oxide::api::Pdf;
let image_bytes = std::fs::read("photo.jpg")?;
let pdf = Pdf::from_image_bytes(&image_bytes)?;
pdf.save("photo.pdf")?;
Python:
from pdf_oxide import Pdf
with open("photo.jpg", "rb") as f:
image_bytes = f.read()
pdf = Pdf.from_image_bytes(image_bytes)
pdf.save("photo.pdf")
JavaScript:
import { WasmPdf } from "pdf-oxide-wasm";
const imageData = new Uint8Array(readFileSync("photo.jpg"));
const pdf = WasmPdf.fromImageBytes(imageData);
writeFileSync("photo.pdf", pdf.toBytes());
WasmPdf.fromMultipleImageBytes(imagesArray) – Multiple Images from Bytes
Creates a multi-page PDF from an array of image byte arrays. Each image becomes a separate page. Available in JavaScript/WASM only.
JavaScript:
import { WasmPdf } from "pdf-oxide-wasm";
const images = ["scan_001.jpg", "scan_002.jpg", "scan_003.jpg"]
.map(f => new Uint8Array(readFileSync(f)));
const pdf = WasmPdf.fromMultipleImageBytes(images);
writeFileSync("scanned_document.pdf", pdf.toBytes());
Pdf::from_images(paths) – Multiple Images
Creates a multi-page PDF where each image becomes a separate page. Pages are individually sized to match each image’s dimensions and aspect ratio.
Rust:
use pdf_oxide::api::Pdf;
let pages = vec!["scan_001.jpg", "scan_002.jpg", "scan_003.jpg"];
let pdf = Pdf::from_images(&pages)?;
pdf.save("scanned_document.pdf")?;
Python:
from pdf_oxide import Pdf
pages = ["scan_001.jpg", "scan_002.jpg", "scan_003.jpg"]
pdf = Pdf.from_images(pages)
pdf.save("scanned_document.pdf")
Using PdfBuilder with Images
Use PdfBuilder to control page size and margins when creating image PDFs.
Rust:
use pdf_oxide::api::PdfBuilder;
use pdf_oxide::writer::PageSize;
let pdf = PdfBuilder::new()
.title("Photo Album")
.author("Photographer")
.page_size(PageSize::A4)
.margin(36.0) // 0.5 inch margins
.from_image("photo.jpg")?;
pdf.save("photo_a4.pdf")?;
Multiple images with builder:
use pdf_oxide::api::PdfBuilder;
use pdf_oxide::writer::PageSize;
let pdf = PdfBuilder::new()
.title("Document Scans")
.page_size(PageSize::Letter)
.from_images(&["page1.png", "page2.png"])?;
pdf.save("scans.pdf")?;
Advanced Examples
Batch Convert a Directory of Images
use pdf_oxide::api::Pdf;
use std::fs;
let mut images: Vec<String> = fs::read_dir("./photos")?
.filter_map(|entry| {
let path = entry.ok()?.path();
let ext = path.extension()?.to_str()?.to_lowercase();
if ext == "jpg" || ext == "jpeg" || ext == "png" {
Some(path.to_string_lossy().to_string())
} else {
None
}
})
.collect();
images.sort();
let pdf = Pdf::from_images(&images)?;
pdf.save("all_photos.pdf")?;
Python: Convert Images from a Directory
from pdf_oxide import Pdf
from pathlib import Path
image_dir = Path("./scans")
images = sorted(
str(p) for p in image_dir.iterdir()
if p.suffix.lower() in (".jpg", ".jpeg", ".png")
)
pdf = Pdf.from_images(images)
pdf.save("scans.pdf")
Create PDF from Downloaded Image Bytes
from pdf_oxide import Pdf
import urllib.request
url = "https://example.com/chart.png"
image_data = urllib.request.urlopen(url).read()
pdf = Pdf.from_image_bytes(image_data)
pdf.save("chart.pdf")
JavaScript: Convert Multiple Images in the Browser
import { WasmPdf } from "pdf-oxide-wasm";
async function imagesToPdf(fileList) {
const images = [];
for (const file of fileList) {
const buffer = await file.arrayBuffer();
images.push(new Uint8Array(buffer));
}
const pdf = WasmPdf.fromMultipleImageBytes(images);
return pdf.toBytes();
}
Supported Formats
| Format | Extensions | Notes |
|---|---|---|
| JPEG | .jpg, .jpeg |
Lossy compression, best for photos |
| PNG | .png |
Lossless, supports transparency |
Related Pages
- PdfBuilder Fluent API – Configure page size, margins, and metadata
- QR Codes and Barcodes – Generate barcode images as PDFs
- Create from Markdown – Convert text content to PDF