这是我对图像进行填充拟合的观点:
#!/usr/bin/env pythonfrom PIL import Image, ImageChopsF_IN = "/path/to/image_in.jpg"F_OUT = "/path/to/image_out.jpg"size = (80,80)image = Image.open(F_IN)image.thumbnail(size, Image.ANTIALIAS)image_size = image.sizethumb = image.crop( (0, 0, size[0], size[1]) )offset_x = max( (size[0] - image_size[0]) / 2, 0 )offset_y = max( (size[1] - image_size[1]) / 2, 0 )thumb = ImageChops.offset(thumb, offset_x, offset_y)thumb.save(F_OUT)
它首先使用缩略图 *** 作将图像降低到原始范围内并保留宽高比。然后将其裁剪掉以实际填充边界的大小(因为除非原始图像为正方形,否则现在会变小),我们找到合适的偏移量使图像居中。图像偏移到中心,因此最终会出现黑色填充,但没有图像裁剪。
除非您能对适当的中心裁切做出合理的猜测,而不会丢失边缘上可能的重要图像数据,否则填充拟合方法会更好。
更新资料
这是可以进行中心裁切或垫合的版本。
#!/usr/bin/env pythonfrom PIL import Image, ImageChops, ImageOpsdef makeThumb(f_in, f_out, size=(80,80), pad=False): image = Image.open(f_in) image.thumbnail(size, Image.ANTIALIAS) image_size = image.size if pad: thumb = image.crop( (0, 0, size[0], size[1]) ) offset_x = max( (size[0] - image_size[0]) / 2, 0 ) offset_y = max( (size[1] - image_size[1]) / 2, 0 ) thumb = ImageChops.offset(thumb, offset_x, offset_y) else: thumb = ImageOps.fit(image, size, Image.ANTIALIAS, (0.5, 0.5)) thumb.save(f_out)source = "/path/to/source/image.JPG"makeThumb(source, "/path/to/source/image_padded.JPG", pad=True)makeThumb(source, "/path/to/source/image_centerCropped.JPG", pad=False)
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)