zoukankan      html  css  js  c++  java
  • OpenCV——径向模糊

    参考来源: 

    学习OpenCV:滤镜系列(5)——径向模糊:缩放&旋转

    // define head function
    #ifndef PS_ALGORITHM_H_INCLUDED
    #define PS_ALGORITHM_H_INCLUDED
    
    #include <iostream>
    #include <string>
    #include "cv.h"
    #include "highgui.h"
    #include "cxmat.hpp"
    #include "cxcore.hpp"
    #include "math.h"
    
    using namespace std;
    using namespace cv;
    
    void Show_Image(Mat&, const string &);
    
    #endif // PS_ALGORITHM_H_INCLUDED
    
    /*
    This program will generate
    radition blur effect
    
    */
    
    
    #include "PS_Algorithm.h"
    #include <time.h>
    
    using namespace std;
    using namespace cv;
    
    int main()
    {
        string Img_name("4.jpg");
        Mat Img_in;
        Img_in=imread(Img_name);
        Show_Image(Img_in, Img_name);
    
        Mat Img_out(Img_in.size(), CV_32FC3);
        Img_in.convertTo(Img_out, CV_32FC3);
    
        int width=Img_in.cols;
        int height=Img_in.rows;
    
        float R;
        float angle;
    
        Point Center(width/2, height/2);
        float t1, t2, t3;
        int new_x, new_y;
    
        int Num=20;
    
        for (int y=0; y<height; y++)
        {
            for (int x=0; x<width; x++)
            {
                t1=0; t2=0; t3=0;
                R=sqrt((y-Center.y)*(y-Center.y)+(x-Center.x)*(x-Center.x));
                angle=atan2((float)(y-Center.y), (float)(x-Center.x));
                for (int mm=0; mm<Num; mm++)
                {
                    float tmR=R-mm>0 ? R-mm : 0.0;
    
                    new_x=tmR*cos(angle)+Center.x;
                    new_y=tmR*sin(angle)+Center.y;
    
                    if(new_x<0)       new_x=0;
                    if(new_x>width-1) new_x=width-1;
                    if(new_y<0)       new_y=0;
                    if(new_y>height-1)new_y=height-1;
    
                    t1=t1+Img_in.at<Vec3b>(new_y, new_x)[0];
                    t2=t2+Img_in.at<Vec3b>(new_y, new_x)[1];
                    t3=t3+Img_in.at<Vec3b>(new_y, new_x)[2];
    
                }
    
                Img_out.at<Vec3f>(y, x)[0]=t1/Num;
                Img_out.at<Vec3f>(y, x)[1]=t2/Num;
                Img_out.at<Vec3f>(y, x)[2]=t3/Num;
    
            }
        }
    
        Img_out=Img_out/255.0;
        Show_Image(Img_out, "out");
    
        imwrite("Out.jpg", Img_out*255);
    
    
        waitKey();
    
    }
    
    
    // define the show image
    #include "PS_Algorithm.h"
    #include <iostream>
    #include <string>
    
    using namespace std;
    using namespace cv;
    
    void Show_Image(Mat& Image, const string& str)
    {
        namedWindow(str.c_str(),CV_WINDOW_AUTOSIZE);
        imshow(str.c_str(), Image);
    
    }
    

    原图 


    效果图


  • 相关阅读:
    Linux系统安全及应用
    Linux 10 进程和计划的管理任务
    Centos netdata 的安装及配置
    Centos nmon安装及使用
    Python 各种数据类型的了解(上)
    神奇的循环知识
    Pathon的基础知识
    初次遇见Python
    操作系统与编程语言的简介
    计算机硬件基础
  • 原文地址:https://www.cnblogs.com/mtcnn/p/9412592.html
Copyright © 2011-2022 走看看