如何使用Golang设置DPI?

时间:2018-12-16 22:24:49

标签: image go jfif

Golang图像包在某种程度上非常方便,但是缺乏设置图像DPI的支持。我检查了生成的文件-6683 (kCVReturnPixelBufferNotOpenGLCompatible)的文件头,它看起来像jpeg raw。 AFAIK,原始不像jfif一样带有DPI。所以这是我的问题,如何设置生成图像的DPI?或者如何将原始文件转换为jfif,据我所知,我可以编辑文件的特定位以设置DPI?以前,我在我的应用程序中嵌入了AdvancedBatchConverter可执行文件,并使用FF D8 FF DB来完成技巧,但实际上,每次查看代码时,都对此感到厌恶。

2 个答案:

答案 0 :(得分:1)

我相信您正在寻找exif值XResolutionYResolution

我的理解是本地jpeg编码器没有任何exif数据选项。

https://github.com/dsoprea/go-exif将允许您修改exif数据。

另外,我相信,如果您首先将jpeg写入一个bytes.Buffer或类似文件,然后附加exif,则可以在内存中完成整个操作,而无需先刷新到磁盘。

我希望有帮助。

答案 1 :(得分:0)

github.com/dsoprea/go-exif/v2可以读取和写入exif数据。 与其他软件包github.com/dsoprea/go-jpeg-image-structure 这是代码示例。将DPI(XResolution,YResolution)写入图像。

import( 
    exif2 "github.com/dsoprea/go-exif/v2"
    exifcommon "github.com/dsoprea/go-exif/v2/common"
    jpegstructure "github.com/dsoprea/go-jpeg-image-structure"
)
func SetExifData(filepath string) error {
jmp := jpegstructure.NewJpegMediaParser()

intfc, err := jmp.ParseFile(filepath)
log.PanicIf(err)

sl := intfc.(*jpegstructure.SegmentList)

// Make sure we don't start out with EXIF data.
wasDropped, err := sl.DropExif()
log.PanicIf(err)

if wasDropped != true {
    fmt.Printf("Expected the EXIF segment to be dropped, but it wasn't.")
}

im := exif2.NewIfdMapping()

err = exif2.LoadStandardIfds(im)
log.PanicIf(err)

ti := exif2.NewTagIndex()
rootIb := exif2.NewIfdBuilder(im, ti, exifcommon.IfdPathStandard, exifcommon.EncodeDefaultByteOrder)

err = rootIb.AddStandardWithName("XResolution", []exifcommon.Rational{{Numerator: uint32(96), Denominator: uint32(1)}})
log.PanicIf(err)

err = rootIb.AddStandardWithName("YResolution", []exifcommon.Rational{{Numerator: uint32(96), Denominator: uint32(1)}})
log.PanicIf(err)

err = sl.SetExif(rootIb)
log.PanicIf(err)

b := new(bytes.Buffer)

err = sl.Write(b)
log.PanicIf(err)

if err := ioutil.WriteFile(filepath, b.Bytes(), 0644); err != nil {
    fmt.Printf("write file err: %v", err)
}
return nil
}