我正在使用以下代码将Image转换为byte []。
public static byte[] extractBytes (String ImageName) throws IOException {
ByteArrayOutputStream baos=new ByteArrayOutputStream();
BufferedImage img=ImageIO.read(new File(ImageName));
ImageIO.write(img, "jpg", baos);
return baos.toByteArray();
}
现在,当我测试我的代码时:
public static void main(String[] args) throws IOException {
String filepath = "image_old.jpg";
File outp=new File(filepath);
System.out.println("Size of original image="+outp.length());
byte[] data = extractBytes(filepath);
System.out.println("size of byte[] data="+data.length);
BufferedImage img = ImageIO.read(new ByteArrayInputStream(data));
//converting the byte[] array into image again
File outputfile = new File("image_new.jpg");
ImageIO.write(img, "jpeg", outputfile);
System.out.println("size of converted image="+outputfile.length());
}
我得到非常奇怪的结果:
Size of original image=78620
size of byte[] data=20280
size of converted image=20244
将图像转换为byte []后,其大小减小了1/4左右,当我将byte
[]转换回图像时,其大小也会改变。但是在所需位置成功创建了输出图像。放大500-600%后,我可以看到原始图像和新图像的质量略有不同。放大后,新图像几乎不模糊。
这是我正在测试的图像http://pbrd.co/1BrOVbf
请说明尺寸变化的原因,并且我想知道在此之后获得相同尺寸的任何方法。
您拥有的图像将以最高质量设置(“
100%”或1.0
以ImageIO的形式)压缩。JPEG压缩在如此高的设置下不是很有效,因此比平时大很多。使用ImageIO.write(..., "JPEG", ...)
默认质量设置时。此默认值是0.75
(此值的确切含义虽然与编码器有关,但并不完全是科学依据),因此质量较低,因此文件较小。
(另一个可能导致原始图像和重新压缩后的图像之间的文件大小显着减小的原因是删除了元数据。使用进行读取ImageIO.read(file)
时,实际上是在剥离JPEG文件中的任何元数据,例如XMP,Exif或ICC配置文件。在极端情况下(是的,我在这里主要是在谈论Photoshop
;-),此元数据可能比图像数据本身占用更多的空间(即,可能有数百万字节的元数据)。但是,文件不是这种情况。)
从第二次重新压缩(从byte[]
到最终输出文件)可以看到,输出仅略小于输入。这是因为两种情况下的质量设置(未指定,因此仍使用默认设置)是相同的(此外,在此步骤中任何元数据也会丢失,因此不会增加文件大小)。较小的差异可能是由于JPEG解压缩/重新压缩中的一些小损失(舍入误差等)引起的。
尽管有点违反直觉,但是在重新压缩JPEG时,总是通过相同质量设置(使用完全相同的质量)的重新压缩来实现最小的数据丢失(根据与原始图像的变化,而不是文件大小的变化)表格实际上应该是无损的,但仍会像原始表格那样产生较小的舍入误差。增加质量设置将使文件输出更大,但是质量实际上会降低。
确保不丢失任何数据或图像质量的唯一方法是,首先不要解码/编码图像,而只是逐字节复制文件,例如:
File in = ...;
File out = ...;
InputStream input = new FileInputStream(in);
try {
OutputStream output = new FileOutputStream(out);
try {
copy(input, output);
}
finally {
output.close();
}
}
finally {
input.close();
}
和复制方法:
public void copy(final InputStream in, final OutputStream out) {
byte[] buffer = new byte[1024];
int count;
while ((count = in.read(buffer)) != -1) {
out.write(buffer, 0, count);
}
// Flush out stream, to write any remaining buffered data
out.flush();
}
问题内容: 我正在使用以下代码将Image转换为byte []。 现在,当我测试我的代码时: 我得到非常奇怪的结果: 将图像转换为byte []后,其大小减小了1/4左右,当我将byte []转换回图像时,其大小也会改变。但是在所需位置成功创建了输出图像。放大500-600%后,我可以看到原始图像和新图像的质量略有不同。放大后,新图像几乎不模糊。 这是我正在测试的图像http://pbrd.co/
问题内容: 在StackOverflow上已经存在类似此链接的问题,并且可接受的答案是“广播”: 在我的程序中,我尝试: 不幸的是,我得到运行时错误: sun.awt.image.ToolkitImage无法转换为java.awt.image.BufferedImage 显然,投射不起作用。 问题是:将Image转换为BufferedImage的正确方法是(或存在)什么? 问题答案: 从Java游
我正在尝试使用下面的函数将CGM文件转换为PNG。我一直在得到NullPointerException。 下面是我面临的例外 我尝试调试代码,发现ImageIO不支持CGM格式(CanDecodeInputFilter为我的CGM返回false)。关于如何将CGM转换为PNG图像的任何想法。 PS:我正在使用java 11进行开发。 提前感谢 使现代化 根据回复,我尝试了jcgm库(将核心和图像库
问题内容: 我这里有点问题。 我有一个applet,用户可以在其中“绘制”它。为此,我使用java.awt.Graphics2D。但是,如何将用户绘图图像保存为JPEG图像,或者至少将其转换为BufferedImage或其他内容?我不知道该怎么做。 谢谢。 问题答案: 我这样做,并且效果很好: 就这些了:)谢谢大家:)
我有一个名为sampleImage的图像,我试图沿着x轴和y轴拉伸它,如下所示,当它处于横向时,它根本不起作用 然后,我在viewDidLayoutSubviews()中做了如下操作, 如果设备在中,这是有效的,但是一旦您将其旋转到并返回,所有更改都将消失。如何确保这些尺寸在旋转时保持不变?
本文向大家介绍python opencv 图像尺寸变换方法,包括了python opencv 图像尺寸变换方法的使用技巧和注意事项,需要的朋友参考一下 利用Python OpenCV中的 cv.Resize(源,目标,变换方法)就可以实现变换为想要的尺寸了 源文件:就不用说了 目标:你可以对图像进行倍数的放大和缩小 也可以直接的输入尺寸大小 变换的方法: CV_INTER_NN - 最近邻插值,