首页 > 其他 > 详细

图像锐化

时间:2014-03-12 06:28:15      阅读:551      评论:0      收藏:0      [点我收藏+]
bubuko.com,布布扣
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
#include <iostream>
using namespace cv;

void sharpenImage1(const cv::Mat& image, cv::Mat &result)
{
    cv::Mat kelnel (3,3,CV_32F,cv::Scalar(0)); //构造核函数
        //对核元素进行赋值
    kelnel.at<float>(1,1)=5.0;
    kelnel.at<float>(0,1)=-1.0;
    kelnel.at<float>(2,1)=-1.0;
    kelnel.at<float>(1,0)=-1.0;
    kelnel.at<float>(1,2)=-1.0;
    //对图像进行滤波
    cv::filter2D(image,result,image.depth(),kelnel);
}

int main(int argc, char* argv[])
{
    Mat image = cv::imread("my.jpg");
    Mat image_gray ;
    image_gray.create(image.size(),image.type());//创建一个矩阵
    if(!image.data)
        return -1;//判断是否图片存在,若不存在,返回-1
    if(image.channels()==3)//如果为3通道,即彩色图片
        cv::cvtColor(image,image_gray,CV_RGB2GRAY);//将彩色图片转化为灰度图片
    cv::Mat result;
    result.create(image_gray.size(),image_gray.type());
    double time_ = static_cast<double>(cv::getTickCount());
    sharpenImage1(image_gray,result);
    time_ = 1000*static_cast<double>(cv::getTickCount()-time_)/cv::getTickFrequency();
    std::cout<<"time = "<<time_<<"ms"<<std::endl;

    cv::imshow("image result",result);

    cv::waitKey();
    return 0;
}
bubuko.com,布布扣


对图像进行锐化 并输出时间

图像锐化,布布扣,bubuko.com

图像锐化

原文:http://www.cnblogs.com/zsmj2014/p/3594107.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!