0

我正在使用以下代码从 Amazon s3 获取对象并在执行调整大小和裁剪之后。我想将它存储在 s3 上。但问题是我无法转换mw (Image maigck object)为字节数组。它将用于将其存储在 s3 上。此外,在当前方法中,它使用 jpeg.Encode。如果图像是 .png 或 .gif 格式怎么办。我们如何将其转换为 []byte?

您能否还告诉我如何仅通过纵横比而不是裁剪坐标来均匀裁剪图像。imgStream.Crop((int)originalWidth, ((int)(originalWidth / masterAspectRatio)), Gravity.Center)就像我们在 .net 中那样。我要问的原因是库中没有提供这种灵活性的方法。

s3Client := s3.New(session.New(), &aws.Config{Region: aws.String(region)})
            params := &s3.GetObjectInput{
            Bucket: aws.String(bucketName),
            Key: aws.String(keyName),
            }

        out, err := s3Client.GetObject(params)

        if err != nil {
             log.Fatal(err)
        }

        img, err := ioutil.ReadAll(out.Body)
        if err != nil {
            log.Fatal(err)
        }      

        mw := imagick.NewMagickWand()   

        err = mw.ReadImageBlob(img)
        if err != nil {
            log.Fatal(err)
        }

        //Perform resizing and cropping on mw object

        buf := new(bytes.Buffer)
        err = jpeg.Encode(buf, mw, nil)
        sendmw_s3 := buf.Bytes()

         paramsPut := &s3.PutObjectInput{
                        Bucket:         aws.String(masterBucketName),
                        Key:            aws.String(keyName),
                        Body:         bytes.NewReader(sendmw_s3),
                }

        resp, err := s3Client.PutObject(paramsPut)
        if err != nil {
            log.Fatal(err)
        }

错误 :

 cannot use mw (type *imagick.MagickWand) as type image.Image in argument to jpeg.Encode:
    *imagick.MagickWand does not implement image.Image (missing At method)
4

2 回答 2

2

您需要使用该func (mw *MagickWand) GetImageBlob() []byte功能。

它返回一个字节切片,其中包含当前文件格式(JPEG、gif、PNG...)的完整编码图像。

因此,返回的数据可以保存到磁盘,或按原样发送到 s3。

有关文档,请参阅https://gowalker.org/github.com/gographics/imagick/imagick#MagickWand_GetImageBlob

于 2016-02-03T16:42:36.580 回答
1

这个问题实际上是两个问题,@SirDarius 通过建议使用GetImageBlob(). 您还可以使用SetImageFormat()在生成 blob 之前更改图像格式。

关于作物的部分,我相信 ImageMagick 有很多方法可以做到这一点。我实现中心裁剪的方法是首先转换图像,使较小的尺寸适合我想要的目标分辨率。然后裁剪掉溢出的部分。

// Create a new image where smallest dimension is fit
// and the rest overflows the dimensions
size := fmt.Sprintf("%dx%d^+0+0", w, h)
tx := wand.TransformImage("", size)

// Center Crop away the extra parts of the image, to perform
tx.SetImageGravity(imagick.GRAVITY_CENTER)
offsetX := -(int(w) - int(tx.GetImageWidth())) / 2
offsetY := -(int(h) - int(tx.GetImageHeight())) / 2
err := tx.ExtentImage(w, h, offsetX, offsetY)
...
于 2016-02-03T20:09:01.957 回答