MFC下CPictureCtrl控件基于鼠标左键坐标的直线绘图

这篇具有很好参考价值的文章主要介绍了MFC下CPictureCtrl控件基于鼠标左键坐标的直线绘图。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

本文仅供学习交流,严禁用于商业用途,如本文涉及侵权请及时联系本人将于及时删除

目录

1.创建自定义类CMyPictureCtrl

2.布局Dlg

3.实验代码

4.运行结果


在基于对话框的MFC应用程序中,通过鼠标操作获取坐标并在CPictureCtrl控件中使用LineTo()函数画直线,涉及以下几个关键步骤:

1.创建自定义类CMyPictureCtrl

创建一个自定义类CMyPictureCtrl,继承自CPictureCtrl(一般继承自CStaic),以便重写绘图方法。并且重载OnPoint()函数,并自定义CPoint m_startPoint, m_endPoint分别用于接受线段的起点、终点坐标值。

//头文件如下
#pragma once
#include "afxwin.h"
class CMyPictureCtrl :
	public CStatic
{
public:
	CMyPictureCtrl();
	~CMyPictureCtrl();
	DECLARE_MESSAGE_MAP()
	afx_msg void OnPaint();
public:
	CPoint m_startPoint, m_endPoint;
};
//源文件如下
#include "stdafx.h"
#include "MyPictureCtrl.h"


CMyPictureCtrl::CMyPictureCtrl()
{
}


CMyPictureCtrl::~CMyPictureCtrl()
{
}
BEGIN_MESSAGE_MAP(CMyPictureCtrl, CStatic)
	ON_WM_PAINT()
END_MESSAGE_MAP()


void CMyPictureCtrl::OnPaint()
{
	CPaintDC dc(this); // device context for painting
	// TODO:  在此处添加消息处理程序代码
	// 不为绘图消息调用 CStatic::OnPaint()
	//设置绘图属性 颜色  线宽等等
	dc.SelectStockObject(BLACK_BRUSH);//选择黑色画刷为背景色
	dc.SetBkMode(TRANSPARENT);//设置透明背景模式

	//此处是否需要判断Cpoint两个点为空
	dc.MoveTo(m_startPoint);
	dc.LineTo(m_endPoint);

}

2.布局Dlg

在主对话框中创建CPictureCtrl,控件并绑定自变量(自变量类型为CMyPictureCtrl)

MFC下CPictureCtrl控件基于鼠标左键坐标的直线绘图,C++,mfc,c++

MFC下CPictureCtrl控件基于鼠标左键坐标的直线绘图,C++,mfc,c++

3.实验代码

在主对话框中重载OnMouseMove()、OnLButtonDown()函数

// 画图Dlg.h : 头文件
//

#pragma once
#include "afxwin.h"
#include "MyPictureCtrl.h"


// C画图Dlg 对话框
class C画图Dlg : public CDialogEx
{
// 构造
public:
	C画图Dlg(CWnd* pParent = NULL);	// 标准构造函数

// 对话框数据
	enum { IDD = IDD_MY_DIALOG };

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


// 实现
protected:
	HICON m_hIcon;

	// 生成的消息映射函数
	virtual BOOL OnInitDialog();
	afx_msg void OnSysCommand(UINT nID, LPARAM lParam);
	afx_msg void OnPaint();
	afx_msg HCURSOR OnQueryDragIcon();
	DECLARE_MESSAGE_MAP()
public:
	CStatic m_picture;
	CDC * pDC;
	afx_msg void OnBnClickedBtn1();
	afx_msg void OnBnClickedBtnBack();
	CMyPictureCtrl m_mypicture;
	
	afx_msg void OnLButtonDblClk(UINT nFlags, CPoint point);
	afx_msg void OnLButtonUp(UINT nFlags, CPoint point);
	afx_msg void OnLButtonDown(UINT nFlags, CPoint point);
	afx_msg void OnMouseMove(UINT nFlags, CPoint point);
};
// 画图Dlg.cpp : 实现文件
//

#include "stdafx.h"
#include "画图.h"
#include "画图Dlg.h"
#include "afxdialogex.h"
#include <cmath>
#include "MyPictureCtrl.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#endif


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

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

// 对话框数据
	enum { IDD = IDD_ABOUTBOX };

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

// 实现
protected:
	DECLARE_MESSAGE_MAP()
};

CAboutDlg::CAboutDlg() : CDialogEx(CAboutDlg::IDD)
{
}

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

BEGIN_MESSAGE_MAP(CAboutDlg, CDialogEx)
END_MESSAGE_MAP()


