Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/oliamb/cutter
Crop images in Golang
https://github.com/oliamb/cutter
Last synced: 2 months ago
JSON representation
Crop images in Golang
- Host: GitHub
- URL: https://github.com/oliamb/cutter
- Owner: oliamb
- License: mit
- Created: 2014-02-28T16:50:17.000Z (almost 11 years ago)
- Default Branch: master
- Last Pushed: 2021-06-28T12:24:58.000Z (over 3 years ago)
- Last Synced: 2024-08-01T13:31:31.260Z (5 months ago)
- Language: Go
- Homepage: http://godoc.org/github.com/oliamb/cutter
- Size: 3.66 MB
- Stars: 199
- Watchers: 1
- Forks: 30
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ccamel - oliamb/cutter - Crop images in Golang (Go)
README
Cutter
======A Go library to crop images.
[![Build Status](https://travis-ci.org/oliamb/cutter.png?branch=master)](https://travis-ci.org/oliamb/cutter)
[![GoDoc](https://godoc.org/github.com/oliamb/cutter?status.png)](https://godoc.org/github.com/oliamb/cutter)Cutter was initially developped to be able
to crop image resized using github.com/nfnt/resize.Usage
-----Read the doc on https://godoc.org/github.com/oliamb/cutter
Import package with
```go
import "github.com/oliamb/cutter"
```Package cutter provides a function to crop image.
By default, the original image will be cropped at the
given size from the top left corner.```go
croppedImg, err := cutter.Crop(img, cutter.Config{
Width: 250,
Height: 500,
})
```Most of the time, the cropped image will share some memory
with the original, so it should be used read only. You must
ask explicitely for a copy if nedded.```go
croppedImg, err := cutter.Crop(img, cutter.Config{
Width: 250,
Height: 500,
Options: cutter.Copy,
})
```It is possible to specify the top left position:
```go
croppedImg, err := cutter.Crop(img, cutter.Config{
Width: 250,
Height: 500,
Anchor: image.Point{100, 100},
Mode: cutter.TopLeft, // optional, default value
})
```The Anchor property can represents the center of the cropped image
instead of the top left corner:```go
croppedImg, err := cutter.Crop(img, cutter.Config{
Width: 250,
Height: 500,
Mode: cutter.Centered,
})
```The default crop use the specified dimension, but it is possible
to use Width and Heigth as a ratio instead. In this case,
the resulting image will be as big as possible to fit the asked ratio
from the anchor position.```go
croppedImg, err := cutter.Crop(baseImage, cutter.Config{
Width: 4,
Height: 3,
Mode: cutter.Centered,
Options: cutter.Ratio&cutter.Copy, // Copy is useless here
})
```About resize
------------
This lib only manage crop and won't resize image, but it works great in combination with [github.com/nfnt/resize](https://github.com/nfnt/resize)Contributing
------------
I'd love to see your contributions to Cutter. If you'd like to hack on it:- fork the project,
- hack on it,
- ensure tests pass,
- make a pull requestIf you plan to modify the API, let's disscuss it first.
Licensing
---------
MIT License, Please see the file called LICENSE.Credits
-------
Test Picture: Gopher picture from Heidi Schuyt, http://www.flickr.com/photos/hschuyt/7674222278/,
© copyright Creative Commons(http://creativecommons.org/licenses/by-nc-sa/2.0/)Thanks to Urturn(http://www.urturn.com) for the time allocated to develop the library.