温习MFC画图——附带源码

void CDrawView::OnLButtonDown(UINT nFlags, CPoint point)
{
	//MessageBox(L"Button Clicked !");  //unicode
	//MessageBox("Button Clicked !");     //使用多字节

	m_ptOrign=point;
	m_ptOld=point;
	m_bDraw=true;
	CView::OnLButtonDown(nFlags, point);
}


void CDrawView::OnLButtonUp(UINT nFlags, CPoint point)
{
	获得窗口的设备描述表
	/*HDC hdc;
	hdc=::GetDC(m_hWnd);
	MoveToEx(hdc,m_ptOrign.x,m_ptOrign.y,NULL);
	LineTo(hdc,point.x,point.y);
	::ReleaseDC(m_hWnd,hdc);*/
	//使用CDC类
	/*CDC *pDC=GetDC();
	pDC->MoveTo(m_ptOrign);
	pDC->LineTo(point);
	ReleaseDC(pDC);*/

	//使用画笔、画刷
	/*CPen pen(PS_SOLID,1,RGB(234,23,53));
	//定义一个CPen类对象,并利用RGB宏改变其颜色
	CClientDC dc(this);
	CPen *pOldPen=dc.SelectObject(&pen); //将其选入设备表
	dc.MoveTo(m_ptOrign);
	dc.LineTo(point);
	dc.SelectObject(pOldPen); */ 
	/
	/*CBrush brush(RGB(0,255,0)); 
	CClientDC dc(this); 
	CRect rect(m_ptOrign,point); 
	//dc.FillRect(&rect,&brush); 
	dc.SelectObject(&brush);
	dc.Rectangle(m_ptOrign.x,m_ptOrign.y,point.x,point.y);
	*/
	m_ptEnd=point;
	m_bDraw=false;

	CView::OnLButtonUp(nFlags, point);
}


void CDrawView::OnMouseMove(UINT nFlags, CPoint point)
{
	/*CClientDC dc(this);
	CPen pen(PS_SOLID,1,RGB(255,0,0));
	CPen *poldPen=dc.SelectObject(&pen); //将其选入设备表
	//if (m_bDraw==TRUE)
	//{
	//	dc.MoveTo(m_ptOrign);
	//	dc.LineTo(point);
	//	//m_ptOrign=point;  //注释掉就变成扇形曲线	
	//}

	if (m_bDraw==TRUE)      //带外包线的扇形
	{
		dc.MoveTo(m_ptOrign);
		dc.LineTo(m_ptOld);
		dc.MoveTo(m_ptOld);
		dc.LineTo(point);
		m_ptOld=point;
	}*/

	//画无边框矩形,利用FillRect函数填充矩形。填充内容为画刷的内容,即画刷对象的指针。
	/*CClientDC dc(this);
	CBrush brush(RGB(5,255,255));
	dc.FillRect(CRect(m_ptOrign,point),&brush);*/

	//以位图作为画刷的资源
	/*CClientDC dc(this);
	CBitmap bitmap;
	bitmap.LoadBitmap(IDB_FILE_VIEW);
	CBrush brush(&bitmap);
	dc.FillRect(CRect(m_ptOrign,point),&brush);*/

	//画有边框的矩形,方法说明:利用Rectangle方法来画矩形。其中CBrush与CPen类分别负责矩形内部和矩形边框的属性
	//画中心为白色的矩形
	/*CClientDC dc(this);
	//dc.Rectangle(CRect(m_ptOrign,point));
	dc.Rectangle(m_ptOrign.x,m_ptOrign.y,point.x,point.y);
	*/

	//画中心为透明的矩形
	/*CClientDC dc(this);
	CBrush *pbrush=CBrush::FromHandle((HBRUSH)GetStockObject(NULL_BRUSH));
	CBrush *pOldbrush=dc.SelectObject(pbrush);  //将其选入设备表
	//dc.Rectangle(CRect(m_ptOrign,m_ptEnd));
	dc.Rectangle(CRect(m_ptOrign,point));
	pOldbrush=pbrush;*/

	//画中心为透明边为任意颜色的矩形
	/*CClientDC dc(this);
	CBrush *pbrush=CBrush::FromHandle((HBRUSH)GetStockObject(NULL_BRUSH));
	CBrush *pOldbrush=dc.SelectObject(pbrush);  //将其选入设备表
	CPen pen(PS_SOLID,1,RGB(234,23,53));
	CPen *poldpen=dc.SelectObject(&pen);  //将其选入设备表
	dc.Rectangle(CRect(m_ptOrign,point));
	dc.SelectObject(poldpen);
	dc.SelectObject(pOldbrush);
	*/
	CView::OnMouseMove(nFlags, point);
}

http://blog.csdn.net/muzi9_17/article/details/6376922

绘制任意线条:

1、创建基于单文档工程:Draw

CDrawView类中添加成员变量:

CPoint m_ptOrigin;

BOOL m_bDraw;

2、CDrawView()中初始化:

m_ptOrigin = point;

m_bDraw = false;

3、添加消息响应函数:

