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);

}

运行结果

在这里插入图片描述

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • 第十五篇 Python之文件处理

    第十五篇 Python之文件处理一文件操作计算机系统分为:计算机硬件,操作系统,应用程序三部分。我们用python或其他语言编写的应用程序若想要把数据永久保存下来,必须要保存于硬盘中,这就涉及到应用程序要操作硬件,众所周知,应

  • python数组操作方法_python的数组怎么用

    python数组操作方法_python的数组怎么用python列表数组类型,用中括号代表,具有顺序关系,可以修改,是最常用的数组bracket=[‘b’,’r’,’a’,’c’,’k’,’e’,’t’]pyhon元组数组类型,用小括号代表,具有顺序关系,不可以修改,是只读型数组,用来保护不需要改变的数据parentheses=(‘p’,’a’,’r’,’e’,’n’,’t’,’h’,’e’,’s’,’e’,’s’)python字典数组

    2022年10月25日
  • Center OS 7 下的安装Apache「建议收藏」

    Center OS 7 下的安装Apache「建议收藏」使用yum安装,直接yuminstallhttpd

  • hibernate中executeUpdate的缓存问题

    hibernate中executeUpdate的缓存问题解决hibernate批量更新时的缓存问题

    2022年10月20日
  • 离线地图的原理_matplotlib地图

    离线地图的原理_matplotlib地图侵权说明:如文章内容有侵权行为,请联系本人告知,本人会尽快删除修改,避免扩大影响。Bmap说明:Bmap由北京百度网讯科技有限公司提供技术支持为用户提供包括智能路线规划、智能导航(驾车、步行、骑行)、实时路况等出行相关服务的平台。本身并不提供离线功能,因为离线会导致“搜索周边”“搜索路线”“交通状况”等实时性数据要求的功能缺失。Bmap加载原理简图:离线地图…

    2022年10月31日
  • Python框架区别是什么?比较常用的框架有哪些?

    Python框架区别是什么?比较常用的框架有哪些?前言本文的文字及图片来源于网络,仅供学习、交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理。众所周知,Python开发框架大大减少了开发者不必要的重复劳动,提高了项目开发效率的同时,还使得创建的程序更加稳定。目前比较主流的Python框架都有哪些呢?一般大家用的比较多的是Django、Flask、Scrapy、Diesel、Cubes、Pulsar和Tornado。那么这些Python框架的区别是什么呢?下面我们一起来看看这些Python框架的不同适用环境。.

发表回复

您的电子邮箱地址不会被公开。

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