opencv:image->imageData+image->widthStep*i)[j]表达式含义

opencv:image->imageData+image->widthStep*i)[j]表达式含义代码含义image->imageData+image->widthStepi)[j]就是得到image图像中第i行第j列的像素值。一开始ptr[Rows]=255;显示的结果不是中心5050区域,后来查阅资料得知要用三通道的表达方式ptr[3*Rows]=0;//Rptr[3*Rows+1]=0;//Gptr[3*Rows+2]=0;//…

大家好,又见面了,我是你们的朋友全栈君。

代码含义

image->imageData+image->widthStep*i)[j] 就是得到image图像中第i行第j列的像素值。

一开始ptr[Rows] = 255;显示的结果不是中心50*50区域,后来查阅资料得知要用三通道的表达方式

ptr[3 * Rows] = 0;//R
ptr[3 * Rows + 1] = 0;//G
ptr[3 * Rows + 2] = 0;//B

完整代码如下:

#include "stdafx.h"
#include "convert.h"
#include "convertDlg.h"
#include "afxdialogex.h"
#include "cv.h"
#include "highgui.h" 
#include <stdio.h> 
#include <cxcore.h>
#include <stdbool.h>
//#include "CvvImage.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#endif

IplImage *src = NULL;
IplImage *src1 = NULL;
IplImage *dst = NULL;
IplImage *MultiImage = NULL;

// 用于应用程序“关于”菜单项的 CAboutDlg 对话框

class CAboutDlg : public CDialogEx
{
public:
	CAboutDlg();

// 对话框数据
#ifdef AFX_DESIGN_TIME
	enum { IDD = IDD_ABOUTBOX };
#endif

	protected:
	virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV 支持

// 实现
protected:
	DECLARE_MESSAGE_MAP()
};

CAboutDlg::CAboutDlg() : CDialogEx(IDD_ABOUTBOX)
{
}

void CAboutDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialogEx::DoDataExchange(pDX);
}

BEGIN_MESSAGE_MAP(CAboutDlg, CDialogEx)
END_MESSAGE_MAP()


// CconvertDlg 对话框



CconvertDlg::CconvertDlg(CWnd* pParent /*=nullptr*/)
	: CDialogEx(IDD_CONVERT_DIALOG, pParent)
{
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void CconvertDlg::DoDataExchange(CDataExchange* pDX)
{
	CDialogEx::DoDataExchange(pDX);
}

BEGIN_MESSAGE_MAP(CconvertDlg, CDialogEx)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_BUTTON1, &CconvertDlg::OnBnClickedButton1)
	//ON_BN_CLICKED(IDC_BUTTON2, &CconvertDlg::OnBnClickedButton2)
	ON_BN_CLICKED(IDC_BUTTON2, &CconvertDlg::OnBnClickedButton2)
END_MESSAGE_MAP()


// CconvertDlg 消息处理程序

BOOL CconvertDlg::OnInitDialog()
{
	CDialogEx::OnInitDialog();

	// 将“关于...”菜单项添加到系统菜单中。

	// IDM_ABOUTBOX 必须在系统命令范围内。
	ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
	ASSERT(IDM_ABOUTBOX < 0xF000);

	CMenu* pSysMenu = GetSystemMenu(FALSE);
	if (pSysMenu != nullptr)
	{
		BOOL bNameValid;
		CString strAboutMenu;
		bNameValid = strAboutMenu.LoadString(IDS_ABOUTBOX);
		ASSERT(bNameValid);
		if (!strAboutMenu.IsEmpty())
		{
			pSysMenu->AppendMenu(MF_SEPARATOR);
			pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
		}
	}

	// 设置此对话框的图标。  当应用程序主窗口不是对话框时,框架将自动
	//  执行此操作
	SetIcon(m_hIcon, TRUE);			// 设置大图标
	SetIcon(m_hIcon, FALSE);		// 设置小图标

	// TODO: 在此添加额外的初始化代码

	return TRUE;  // 除非将焦点设置到控件,否则返回 TRUE
}

void CconvertDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
	if ((nID & 0xFFF0) == IDM_ABOUTBOX)
	{
		CAboutDlg dlgAbout;
		dlgAbout.DoModal();
	}
	else
	{
		CDialogEx::OnSysCommand(nID, lParam);
	}
}

// 如果向对话框添加最小化按钮,则需要下面的代码
//  来绘制该图标。  对于使用文档/视图模型的 MFC 应用程序,
//  这将由框架自动完成。

