學習OpenCV:濾鏡系列(15)——羽化(模糊邊緣)
【原文:http://blog.csdn.net/yangtrees/article/details/9210153】
#include <math.h>
#include <opencv/cv.h>
#include <opencv/highgui.h>
#define MAXSIZE (32768)
using namespace cv;
using namespace std;
float mSize = 0.5;
int main()
{
Mat src = imread("D:/img/arrow04.jpg",1);
imshow("src",src);
int width=src.cols;
int heigh=src.rows;
int centerX=width>>1;
int centerY=heigh>>1;
int maxV=centerX*centerX+centerY*centerY;
int minV=(int)(maxV*(1-mSize));
int diff= maxV -minV;
float ratio = width >heigh ? (float)heigh/(float)width : (float)width/(float)heigh;
Mat img;
src.copyTo(img);
Scalar avg=mean(src);
Mat dst(img.size(),CV_8UC3);
Mat mask1u[3];
float tmp,r;
for (int y=0;y<heigh;y++)
{
uchar* imgP=img.ptr<uchar>(y);
uchar* dstP=dst.ptr<uchar>(y);
for (int x=0;x<width;x++)
{
int b=imgP[3*x];
int g=imgP[3*x+1];
int r=imgP[3*x+2];
float dx=centerX-x;
float dy=centerY-y;
if(width > heigh)
dx= (dx*ratio);
else
dy = (dy*ratio);
int dstSq = dx*dx + dy*dy;
float v = ((float) dstSq / diff)*255;
r = (int)(r +v);
g = (int)(g +v);
b = (int)(b +v);
r = (r>255 ? 255 : (r<0? 0 : r));
g = (g>255 ? 255 : (g<0? 0 : g));
b = (b>255 ? 255 : (b<0? 0 : b));
dstP[3*x] = (uchar)b;
dstP[3*x+1] = (uchar)g;
dstP[3*x+2] = (uchar)r;
}
}
imshow("羽化",dst);
waitKey();
imwrite("D:/img/羽化.jpg",dst);
}
Reference:http://www.cnblogs.com/lipeil/archive/2012/09/21/2696519.html
更加簡單的方式:
分析PS的羽化結果可以知道,羽化達成了兩個目的:1. 平滑輪廓線 2. 擴寬過渡區域
1.平滑輪廓線:可以採用均值濾波和cvSnakeImage()兩種方式,前者維護一個寬度為H的視窗,視窗內均值濾波;而後者是OpenCV的C語言版本函式C++沒有包含,其原理是能量最小化,經過測試前者的速度略高於後者,且當H較大時,可以採用視窗加權減一加一的方式來代替每次都求H次加權的方式;
2.擴寬過度區域:採用對mask採用全圖均值濾波方法即可,卷積核的半徑越大,過渡區域越寬。
相關文章
- opencv 邊緣羽化,邊緣過渡OpenCV
- 學習OpenCV:濾鏡系列(5)——徑向模糊:縮放&旋轉OpenCV
- 學習OpenCV:濾鏡系列(6)——風OpenCV
- 學習OpenCV:濾鏡系列(8)——素描OpenCV
- 學習OpenCV:濾鏡系列(1)—— 雕刻&浮雕OpenCV
- 學習OpenCV:濾鏡系列(4)——波浪:正弦OpenCV
- 學習OpenCV:濾鏡系列(7)——漩渦OpenCV
- 學習OpenCV:濾鏡系列(2)——擴張&擠壓OpenCV
- 學習OpenCV:濾鏡系列(9)——擴散(毛玻璃)OpenCV
- 學習OpenCV:濾鏡系列(14)——載入選區OpenCV
- 學習OpenCV:濾鏡系列(12)——計算模式(強光)OpenCV模式
- opencv學習之邊緣檢測OpenCV
- 學習OpenCV:濾鏡系列(13)——計算模式演算法集合OpenCV模式演算法
- 學習OpenCV:濾鏡系列(11)——高反差保留 (6.30修改版)OpenCV
- ps羽化邊緣怎麼設定
- 學習OpenCV:濾鏡系列(10)——懷舊色 & 連環畫 & 熔鑄 & 冰凍OpenCV
- 【從0到1學習邊緣容器系列1】之 邊緣計算與邊緣容器的起源
- 【從0到1學習邊緣容器系列2】之 邊緣應用管理
- 【從0到1學習邊緣容器系列-3】應用容災之邊緣自治
- 【OpenCV學習】影象卷積濾波OpenCV卷積
- 前端 -- 頁面濾鏡效果及高斯模糊效果前端
- OpenCV計算機視覺學習(4)——影像平滑處理(均值濾波,高斯濾波,中值濾波,雙邊濾波)OpenCV計算機視覺
- 【OpenCV】鄰域濾波:方框、高斯、中值、雙邊濾波OpenCV
- Opencv-Python學習筆記十——影像梯度、邊緣檢測 Gradient, Edge DetectionOpenCVPython筆記梯度
- Canvas系列之一——濾鏡效果Canvas
- python+opencv邊緣檢測方法整理PythonOpenCV
- opencv——自適應閾值Canny邊緣檢測OpenCV
- OPENCV例程2 :CANNY運算元邊緣檢測OpenCV
- 【OpenCV】影像的變換(三)-Canny邊緣檢測OpenCV
- 影像濾鏡藝術----Brannan濾鏡NaN
- OpenCV(iOS)的邊緣檢測和Canny運算元OpenCViOS
- 邊緣計算系列科普(五)邊緣計算中的關鍵技術
- Go 邊看邊練 - 《Go 學習筆記》系列Go筆記
- Qt5&OpenCV3.2 Canny邊緣檢測+Hough變換QTOpenCV
- Python-OpenCV 處理影象(二):濾鏡和影象運算PythonOpenCV
- 從《鏡之邊緣》中學到的8個實用的關卡設計技巧
- 詳解數字影像的濾波和邊緣檢測
- opencv 學習OpenCV