// C画图Dlg 对话框



C画图Dlg::C画图Dlg(CWnd* pParent /*=NULL*/)
	: CDialogEx(C画图Dlg::IDD, pParent)
{
	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
}

void C画图Dlg::DoDataExchange(CDataExchange* pDX)
{
	CDialogEx::DoDataExchange(pDX);
	DDX_Control(pDX, IDC_PICTURE, m_picture);
	DDX_Control(pDX, IDC_MY_PIC, m_mypicture);
}

BEGIN_MESSAGE_MAP(C画图Dlg, CDialogEx)
	ON_WM_SYSCOMMAND()
	ON_WM_PAINT()
	ON_WM_QUERYDRAGICON()
	ON_BN_CLICKED(IDC_BTN1, &C画图Dlg::OnBnClickedBtn1)
	ON_BN_CLICKED(IDC_BTN_BACK, &C画图Dlg::OnBnClickedBtnBack)
	ON_WM_LBUTTONDBLCLK()
	ON_WM_LBUTTONUP()
	ON_WM_LBUTTONDOWN()
	ON_WM_MOUSEMOVE()
END_MESSAGE_MAP()


// C画图Dlg 消息处理程序

BOOL C画图Dlg::OnInitDialog()
{
	CDialogEx::OnInitDialog();

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

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

	CMenu* pSysMenu = GetSystemMenu(FALSE);
	if (pSysMenu != NULL)
	{
		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:  在此添加额外的初始化代码
	
	pDC = m_picture.GetDC();                       //获得设备上下文
	CRect rc, rect;
	m_picture.GetClientRect(rect);               //获得控件客户区域
	m_picture.GetWindowRect(rc);                 //获得控件窗口区域
	pDC->FillRect(rect, NULL);                    //填充区域
	//取出中心点
	CPoint center;
	center.x = rc.Width() / 2;
	center.y = rc.Height() / 2;
	pDC->SetViewportOrg(center);                 //设置原点




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

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

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

void C画图Dlg::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 C画图Dlg::OnQueryDragIcon()
{
	return static_cast<HCURSOR>(m_hIcon);
}



void C画图Dlg::OnBnClickedBtn1()
{
	// TODO:  在此添加控件通知处理程序代码
	int r = 180, n = 10;
	CPoint P[10];//用于存放顶点数组
	double PI = 3.14;
	double Theta = 2 * PI / n;
	for (int i = 0; i < n; i++)
	{
		//记得包含应用#include<cmath> 头文件
		P[i].x = round(r*cos(i*Theta));
		P[i].y = round(r*sin(i*Theta));
	}
	for (int i = 0; i <= n - 2; i++)
	{
		for (int j = i + 1; j <= n - 1; j++)
		{
			pDC->MoveTo(P[i]);
			pDC->LineTo(P[j]);
		}
	}
}


void C画图Dlg::OnBnClickedBtnBack()
{
	// TODO:  在此添加控件通知处理程序代码
	delete pDC; //释放内存空间,指示系统随时可回收内存,指针指向地址不变
	pDC = NULL;
	this->DestroyWindow();
}


void C画图Dlg::OnLButtonDblClk(UINT nFlags, CPoint point)
{
	// TODO:  在此添加消息处理程序代码和/或调用默认值

	CDialogEx::OnLButtonDblClk(nFlags, point);
}


void C画图Dlg::OnLButtonUp(UINT nFlags, CPoint point)
{
	 TODO:  在此添加消息处理程序代码和/或调用默认值
	//if (nFlags&MK_LBUTTON)
	{
	//m_mypicture.m_endPoint = point;
	//m_mypicture.Invalidate();//触发控件重绘
	}


	CDialogEx::OnLButtonUp(nFlags, point);
}


void C画图Dlg::OnLButtonDown(UINT nFlags, CPoint point)
{
	// TODO:  在此添加消息处理程序代码和/或调用默认值
	//m_mypicture.m_startPoint = m_mypicture.m_endPoint = point;
	m_mypicture.m_startPoint = point;
	//m_mypicture.Invalidate();//初始位置绘制,//触发控件重绘

	CDialogEx::OnLButtonDown(nFlags, point);
}


void C画图Dlg::OnMouseMove(UINT nFlags, CPoint point)
{
	// TODO:  在此添加消息处理程序代码和/或调用默认值
	//if (nFlags&MK_LBUTTON)//如果左键按下
	if (nFlags&MK_LBUTTON)
	{
		m_mypicture.m_endPoint = point;
		m_mypicture.Invalidate();//触发控件重绘
	}
	CDialogEx::OnMouseMove(nFlags, point);
}

4.运行结果

MFC下CPictureCtrl控件基于鼠标左键坐标的直线绘图,C++,mfc,c++文章来源地址https://www.toymoban.com/news/detail-857279.html

到了这里,关于MFC下CPictureCtrl控件基于鼠标左键坐标的直线绘图的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • OpenCV学习(三)——响应鼠标事件(获取点击点坐标和颜色,利用鼠标进行绘图)

    使用OpenCV读取图像,可以在读取图像的窗口通过鼠标点击可以实现:获取鼠标点击像素点的坐标、获取鼠标点击像素点的颜色和在鼠标点击的像素点生成圆等等。 winname:窗口的名字 callback:回调函数 userdata:给回调函数的参数 enent:鼠标事件 x:横坐标 y:纵坐标 flags:事件

    2024年02月08日
    浏览(92)
  • mfc 动态加载dll库,Mat转CImage,读ini配置文件,鼠标操作,在edit控件上画框,调试信息打印

    h文件中添加 cpp文件中添加 左键按下弹起,右键按下弹起 TRACE(\\\"temp= %dn\\\", temp);

    2024年02月07日
    浏览(46)
  • MFC List Control 上实现左键框选

    本文主要实现了在list control 上进行框选,获得框选区域的左上角及右下角位置坐标。 1、添加 List Control 控件ID设为IDC_Listcontrol 2、给控件添加变量 m_list 3、在头文件中定义:                                                                                         

    2024年02月04日
    浏览(27)
  • 点到直线垂足坐标的计算

            假设空间某点O的坐标为(Xo, Yo, Zo),空间某条直线上两点A和B的坐标为:(X1, Y1, Z1),(X2, Y2, Z2),设点O在直线AB上的垂足为点N,坐标为(Xn, Yn, Zn)。点N坐标解算过程如下: 首先求出下列向量: 由向量垂直关系,两个向量如果垂直,那么两个向量的点积(点乘,向量积)

    2024年02月11日
    浏览(54)
  • winapi模拟鼠标按住左键拖动

            继前文《windows下通过uiAutomation技术获取ui元素》介绍获取ui元素信息后,还需要对信息进行修改,但是 uiAutomation 技术并未提供可修改的 api ,只能另辟他径看看了。         以 camera raw 为例,已知的是可将鼠标放在指定区域位置,然后按下左键并左右拖动,也

    2024年02月16日
    浏览(41)
  • Unity 实现鼠标左键进行射击

    发射脚本实现思路 分析 确定用户交互方式:通过鼠标左键点击发射子弹。 确定子弹发射逻辑:每次点击后有一定时间间隔才能再次发射。 确定子弹发射源和方向:子弹从枪口(Transform)位置发射,沿枪口方向前进。 变量设定 设定子弹预制体引用:用于在游戏中实例化子弹

    2024年04月11日
    浏览(38)
  • Qt 鼠标左键推拽界面

    代码实现: button 返回 哪个按钮造成了此事件, buttons 返回 发生此事件时哪些按钮还处于按下状态 appinitdrag.h appinitdrag.cpp 在 main.cpp 里添加 appinitdrag.h ,然后在要设定拖拽的 widget 窗口的构造函数里添加代码

    2024年02月04日
    浏览(46)
  • 鼠标连点器(VB.net 全局键盘钩子+模拟鼠标 左键、右键)

    相信大家在玩游戏的时候会把 “攻击” 设置为鼠标左键,但是自己手速不够快,被人家秒了 废话不多说,立马进入主题: 一、新建一个vb.net工程(窗体应用程序) 大概是这样,timer1控制鼠标左键,timer2控制鼠标右键 二、新建一个模块(Module1.vb) 写入:注意,本模块由C

    2024年02月09日
    浏览(61)
  • vscode ctrl+鼠标左键没反应

    vscode刚开始用的好好地,有一天突然发现按ctrl+鼠标左键无法跳转到函数,我就知道我要踩坑了 重装vscode,重启电脑,按照百度折腾了一个小时还是没搞定,最后迫于无奈加了个go的开发群问了下,有一个大佬说了两种可能,特此记录下 可能的原因 原因一: vscode当前存储的

    2024年02月12日
    浏览(52)
  • Unity(六)--绑定鼠标点击事件(左键、右键、中键)

    新建一个脚本buttonEvent:

    2024年02月01日
    浏览(55)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包