如何解决imageminJpegTran 插件旋转图像
我正在做的是压缩我从文件中获得的缓冲区,然后再次将压缩的缓冲区写入内存。发生的情况是正方形和矩形图像被正确压缩,但垂直图像正在旋转。是否有任何选项可以传递给 imageminJpegtran 插件,以便图像保持不变,只是压缩? 这是我的代码:
const fs = require("fs");
const imagemin = require("imagemin");
const imageminJpegtran = require('imagemin-jpegtran');
const imageminpngquant = require('imagemin-pngquant');
async function outputFile() {
let imageBase64 = fs.readFileSync("test_ios.jpg",{encoding: "base64"})
const butmap = Buffer.from(imageBase64,"base64")
try {
let compressedBuffer = await imagemin.buffer(butmap,{
plugins: [
imageminJpegtran(),imageminpngquant({
quality: [0.1,0.8]
})
]
});
compressedBuffer = compressedBuffer.toString("base64");
const compressedBitmap = Buffer.from(compressedBuffer,"base64")
fs.writeFileSync("./test_ios_copy.jpg",compressedBitmap)
} catch (error) {
console.log(error)
}
}
解决方法
我最终使用了另一个名为 imagemin-mozjpeg 的插件。 它允许在不旋转的情况下压缩图像。
const fs = require("fs");
const imagemin = require("imagemin");
const imageMozg = require("imagemin-mozjpeg");
const imageminPngquant = require('imagemin-pngquant');
async function outputFile() {
let imageBase64 = fs.readFileSync("test_ios.jpg",{encoding: "base64"})
const butmap = Buffer.from(imageBase64,"base64")
try {
let compressedBuffer = await imagemin.buffer(butmap,{
plugins: [
imageMozg({
quality: 75,progressive: true
}),imageminPngquant({
quality: [0.1,0.8]
})
]
});
compressedBuffer = compressedBuffer.toString("base64");
const compressedBitmap = Buffer.from(compressedBuffer,"base64")
fs.writeFileSync("./test_ios_copy.jpg",compressedBitmap)
} catch (error) {
console.log(error)
}
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。