No description
Find a file
Shunsuke Michii b6fdea0f69 Merge pull request #10 from harukasan/feature/importGray
Add support encoding image.Gray.
2016-06-29 21:47:44 +09:00
examples Update examples. 2016-06-28 16:49:57 +09:00
test/util Try to find example files in multiple directories which contains $GOPATH. 2015-01-09 16:59:41 +09:00
webp Add const keyword to arguments. 2016-06-29 21:24:39 +09:00
.gitignore initial commit 2015-01-09 12:52:13 +09:00
.travis.yml Make faster Travis. 2016-06-29 19:35:46 +09:00
LICENSE initial commit 2015-01-09 12:52:13 +09:00
README.md Merge pull request #9 from harukasan/feature/config 2016-06-29 18:06:42 +09:00

go-libwebp

Build Status GoDoc

A implementation of Go binding for libwebp.

Dependencies

  • libwebp 0.4, 0.5

Usage

The examples directory contains example codes and images.

Decoding WebP into image.RGBA

package main

import (
	"github.com/harukasan/go-libwebp/test/util"
	"github.com/harukasan/go-libwebp/webp"
)

func main() {
	var err error

	// Read binary data
	data := util.ReadFile("cosmos.webp")

	// Decode
	options := &webp.DecoderOptions{}
	img, err := webp.DecodeRGBA(data, options)
	if err != nil {
		panic(err)
	}

	util.WritePNG(img, "encoded_cosmos.png")
}

You can set more decoding options such as cropping, flipping and scaling.

Encoding WebP from image.RGBA

package main

import (
	"bufio"
	"image"

	"github.com/harukasan/go-libwebp/test/util"
	"github.com/harukasan/go-libwebp/webp"
)

func main() {
	img := util.ReadPNG("cosmos.png")

	// Create file and buffered writer
	io := util.CreateFile("encoded_cosmos.webp")
	w := bufio.NewWriter(io)
	defer func() {
		w.Flush()
		io.Close()
	}()

	config := webp.ConfigPreset(webp.PresetDefault, 90)

	// Encode into WebP
	if err := webp.EncodeRGBA(w, img.(*image.RGBA), config); err != nil {
		panic(err)
	}
}

TODO

  • Incremental decoding API
  • Container API (Animation)

License

Copyright (c) 2016 MICHII Shunsuke. All rights reserved.

This library is released under The BSD 2-Clause License. See LICENSE.