python图像处理:凸透镜效果/鱼眼图像

该博客介绍了如何使用Python进行图像处理,通过数学计算模拟凸透镜效果,将全景图片转化为鱼眼图片。代码中展示了如何遍历图像像素,根据凸透镜原理进行坐标转换,实现鱼眼矫正。最终结果为将输入图片转换后的鱼眼效果展示并保存。
摘要由CSDN通过智能技术生成

图像处理:凸透镜效果/鱼眼图像

原理

在这里插入图片描述
原理很简单,经过凸透镜放大的区域可以看成一个圆形区域,这个圆形区域是由原始图像一个很小的圆形区域扩展而来。

效果

原图
变换后

应用

python图像处理:全景图片转鱼眼图片(鱼眼矫正)

代码

import cv2
import numpy as np 
import math
def transform(img):
    rows,cols,c = img.shape
    center_x,center_y = rows/2,cols/2
    #radius = min(center_x,center_y)
    radius = math.sqrt(rows**2+cols**2)/2
    new_img = img.copy()
    for i in range(rows):
        for j in range(cols):
            dis = math.sqrt((i-center_x)**2+(j-center_y)**2)
            if dis <= radius:
                new_i = np.int(np.round(dis/radius*(i-center_x)+center_x))
                new_j = np.int(np.round(dis/radius*(j-center_y)+center_y))
                new_img[i,j] = img[new_i,new_j]
                #print((i,j),'\t',(new_i,new_j))
    return new_img
    img = cv2.imread('cat.jpg')
img = transform(img)
cv2.imshow('result',img)
cv2.waitKey(0)
cv2.imwrite('result.jpg',img)
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值