作为“夺旗”挑战的一部分,附加的 jpg 被打乱以掩盖内容。图像(“flagpoles.jpg”)为 1600 x 1600 像素。同心线似乎具有 10 像素宽的块大小。(它类似于弗兰克斯特拉的画作)。看起来原始图像已被分成四个部分,围绕中心对称排列。我一直在尝试编写一个 python 脚本来处理像素并解读同心方块。我的努力导致了两种无用的反复出现的情况,要么没有变化,要么更加混乱。我认为这可能是因为我正在处理整个图像,并且尝试解读其中的一部分可能会更好。这是我的代码。目前它只处理一半的像素,因为我试图将图片的各个部分相互匹配。我尝试将块发送到图像的另一侧以尝试匹配它们,但没有任何改进。我们将不胜感激地收到任何有助于获得清晰图片的帮助。
from PIL import Image
import math
im = Image.open("flagpoles.jpg", "r")
pic = im.load()
def rot(A, r, x1, y1):
myArray = []
for i in range(r):
myArray.append([])
for j in range(r):
myArray[i].append(pic[x1+i, y1+j])
for i in range(r):
for j in range(r):
pic[x1+i,y1+j] = myArray[r-1-i][r-1-j]
xres = 800
yres = 800
blocksize = 10
for i in range(blocksize, blocksize+1):
for j in range(int(math.floor(float(xres)/float(blocksize+2+i)))):
for k in range(int(math.floor(float(yres)/float(blocksize+2+i)))):
rot(pic, blocksize+2+i, j*(blocksize+2+i), k*(blocksize+2+i))
im.save("hopeful.png")
print("Finished!")