WM_LBUTTONDOWN    WM_LBUTTONUP  WM_MOUSEMOVE

4、左键按下时:

m_ptOrigin = point;

m_bDraw = true;

5、左键抬起:

m_bDraw = false;

6、鼠标移动时:

    //画连续线条

CClientDC dc(this);

if(m_bDraw)

    {

       dc.MoveTo(m_ptOrigin);

       dc.LineTo(point);

       m_ptOrigin = point;

    }

    //画扇形线条

CClientDC dc(this);

    if(m_bDraw)

    {

       dc.MoveTo(m_ptOrigin);

       dc.LineTo(point);

    }

    //画带外包线的扇形线条

析:画带外包线的扇形线条,不光记录初始位置,还要记录鼠标移动上一位置。

添加成员变量:

CPoint m_ptOld;

在鼠标左键按下时初始化:

m_ptOld = point;

在鼠标移动时进行改变:

CClientDC dc(this);

    if(m_bDraw)

    {

       dc.MoveTo(m_ptOrigin);

       dc.LineTo(m_ptOld);

       dc.MoveTo(m_ptOld);

       dc.LineTo(point);

       m_ptOld = point;

    }

画矩形:

画无边框的矩形

方法说明:利用FillRect函数填充矩形。填充内容为画刷的内容,即画刷对象的指针。

     CBrush brush(RGB(5,255,255));

     CClientDC dc(this);

     dc.FillRect(CRect(m_ptOrigin,point),&brush);

以位图作为画刷的资源

     CBitmap bitmap;

     bitmap.LoadBitmap(IDB_BITMAP1); 

     CBrush brush(&bitmap);

     CClientDC dc(this);

     dc.FillRect(CRect(m_ptOrigin,point),&brush);

画有边框的矩形

方法说明:利用Rectangle方法来画矩形。其中CBrush与CPen类分别负责矩形内部和矩形边框的属性

     //画中心为白色的矩形

     CClientDC dc(this);

     dc.Rectangle(CRect(m_ptOrigin,point));

 

     //画中心为透明的矩形

     CClientDC dc(this);

CBrush *pBrush=CBrush::FromHandle((HBRUSH)

GetStockObject(NULL_BRUSH));

     CBrush *pOldBrush=dc.SelectObject(pBrush);

     dc.Rectangle(CRect(m_ptOrigin,point));

     pOldBrush=pBrush;

 

//画中心为透明边为任意颜色的矩形

     CClientDC dc(this);

     CPen pen(PS_SOLID,1,RGB(234,23,53));

     CPen *pOldPen=dc.SelectObject(&pen);

     CBrush *pBrush=CBrush::FromHandle((HBRUSH)

GetStockObject(NULL_BRUSH))

     CBrush *pOldBrush=dc.SelectObject(pBrush);

     dc.Rectangle(CRect(m_ptOrigin,point));

     dc.SelectObject(pOldPen);

     dc.SelectObject(pOldBrush);

 

使用画笔、画刷

在OnLButtonUp函数中:

/

CPen pen(PS_SOLID,1,RGB(234,23,53));

//定义一个CPen类对象,并利用RGB宏改变其颜色

CClientDC dc(this);

CPen *pOldPen=dc.SelectObject(&pen); //将其选入设备表

dc.MoveTo(m_ptOrigin);

dc.LineTo(point);

dc.SelectObject(pOldPen); 

/

CBrush brush(RGB(0,255,0)); 

CClientDC dc(this); 

CRect rect(m_ptOrigin,point); 

dc.FillRect(&rect,&brush); 

/

使用位图创建画刷:

插入->资源->位图->引入,可以引入位图,初始一般命名为:IDB_BITMAP1

CBitmap bitmap; 

bitmap.LoadBitmap(IDB_BITMAP1); 

CBrush brush(&bitmap); 

CClientDC dc(this); 

CRect rect(m_ptOrigin,point); 

dc.FillRect(&rect,&brush);

/

CBrush *brush; 

brush = CBrush::FromHandle((HBRUSH)GetStockObject(NULL_BRUSH));

CClientDC dc(this); 

CBrush *pOldBrush =dc.SelectObject(brush) ;  

dc.Rectangle(CRect(m_ptOrigin,point)); 

dc.SelectObject(pOldBrush) ; 

注:

常用的绘图设备类对象的创建和将其引入到设备环境中的方法

在选择绘图设备类对象(GDI对象)进行绘图时,一般可按下列步骤进行:

(1)定义一个GDI对象,然后调用相应的函数(如CreatePen、CreateSolidBrush等)创建此GDI对象。

(2)将已构造出的GDI对象利用设备环境类对象的成员函数SelectObject选入到当前环境中,并同时将原来的GDI对象保存起

来。

(3)绘图结束后,恢复当前设备环境中原来的GDI对象。

注意:在Windows系统中包含了一些库存的GDI对象,在第(3)步中可直接利用设备环境类(CDC)的成员函数

SelectStockObject将一个Windows库存的GDI对象选入,系统可自动将原来选入的GDI对象从设备环境中分离出来。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值