我不應該充分答案爲JES是一個應用程序專爲學生,但我認爲三個月後可以給它可以用作其他參考完整工作示例...
這應該是接近你試圖做什麼:
注意:您對x和y的簡單雙重循環方法是正確的。
def crazyPic(pic, newRed, newGreen, newBlue):
w = getWidth(pic)
h = getHeight(pic)
new_w = w * 2
new_h = h * 2
newPic = makeEmptyPicture(w * 2, h * 2)
for x in range(new_w):
for y in range(new_h):
new_px = getPixel(newPic, x, y)
# Top-left: B&W
if (x < w) and (y < h):
px = getPixel(pic, x, y)
nRed = getRed(px) * newRed #0.299
nGreen = getGreen(px) * newGreen #0.587
nBlue = getBlue(px) * newBlue #0.114
luminance = nRed + nGreen + nBlue
new_col = makeColor(luminance, luminance, luminance)
# Top-right
elif (y < h):
px = getPixel(pic, x - w, y)
nRed = getRed(px) * newRed
new_col = makeColor(nRed, getGreen(px), getBlue(px))
# Bottom-left
elif (x < w):
px = getPixel(pic, x, y - h)
nGreen = getGreen(px) * newGreen
new_col = makeColor(getGreen(px), nGreen, getBlue(px))
# Bottom-right
else:
px = getPixel(pic, x - w, y - h)
nBlue = getBlue(px) * newBlue
new_col = makeColor(getGreen(px), getBlue(px), nBlue)
setColor(new_px, new_col)
return newPic
file = pickAFile()
picture = makePicture(file)
#picture = crazyPic(picture, 0.299, 0.587, 0.114)
# Here, with my favorite r, g, b weights
picture = crazyPic(picture, 0.21, 0.71, 0.07)
writePictureTo(picture, "/home/quartered.jpg")
show(picture)
輸出(繪畫由安東尼塔皮埃斯):
......來自......
這裏是更多detailed thread約灰度。