import ImageFilter
import pygame
import numpy
from PIL import Image
import PIL.Image
imageFile='C:\Users\Abhi\Desktop\cbir-p\New folder\gray_image.jpg'
size = Image.open(imageFile).size
im2=Image.open(imageFile)
a=[]
for x in range(size[0]):
a.append([])
for y in range(size[1]):
inten=im2.getpixel((x,y))
a[x].append(inten)
#inten=im2.getpixel((116,143))
#print inten
for item in a:
item.insert(0,0)
item.append(0)
#print a
a.insert(0,[0]*len(a[0]))
a.append([0]*len(a[0]))
#print len(a)
#for item in a:
#print len(item)
b=[]
#print a[1:-1]
for i in range(1,len(a)-1):
b.append([])
for j in range(1,len(a[0])-1):
b[i-1].append((a[i-1][j-1]+a[i-1][j]+a[i-1][j+1]+a[i][j-1]+a[i][j]+a[i][j+1]+a[i+1][j-1]+a[i+1][j]+a[i+1][j+1])/9)
#print b[81][140]
c=numpy.array(b)
#print c
i1 = Image.fromarray(c)
i1.show()
#i1.save('gray.png')
我通过查找其8个邻居的平均值以及当前像素来模糊图像。 当我尝试打印图像时,我得到一个模糊的图像,但它向左旋转。 任何人都可以帮助我向左旋转。图像是灰度图像。
答案 0 :(得分:3)
形状(h, w)
的2D numpy数组可以被认为具有h
行和w
列。
但尺寸为(w, h)
的PIL图片宽w
像素,h
像素高。
因此,这两个数据结构会触发行和列的顺序。如果你追踪你的代码,你会看到
a[x].append(inten)
沿x
行放置a
坐标,从而旋转图像。
修复代码的最简单方法是转置c
:
c=numpy.array(b).T
但请注意,有更简单的方法来模糊图像:
使用PIL:
import ImageFilter
import numpy as np
import Image
imageFile='C:\Users\Abhi\Desktop\cbir-p\New folder\gray_image.jpg'
img = Image.open(FILENAME, 'r').convert('RGB')
img_blur = img.filter(ImageFilter.BLUR)
img_blur.save('/tmp/pil_blur.png')
或者,如果您安装了scipy:
import scipy.ndimage as ndimage
arr = np.asarray(img)
arr_blur = ndimage.gaussian_filter(arr, sigma=(3, 3, 0), order = 0)
img2_blur = Image.fromarray(arr_blur.astype('uint8'), 'RGB')
img2_blur.save('/tmp/scipy_blur.png')