void CconvertDlg::OnPaint()
{
	if (IsIconic())
	{
		CPaintDC dc(this); // 用于绘制的设备上下文

		SendMessage(WM_ICONERASEBKGND, reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);

		// 使图标在工作区矩形中居中
		int cxIcon = GetSystemMetrics(SM_CXICON);
		int cyIcon = GetSystemMetrics(SM_CYICON);
		CRect rect;
		GetClientRect(&rect);
		int x = (rect.Width() - cxIcon + 1) / 2;
		int y = (rect.Height() - cyIcon + 1) / 2;

		// 绘制图标
		dc.DrawIcon(x, y, m_hIcon);
	}
	else
	{
		CDialogEx::OnPaint();
	}
}

//当用户拖动最小化窗口时系统调用此函数取得光标
//显示。
HCURSOR CconvertDlg::OnQueryDragIcon()
{
	return static_cast<HCURSOR>(m_hIcon);
}



void CconvertDlg::OnBnClickedButton1()
{
	// TODO: 在此添加控件通知处理程序代码
		unsigned char cWaitKeyValue, Rows, Cols;
		src = cvLoadImage("1.png", 1);
		//src = cvCreateImage(cvSize(100, 100), IPL_DEPTH_8U, 1);
		//cvZero(src);
		int nHeight;
		int nWidth;
		nHeight = src -> height;
		nWidth = src -> width;
		char *ptr = NULL;
		for (Cols = ((nWidth / 2) - 25); Cols < ((nWidth / 2) +25); Cols++)
		{
			ptr = src->imageData + Cols * src->widthStep;
			for (Rows = ((nHeight / 2) -25); Rows < ((nHeight / 2) + 25); Rows++)
			{
				ptr[3 * Rows] = 0;//R
				ptr[3 * Rows + 1] = 0;//G
				ptr[3 * Rows + 2] = 0;//B

				//ptr[Rows] = 255;
			}
		}
		cvNamedWindow("Filter", 1);
		cvShowImage("Filter", src);
		cvWaitKey(0);

}




void CconvertDlg::OnBnClickedButton2()
{
	// TODO: 在此添加控件通知处理程序代码
	src1 = cvLoadImage("1.png", 1);
	cvNamedWindow("original", 1);
	cvShowImage("original", src1);
	cvWaitKey(0);

}

运行结果

在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/143083.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 解决修改PyCharm源后添加源信任的问题

    解决修改PyCharm源后添加源信任的问题这里写自定义目录标题问题描述解决办法方法一(临时)方法二WindowsLinuxmacOS问题描述使用PyCharm内置的包管理修改默认源为豆瓣源后出现报错:“Therepositorylocatedatpypi.douban.comisnotatrustedorsecurehostandisbeingignored”解决办法方法一(临时)在选择安装包的右…

    2022年8月28日
    3
  • Java 图片 滑动 解锁「建议收藏」

    Java 图片 滑动 解锁「建议收藏」滑动解锁功能大家都不陌生,类似于如下这种:公司近期也要求实现类似的功能,百度各种文章,总算实现了一个比较糙的版本,保密等原因就不贴完成图了。我觉得难点在于滑块图和背景图的处理。图片处理原理我粗略的理解,图片就是一个二维的直角坐标系的一部分,(x,y)就是对应位置的一个像素点,可以操作某一个像素点,比如改变颜色,设置透明度等。Java中使用BufferedImage完成图…

    2022年6月18日
    40
  • pytest parametrize fixture_pytest参数化可变参数

    pytest parametrize fixture_pytest参数化可变参数前言当某个接口中的一个字段,里面规定的范围为1-5,你5个数字都要单独写一条测试用例,就太麻烦了,这个时候可以使用pytest.mark.parametrize装饰器可以实现测试用例参数化。官方示

    2022年7月31日
    10
  • pycharm安装torch和cuda(在anaconda创建的新环境下)[通俗易懂]

    pycharm安装torch和cuda(在anaconda创建的新环境下)[通俗易懂]pycharm安装torch和cuda(在anaconda创建的新环境下)

    2025年7月29日
    3
  • redis中ziplist

    ziplist是一个压缩的双向列表。传统的双向链表,在每个节点,都需要指向下一个和前一个节点的指针,占据了一定的空间;同时双向链表中使用字符串保存了节点的值,对于整形的数值而言,比较费空间。ziplist在这些方面进行了一些优化。    下面跟着源码来学习下:      结构        其中zlbytes 整个列表所占据的空间。

    2022年4月9日
    50
  • stat函数详解

    Linux系统函数之文件系统管理(二)stat函数​作用:获取文件信息​头文件:include&lt;sys/types.h&gt;#include&lt;sys/stat.h&gt;#include&lt;unistd.h&gt;​函数原型:intstat(constchar*path,structstat*buf)​返回值:成功返…

    2022年4月5日
    47

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号