Go to file
2012-08-09 18:58:57 +02:00
filters.go Changed function signature to include error handling. Filters simplified. 2012-08-08 21:32:51 +02:00
LICENSE Documentation updated 2012-08-03 17:39:38 +02:00
README.md Function signature changed again, no need for multiple return value 2012-08-09 18:58:57 +02:00
resize_test.go Function signature changed again, no need for multiple return value 2012-08-09 18:58:57 +02:00
resize.go Function signature changed again, no need for multiple return value 2012-08-09 18:58:57 +02:00
sinc_test.go initial commit 2012-08-02 21:59:40 +02:00
sinc.go initial commit 2012-08-02 21:59:40 +02:00

Resize

Image resizing for the Go programming language that includes a few interpolation methods.

Installation

$ go get github.com/nfnt/resize

It's that easy!

Usage

Import package with

import "github.com/nfnt/resize"

Resize creates a scaled image with new dimensions (width, height) using the interpolation function interp. If either width or height is set to 0, it will be set to an aspect ratio preserving value.

resize.Resize(width, height uint, img image.Image, interp resize.InterpolationFunction) image.Image, error 

The provided interpolation functions are

Sample usage:

package main

import (
	"github.com/nfnt/resize"
	"image/jpeg"
	"os"
)

func main() {
	// open "test.jpg"
	file, err := os.Open("test.jpg")
	if err != nil {
		return
	}

	// decode jpeg into image.Image
	img, err := jpeg.Decode(file)
	if err != nil {
		return
	}
	file.Close()

	// resize to width 1000 using Lanczos resampling
	// and preserve aspect ration
	m := resize.Resize(1000, 0, img, resize.Lanczos3)

	out, err := os.Create("test_resized.jpg")
	if err != nil {
		return
	}
	defer out.Close()

	// write new image to file
	jpeg.Encode(out, m, nil)
}

License

Copyright (c) 2012 Jan Schlicht janschlicht@gmail.com Resize is released under an MIT style license.