赞
踩
浮雕效果是一种图像处理技术,用于将图像转换为看起来像浮雕一样的效果,给人一种凸起或凹陷的立体感觉,下面第二张图就是图像处理实现浮雕效果。
不过这个图是用Adobe公司的PS人工P图实现的,效果比较好,算法比我们在本教程讲述的要复杂很多,当然算法也没有公开。
图像的浮雕效果通常是通过以下步骤实现的:
转换为灰度图像:首先,将彩色图像转换为灰度图像。因为浮雕效果更适用于单通道的灰度图像,而且计算简单。
计算浮雕效果:对于每个像素,计算其与相邻像素的亮度差异。这个差异值越大,就越可能是立体感觉的边界。
映射到目标图像:根据计算的差异值,将图像中的每个像素替换为其灰度值加上一个固定的偏移量。通常,亮度差越大,偏移量就越大,从而产生浮雕效果。
调整浮雕强度:可以通过调整偏移量的大小来控制浮雕的强度。较大的偏移量将产生更加明显的浮雕效果,而较小的偏移量则会产生更加柔和的效果。
输出结果:最终得到的图像就是具有浮雕效果的图像,可以保存或者显示出来。
浮雕效果的实现方法有多种,但通常包括计算亮度差异、映射到目标图像和调整强度等步骤。
浮雕效果旨在突出图像中的变化部分,减弱相似部分,从而产生一种立体感。一般的处理流程如下:
差值计算:对于每个像素点,计算其左上角像素与右下角像素的亮度差值,然后加上一个固定的偏移值(通常为128)。这个过程突出了图像中的边缘和变化部分。
边界处理:对计算得到的差值进行边界处理,确保其范围在0到255之间。大于255的值被截断为255,小于0的值被截断为0。
像素替换:用处理后的差值替换原始图像中对应位置的像素值,产生浮雕效果。
PotatoPie 4.0 实验教程(32) —— FPGA实现摄像头图像浮雕效果-Anlogic-安路论坛-FPGA CPLD-ChipDebug
这段代码实现了将一张彩色图像转换为灰度图像,并对灰度图像进行浮雕效果的处理。具体功能如下:
函数功能说明:
cv2.imread(imagePath)
: 读取图像文件,返回图像的Numpy数组表示。cv2.cvtColor(imageIn, cv2.COLOR_BGR2GRAY)
: 将彩色图像转换为灰度图像。plt.imshow(image, cmap='gray')
: 将图像显示在matplotlib窗口中,使用灰度色彩映射。plt.title('title', fontproperties=font)
: 设置图像的标题,使用指定的字体。上面这段代码中我们运用了两种方式计算浮雕效果:
imageGray(i-1, j-1) - imageGray(i+1, j+1) + 128;
即像素点的左上角像素与右下角的像素做差值然后加上 128 imageGray(i, j+1) - imageGray(i, j) + 128;
采用一行像素中前后两个像素做差值然后加上128下面是两种浮雕效果的示意图,可以看到第一种的效果要比第二种的效果好。
PotatoPie 4.0 实验教程(32) —— FPGA实现摄像头图像浮雕效果-Anlogic-安路论坛-FPGA CPLD-ChipDebug
这段 MATLAB 代码实现了对输入的彩色图像进行浮雕效果处理,并显示处理前后的图像。以下是代码的详细功能介绍:
清除工作空间:
clear
、clear all
和 clc
命令清除 MATLAB 工作空间中的所有变量、函数以及命令窗口的内容。获取当前脚本所在目录:
mfilename
和 fileparts
函数获取当前 MATLAB 脚本所在的目录。读取图像文件:
imread
函数读取名为 “Lena.jpg” 的图像文件,该文件位于脚本所在目录。将图像转换为灰度图像:
rgb2gray
函数将彩色图像转换为灰度图像。初始化浮雕效果图像矩阵:
zeros
函数初始化一个与灰度图像大小相同的全零矩阵,用于存储浮雕效果图像。计算浮雕效果:
for
循环遍历灰度图像的每个像素点。显示图像:
subplot
和 imshow
函数在 MATLAB 中创建一个包含三个子图的图像窗口。通过这段代码,可以清楚地展示了原始图像和经过浮雕效果处理后的图像,帮助用户理解浮雕效果处理的效果和实现过程。
上面这段代码中我们运用了两种方式计算浮雕效果:
imageGray(i-1, j-1) - imageGray(i+1, j+1) + 128;
即像素点的左上角像素与右下角的像素做差值然后加上 128 imageGray(i, j+1) - imageGray(i, j) + 128;
采用一行像素中前后两个像素做差值然后加上128下面是两种浮雕效果的示意图,可以看到第一种的效果要比第二种的效果好。
与demo18相比,只是多了一个img_emboss的模块,也就是下面这一段代码,在从SDRAM读出来之后,经它处理后再输出hdmi_tx模块。
- img_emboss u_img_emboss
- (
- .i_clk(clk_pixel),
- .i_rst_n(sys_rst_n),
- .i_hs(VGA_HS),
- .i_vs(VGA_VS),
- .i_de (VGA_DE),
- .i_r(VGA_RGB[23:16]),
- .i_g(VGA_RGB[15:8] ),
- .i_b(VGA_RGB[7:0] ),
- .value(65),
- .o_hs(emboss_hs),
- .o_vs(emboss_vs),
- .o_de(emboss_de),
- .o_gray(emboss_data)
- );
前面讲过有两种实现浮雕效果的算法,为了简化运算和让教程更易懂,我们这个教程中先采用第二种算法。在后面会再开一篇讲解如何实现浮雕效果的第一种算法。
img_emboss核心代码总共有三步:
1、转灰度图,前面的课程中介绍过
r_d0 <= 77 * i_r;
g_d0 <= 150 * i_g;
b_d0 <= 29 * i_b;
2、浮雕计算,这里即为采用第二种方法,gray_d0[15:8]
是当前像素的灰度值,gray_reg
是前一像素的灰度值
assign emboss = gray_d0[15:8] - gray_reg + value; // 浮雕效果值计算
3.对计算出来的值进行防溢出处理,详见代码最后一段always
;
与PotatoPie 4.0 实验教程(18) —— FPGA实现OV5640摄像头采集以SDRAM作为显存进行HDMI输出显示相同,不作赘述。
与PotatoPie 4.0 实验教程(18) —— FPGA实现OV5640摄像头采集以SDRAM作为显存进行HDMI输出显示相同,不作赘述。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。