Skip to content

Commit

Permalink
Merge pull request #2 from juliangra/docs/update-helper
Browse files Browse the repository at this point in the history
docs: update to explain newly exported `ReturnImageFromHeif`
  • Loading branch information
MaestroError authored Apr 11, 2024
2 parents c9da8a8 + 3ce4c64 commit 3162c3f
Showing 1 changed file with 61 additions and 14 deletions.
75 changes: 61 additions & 14 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,35 +1,44 @@
# go-libheif
GoLang wrapper for the libheif library, providing easy-to-use APIs for HEIC to JPEG/PNG conversions and vice versa (Also provides support for AVIF to JPEG/PNG conversions).
This package was originally developed to support the [php-heic-to-jpg](https://github.com/MaestroError/php-heic-to-jpg) package, which had [problems](https://github.com/MaestroError/php-heic-to-jpg/issues/15) while converting some HEIF images.

GoLang wrapper for the libheif library, providing easy-to-use APIs for HEIC to JPEG/PNG conversions and vice versa (Also provides support for AVIF to JPEG/PNG conversions).
This package was originally developed to support the [php-heic-to-jpg](https://github.com/MaestroError/php-heic-to-jpg) package, which had [problems](https://github.com/MaestroError/php-heic-to-jpg/issues/15) while converting some HEIF images.

#### Implementation:

- For a swift start, consider browsing our [quickstart guide](https://medium.com/@revaz.gh/using-the-go-libheif-module-for-converting-images-between-the-heic-format-and-other-popular-formats-e7829165c368) on Medium.
- If you're primarily interested in a hassle-free image conversion tool, we have already integrated this module into a Command Line Interface (CLI) application and a docker image, available [here](https://github.com/MaestroError/heif-converter-image).

### Prerequisites

You need to install [libheif](https://github.com/strukturag/libheif) before using this module. You can check the [strukturag/libheif](https://github.com/strukturag/libheif) for installation instructions, but as I have found, the easiest way for me was to use [brew](https://brew.sh/):

```bash
brew install cmake make pkg-config x265 libde265 libjpeg libtool
brew install libheif
```
*Note: Pay attention to the brew's recommendation while installing*

_Note: Pay attention to the brew's recommendation while installing_

You can find installation scripts in [heif-converter-image](https://github.com/MaestroError/heif-converter-image) repository with names:

- install-libheif.sh
- install-libheif-macos.sh
- install-libheif-windows.bat

*If the installation process seems a bit challenging, we recommend to consider using the [heif-converter-image](https://github.com/MaestroError/heif-converter-image) which offers a ready-to-use docker image.*
_If the installation process seems a bit challenging, we recommend to consider using the [heif-converter-image](https://github.com/MaestroError/heif-converter-image) which offers a ready-to-use docker image._

### Installation

```bash
go get github.com/MaestroError/go-libheif
```

### Usage
This library provides functions to convert images between HEIC format and other common formats such as JPEG and PNG.


This library provides functions to convert images between HEIC format and other common formats such as JPEG and PNG.

To convert an image from HEIC / HEIF / AVIF to JPEG or PNG:

```go
package main

Expand All @@ -44,7 +53,7 @@ func main() {
if err != nil {
log.Fatal(err)
}

err = libheif.HeifToPng("input.heic", "output.png")
if err != nil {
log.Fatal(err)
Expand All @@ -53,27 +62,62 @@ func main() {

```

To convert an image from JPEG or PNG to HEIC:
To convert an image from HEIC to `image.Image` and process image:

```go
package main

import (
"log"
"image/png"

"github.com/MaestroError/go-libheif"
)

func main() {
err := libheif.ImageToHeif("input.jpeg", "output.heic")
img, err := libheif.ReturnImageFromHeif("input.heic")
if err != nil {
log.Fatal(err)
}

err = png.Encode(os.Stdout, img)
if err != nil {
t.Errorf("Failed to encode image: %v", err)
}

}

```
*Note: It finds hard to convert some jpeg and png files to heic, see libheif_test.go:14 for details*


_Note: It finds hard to convert some jpeg and png files to heic, see libheif_test.go:14 for details_

To convert an image from HEIC / HEIF / AVIF to JPEG or PNG:

```go
package main

import (
"log"

"github.com/MaestroError/go-libheif"
)

func main() {
err := libheif.HeifToJpeg("input.heic", "output.jpeg", 80)
if err != nil {
log.Fatal(err)
}

err = libheif.HeifToPng("input.heic", "output.png")
if err != nil {
log.Fatal(err)
}
}

```

To save an image as HEIC:

```go
package main

Expand All @@ -93,11 +137,13 @@ func main() {
}

```
*Note: Quality for **HeifToJpeg** function and image format for **SaveImageAsHeif** function should be provided. The quality value ranges from 1 to 100 inclusive, higher values meaning better quality. The format for **SaveImageAsHeif** is the format of the original image.*

Please consult the GoDoc [documentation](https://pkg.go.dev/github.com/MaestroError/go-libheif) for more detailed information about the provided functions and their usage.
_Note: Quality for **HeifToJpeg** function and image format for **SaveImageAsHeif** function should be provided. The quality value ranges from 1 to 100 inclusive, higher values meaning better quality. The format for **SaveImageAsHeif** is the format of the original image._

Please consult the GoDoc [documentation](https://pkg.go.dev/github.com/MaestroError/go-libheif) for more detailed information about the provided functions and their usage.

### Contributions

Contributions to `go-libheif` are wholeheartedly encouraged! We believe in the power of the open source community to build the most robust and accessible projects. Whether you are a seasoned Go developer or just getting started, your perspective and efforts can help improve this project for everyone.

Here are a few ways you might contribute:
Expand All @@ -117,4 +163,5 @@ Please remember to be as detailed as possible in your pull request descriptions
We look forward to seeing what you contribute! Together, we can make go-libheif even better.

### Credits
Thanks to @strukturag and @farindk (Dirk Farin) for his work on the [libheif](https://github.com/strukturag/libheif) library 🙏

Thanks to @strukturag and @farindk (Dirk Farin) for his work on the [libheif](https://github.com/strukturag/libheif) library 🙏

0 comments on commit 3162c3f

Please sign in to comment.