Opencv [Core模块] 案例1 雪花图--操作像素

Mat = image;
//单通道元素级别访问:
image.at<uchar>(j, i) = 255;
//多通道元素
image.at<cv::Vec3b>(i, j)[0] = 255

注意Vec3b不是Vec3d,不然会中断程序运行
区别在于:

typedef Vec<uchar, 3> Vec3b;
typedef Vec<double, 3> Vec3d;

代码

#include<opencv2/core/core.hpp>
#include<opencv2/highgui/highgui.hpp>
#include<iostream>
#include<windows.h>
using namespace std;
using namespace cv;

int main( int argc, char ** argv )
{
    argv[1] = "C:\\Users\\Forrest\\Pictures\\cute.jpg";
    Mat image;
    image = imread(argv[1], CV_LOAD_IMAGE_COLOR);
    if (!image.data)
    {
        cout << "无法打开或找不到图文件" << endl;
        return -1;
    }
    namedWindow("原图", CV_WINDOW_NORMAL);
    namedWindow("下雪图", CV_WINDOW_NORMAL);
    imshow("原图", image);
    int i = 600;//雪点数;
    for (int k = 0; k < i; k++)
    {
        //rand() is MFC random number generator
        // tyr qrand() with Qt
        int i = rand() % image.cols;
        int j = rand() % image.rows;
        if (image.channels() == 1)
        {
            image.at<uchar>(j, i) = 255;
            if (i < image.cols)
                image.at<uchar>(j+1,i) = 255;
            if (j < image.rows)
                image.at<uchar>(j, i + 1) = 255;
            if (i < image.cols && j < image.rows)
                image.at<uchar>(j + 1, i + 1) = 255;
        }
        else if (image.channels() == 3)
        {
            image.at<cv::Vec3b>(j, i)[0] = 255;
            image.at<cv::Vec3b>(j, i)[1] = 255;
            image.at<cv::Vec3b>(j, i)[2] = 255;
            if (i < image.cols - 1)
            {
                image.at<cv::Vec3b>(j, i + 1)[0] = 255;
                image.at<cv::Vec3b>(j, i + 1)[1] = 255;
                image.at<cv::Vec3b>(j, i + 1)[2] = 255;
            }
            if (j < image.rows - 1)
            {
                image.at<cv::Vec3b>(j+1, i)[0] = 255;
                image.at<cv::Vec3b>(j+1, i)[1] = 255;
                image.at<cv::Vec3b>(j+1, i)[2] = 255;
            }
            if (i < image.cols - 1 && j < image.rows - 1)
            {
                image.at<cv::Vec3b>(j + 1, i + 1)[0] = 255;
                image.at<cv::Vec3b>(j + 1, i + 1)[1] = 255;
                image.at<cv::Vec3b>(j + 1, i + 1)[2] = 255;
            }
        }
    }
    imshow("下雪图", image);
    waitKey(0);

}

效果图:

这里写图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值