本文实例讲述了Python实现PS滤镜碎片特效功能。分享给大家供大家参考,具体如下:
这里用 Python 实现 PS 滤镜中的碎片特效,这个特效简单来说就是将图像在 上,下,左,右 四个方向做平移,然后将四个方向的平移的图像叠加起来做平均。具体的效果图与说明可参考附录说明
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
from skimage import img_as_float import matplotlib.pyplot as plt from skimage import io file_name = 'D:/Visual Effects/PS Algorithm/4.jpg' ; img = io.imread(file_name) img = img_as_float(img) img_1 = img.copy() img_2 = img.copy() img_3 = img.copy() img_4 = img.copy() img_out = img.copy() Offset = 7 row, col, channel = img.shape img_1[:, 0 : col - 1 - Offset, :] = img[:, Offset:col - 1 , :] img_2[:, Offset:col - 1 , :] = img[:, 0 : col - 1 - Offset, :] img_3[ 0 :row - 1 - Offset, :, :] = img[Offset:row - 1 , :, :] img_4[Offset:row - 1 , :, :] = img[ 0 :row - 1 - Offset, :, :] img_out = (img_1 + img_2 + img_3 + img_4) / 4.0 plt.figure( 1 ) plt.imshow(img) plt.axis( 'off' ); plt.figure( 2 ) plt.imshow(img_out) plt.axis( 'off' ); |
附:PS 滤镜算法原理——碎片效果
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
% % % Fragment % % % 对原图做四个方向的平移,然后对平移的结果取平均 % % % 碎片效果 clc; clear all ; Image = imread( '4.jpg' ); Image = double(Image) / 255 ; [row,col,k] = size(Image); Image1 = Image; Image2 = Image; Image3 = Image; Image4 = Image; Offset = 5 ; % % % 左移 Image1(:, 1 :col - Offset,:) = Image(:, 1 + Offset:col,:); % % % 右移 Image2(:, 1 + Offset:col,:) = Image(:, 1 :col - Offset,:); % % % % 上移 Image3( 1 + Offset:row,:,:) = Image( 1 :row - Offset,:,:); % % % 下移 Image4( 1 :row - Offset,:,:) = Image( 1 + Offset:row,:,:); Image = (Image1 + Image2 + Image3 + Image4) / 4 ; figure, imshow(Image); |
原图:
效果图:
希望本文所述对大家Python程序设计有所帮助。
原文链接:http://blog.csdn.net/matrix_space/article/details/72303014