Golang图像包在某种程度上非常方便,但是缺乏设置图像DPI的支持。我检查了生成的文件-6683 (kCVReturnPixelBufferNotOpenGLCompatible)
的文件头,它看起来像jpeg raw。 AFAIK,原始不像jfif一样带有DPI。所以这是我的问题,如何设置生成图像的DPI?或者如何将原始文件转换为jfif,据我所知,我可以编辑文件的特定位以设置DPI?以前,我在我的应用程序中嵌入了AdvancedBatchConverter可执行文件,并使用FF D8 FF DB
来完成技巧,但实际上,每次查看代码时,都对此感到厌恶。
答案 0 :(得分:1)
我相信您正在寻找exif值XResolution
和YResolution
我的理解是本地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
}