2 回答
TA贡献1780条经验 获得超1个赞
JPEG、PNG和大多数图像文件格式不能这样工作。它们的开头包含元数据,例如拍照日期、相机型号、GPS 坐标、图像高度、宽度和版权信息。之后,它们通常以高度优化的压缩格式存储像素,因此在不先解压缩数据的情况下无法更改像素。然后,您可以编辑它们并将它们写回,使用新的标头并重新压缩。因此,我们强烈建议您使用图书馆。
如果您真的不想使用 Python 库,您可以在终端中使用ImageMagick(命令行工具)将图像转换为纯 RGB 像素。因此,如果您的图像被称为input.jpg
,您可以在终端中运行它:
magick input.jpg -depth 8 RGB:pixels.dat
然后,如果您的图像为 640x480 像素,则调用的文件的pixels.dat
长度将恰好为 640x480x3 字节,没有标头、元数据或压缩。然后您可以完全按照您最初的设想进行处理。之后,您可以使用以下命令将其恢复为 JPEG 或 PNG:
magick -depth 8 -size 640x480 RGB:pixels.dat output.jpg
请注意,在从 RGB 字节到 JPEG 的返回过程中,您必须如何告诉ImageMagick图像的高度和宽度,因为文件开头没有标头说明其高度和宽度。
TA贡献1777条经验 获得超10个赞
我知道它正在通过输出输出每个像素的信息,因为没有值高于 255 或低于 0
此行为的原因与“每个像素的信息”不同 - 您只是访问了文件的各个字节,并且 1 字节值始终是从0x00
(包括)到0xFF
(包括)。如果您对其他类型的文件(例如文本文件)执行此操作,结果将类似。
此代码复制图像的二进制数据并成功创建一个新图像。
您的代码只是将文件内容复制到另一个文件中。请注意,无论文件类型如何,它都会起作用。
我不想使用任何第三方库,例如 PIL
按照您的意愿进行操作,但请记住,如果没有“任何第三方库”,您必须从头开始自己实现每种图像格式的处理。
添加回答
举报