日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python绘制立体扇形_Python实现PS滤镜特效之扇形变换效果示例

發布時間:2023/12/19 python 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python绘制立体扇形_Python实现PS滤镜特效之扇形变换效果示例 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

本文實例講述了Python實現PS濾鏡特效之扇形變換效果。分享給大家供大家參考,具體如下:

這里用 Python 實現 PS 濾鏡中的一種幾何變換特效,稱為扇形變換,將圖像扭曲成一個扇形,具體的算法原理和效果圖可以參考附錄說明

import numpy as np

from skimage import img_as_float

import matplotlib.pyplot as plt

from skimage import io

import math

import numpy.matlib

file_name2='D:/Visual Effects/PS Algorithm/4.jpg'

img=io.imread(file_name2)

img = img_as_float(img)

# control the radius of the inner circle

radius = 150

# control the distance between the inner circle and outer circle

high = 200

angle = 0

spreadAngle = math.pi

# set the center of the circle, proportion of the image size

centerX = 0.5

centerY = 1.0

row, col, channel = img.shape

icenterX = col * centerX

icenterY = row * centerY

img_out = img * 0

xx = np.arange (col)

yy = np.arange (row)

x_mask = numpy.matlib.repmat (xx, row, 1)

y_mask = numpy.matlib.repmat (yy, col, 1)

y_mask = np.transpose(y_mask)

xx_dif = x_mask - icenterX

yy_dif = y_mask - icenterY

theta = np.arctan2(-yy_dif, -xx_dif+0.0001)

r = np.sqrt(xx_dif*xx_dif + yy_dif * yy_dif)

theta = np.mod(theta, 2 * math.pi)

x1_mask = col * theta/(spreadAngle+0.00001)

y1_mask = row * (1-(r-radius)/(high+0.00001))

'''

mask = x1_mask < 0

x1_mask = x1_mask * (1 - mask)

mask = x1_mask > (col - 1)

x1_mask = x1_mask * (1 - mask) + (x1_mask * 0 + col -2) * mask

mask = y1_mask < 0

y1_mask = y1_mask * (1 - mask)

mask = y1_mask > (row -1)

y1_mask = y1_mask * (1 - mask) + (y1_mask * 0 + row -2) * mask

'''

int_x = np.floor (x1_mask)

int_x = int_x.astype(int)

int_y = np.floor (y1_mask)

int_y = int_y.astype(int)

for ii in range(row):

for jj in range (col):

new_xx = int_x [ii, jj]

new_yy = int_y [ii, jj]

if x1_mask [ii, jj] < 0 or x1_mask [ii, jj] > col -1 :

continue

if y1_mask [ii, jj] < 0 or y1_mask [ii, jj] > row -1 :

continue

img_out[ii, jj, :] = img[new_yy, new_xx, :]

plt.figure (1)

plt.title('www.ddpool.cn')

plt.imshow (img)

plt.axis('off')

plt.figure (2)

plt.title('www.ddpool.cn')

plt.imshow (img_out)

plt.axis('off')

plt.show()

附錄:PS 濾鏡— —扇形warp

clc;

clear all;

close all;

addpath('E:\PhotoShop Algortihm\Image Processing\PS Algorithm');

I=imread('4.jpg');

I=double(I);

Image=I/255;

[height, width, depth]=size(Image);

% set the parameters

radius = 150; % control the radius of the inner circle

high = 200; % control the distance between the inner circle and outer circle

angle = 0;

spreadAngle=pi;

centerX = 0.5; % set the center of the circle, proportion of the image size

centerY = 1.0;

icenterX=width*centerX;

icenterY=height*centerY;

Image_new=Image*0;

for i=1:height

for j=1:width

dx=j-icenterX;

dy=i-icenterY;

theta=atan2(-dy, -dx)+angle;

r=sqrt(dy*dy+dx*dx);

theta=mod(theta, 2*pi);

x=width * theta/(spreadAngle+0.00001);

y=height * (1-(r-radius)/(high+0.00001));

% % if (x<=1) x=1; end

% % if (x>=width) x=width-1; end;

% % if (y>=height) y=height-1; end;

% % if (y<1) y=1; end;

% %

if (x<=1) continue; end

if (x>=width) continue; end;

if (y>=height) continue; end;

if (y<1) continue; end;

x1=floor(x);

y1=floor(y);

p=x-x1;

q=y-y1;

Image_new(i,j,:)=(1-p)*(1-q)*Image(y1,x1,:)+p*(1-q)*Image(y1,x1+1,:)...

+q*(1-p)*Image(y1+1,x1,:)+p*q*Image(y1+1,x1+1,:);

end

end

imshow(Image_new)

imwrite(Image_new, 'out.jpg');

參考來源:http://www.jhlabs.com/index.html

本例Python運行效果:

原圖

效果圖

希望本文所述對大家Python程序設計有所幫助。

總結

以上是生活随笔為你收集整理的python绘制立体扇形_Python实现PS滤镜特效之扇形变换效果示例的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。