image/png

Package png

  • import "image/png"

  • Overview

  • Index

  • Examples

概观

包png实现了一个PNG图像解码器和编码器。

The PNG specification is at http://www.w3.org/TR/PNG/.

索引

  • func Decode(r io.Reader) (image.Image, error)

  • func DecodeConfig(r io.Reader) (image.Config, error)

  • func Encode(w io.Writer, m image.Image) error

  • type CompressionLevel

  • type Encoder

  • func (enc *Encoder) Encode(w io.Writer, m image.Image) error

  • type EncoderBuffer

  • type EncoderBufferPool

  • type FormatError

  • func (e FormatError) Error() string

  • type UnsupportedError

  • func (e UnsupportedError) Error() string

例子

解码编码

包文件

paeth.go reader.go writer.go

func DecodeSource

func Decode(r io.Reader) (image.Image, error)

解码从r读取一个PNG图像并将其作为image.Image返回。返回的图像类型取决于PNG内容。

例子

代码:

// This example uses png.Decode which can only decode PNG images. // Consider using the general image.Decode as it can sniff and decode any registered image format. img, err := png.Decode(gopherPNG()) if err != nil { log.Fatal(err) } levels := []string{" ", "░", "▒", "▓", "█"} for y := img.Bounds().Min.Y; y < img.Bounds().Max.Y; y++ { for x := img.Bounds().Min.X; x < img.Bounds().Max.X; x++ { c := color.GrayModel.Convert(img.At(x, y)).(color.Gray) level := c.Y / 51 // 51 * 5 = 255 if level == 5 { level-- } fmt.Print(levels[level]) } fmt.Print("\n") }

func DecodeConfigSource

func DecodeConfig(r io.Reader) (image.Config, error)

DecodeConfig返回PNG图像的颜色模型和尺寸,而不用解码整个图像。

func EncodeSource

func Encode(w io.Writer, m image.Image) error

Encode将图像m以PNG格式写入w。任何图像都可能被编码,但不是image.NRGBA的图像可能会被损坏编码。

例子

package main import ( "image" "image/color" "image/png" "log" "os" ) func main() { const width, height = 256, 256 // Create a colored image of the given width and height. img := image.NewNRGBA(image.Rect(0, 0, width, height)) for y := 0; y < height; y++ { for x := 0; x < width; x++ { img.Set(x, y, color.NRGBA{ R: uint8((x + y) & 255), G: uint8((x + y) << 1 & 255), B: uint8((x + y) << 2 & 255), A: 255, }) } } f, err := os.Create("image.png") if err != nil { log.Fatal(err) } if err := png.Encode(f, img err != nil { f.Close() log.Fatal(err) } if err := f.Close( err != nil { log.Fatal(err) } }

type CompressionLevelSource

type CompressionLevel int

const ( DefaultCompression CompressionLevel = 0 NoCompression CompressionLevel = -1 BestSpeed CompressionLevel = -2 BestCompression CompressionLevel = -3 )

type EncoderSource

编码器配置编码PNG图像。

type Encoder struct { CompressionLevel CompressionLevel // BufferPool optionally specifies a buffer pool to get temporary // EncoderBuffers when encoding an image. BufferPool EncoderBufferPool }

func (*Encoder) EncodeSource

func (enc *Encoder) Encode(w io.Writer, m image.Image) error

编码将图像m以PNG格式写入w。

type EncoderBufferSource

EncoderBuffer保存用于编码PNG图像的缓冲区。

type EncoderBuffer encoder

type EncoderBufferPoolSource

EncoderBufferPool是用于获取和返回EncoderBuffer结构的临时实例的接口。这可以用于编码多个图像时重用缓冲区。

type EncoderBufferPool interface { Get() *EncoderBuffer Put(*EncoderBuffer) }

type FormatErrorSource

FormatError报告输入不是有效的PNG。

type FormatError string

func (FormatError) ErrorSource

func (e FormatError) Error() string

type UnsupportedErrorSource

UnsupportedError报告输入使用有效但未实现的PNG功能。

type UnsupportedError string

func (UnsupportedError) ErrorSource

func (e UnsupportedError) Error() string