image_gif灰度处理

package main

import (
	image2 "image"
	"image/color"
	"image/color/palette"
	"image/draw"
	"image/gif"
	"log"
	"os"
)

func main() {
	// 读取每一帧GIF(保存图片【图片路径列表处理】)
	var gfs *gif.GIF
	var err error
	gfs, err = readGif(`/Users/cpenny/go/src/local/ce/fang.gif`)
	dealErr(err)
	var imageList []image2.Image
	imageList, err = GenPicture(gfs)
	dealErr(err)

	// 合成GIF
	err = genGif("ceshi.gif", imageList)
	dealErr(err)

}

// 读取GIF
func readGif(gPath string) (gfs *gif.GIF, err error) {
	var gf *os.File
	gf, err = os.Open(gPath)
	dealErr(err)
	gfs, err = gif.DecodeAll(gf)
	dealErr(err)
	return gfs, err
}

// 生成图片
func GenPicture(gfs *gif.GIF) (imageList []image2.Image, err error) {
	w := gfs.Config.Width
	h := gfs.Config.Height
	if len(gfs.Image) > 0 {
		for _, gf := range gfs.Image {
			img := gf.SubImage(image2.Rect(0, 0, w, h))
			// 灰化处理
			var imgR *image2.RGBA
			imgR = hdImage(img)
			dealErr(err)
			imageList = append(imageList, imgR)
		}
	}
	return imageList, err
}

// 图片灰化处理
func hdImage(m image2.Image) *image2.RGBA {
	bounds := m.Bounds()
	dx := bounds.Dx()
	dy := bounds.Dy()
	newRgba := image2.NewRGBA(bounds)
	for i := 0; i < dx; i++ {
		for j := 0; j < dy; j++ {
			colorRgb := m.At(i, j)
			_, g, _, a := colorRgb.RGBA()
			g_uint8 := uint8(g >> 8)
			a_uint8 := uint8(a >> 8)
			newRgba.SetRGBA(i, j, color.RGBA{g_uint8, g_uint8, g_uint8, a_uint8})
		}
	}
	return newRgba
}

// 生成GIF图
func genGif(gPath string, imageList []image2.Image) (err error) {
	var gf *os.File
	gf, err = os.Create(gPath)
	dealErr(err)
	delay := 1
	if len(imageList) > 0 {
		anim := gif.GIF{}
		for _, img := range imageList {
			paletted := image2.NewPaletted(img.Bounds(), palette.Plan9)
			draw.FloydSteinberg.Draw(paletted, img.Bounds(), img, image2.ZP)

			anim.Image = append(anim.Image, paletted)
			anim.Delay = append(anim.Delay, delay*15)
		}
		err = gif.EncodeAll(gf, &anim)
		dealErr(err)
	}
	err = gf.Close()
	dealErr(err)
	return nil
}

func dealErr(err error) {
	if err != nil {
		log.Println(err)
		panic(err)
	}
}

参考链接:https://github.com/wule61/gif2ascii

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值