刚刚给你弄的,有详细过程和源码
1,需求
a,显示圆
b,移动圆
2,概要设计
a,已知圆心和半径,显示圆
b,单击圆开始移动,再次单击结束移动
3,详细设计
a,如果一个点到圆心的距离等于(小于)半径,则在圆上(圆内)。
b,移动过程中以虚线显示。
4,编码
1,新建一个单文档程序Yuan。
2,CYuanView内增加三个变量:
CPoint m_pt;//圆心
int m_iR;//半径
BOOL m_bMove;//是不是在移动
3,构造函数中初始化。
CYuanView::CYuanView()
{
m_pt = CPoint(60,60);
m_iR = 50 ;
m_bMove = FALSE ;
}
4,显示圆
void CYuanView::OnDraw(CDC* pDC)
{
CPen pen(m_bMove?PS_DOT:PS_SOLID,1,RGB(0,0,0));
pDC->SelectObject(&pen);
pDC->Ellipse(m_pt.x-m_iR,m_pt.y-m_iR,m_pt.x+m_iR,m_pt.y+m_iR);
}
5,移动
#include "math.h"
int GetJuLi(const CPoint pt1,const CPoint pt2) //两点间的距离
{
return sqrt((pt1.x-pt2.x)*(pt1.x-pt2.x) + (pt1.y-pt2.y)*(pt1.y-pt2.y));
}
void CYuanView::OnLButtonDown(UINT nFlags, CPoint point)
{
CView::OnLButtonDown(nFlags, point);
if( !m_bMove )
{//开始移动
if(GetJuLi(point,m_pt) <= m_iR)
{
m_pt = point;
m_bMove = TRUE ;
}
}
else
{//结束移动
m_pt = point;
m_bMove = FALSE ;
Invalidate();
}
}
6,移动过程中
void CYuanView::OnMouseMove(UINT nFlags, CPoint point)
{
CView::OnMouseMove(nFlags, point);
if( m_bMove )
{
m_pt = point ;
Invalidate();
}
}
已知问题:
移动开始后无法取消。
源码:
移动位置就是初始(原)位置,减去起点终点的差值。
XFORM g_XF={1,0, 0,1, -1E-8,0,};
int cx=0, cy=0;
2、在WM_PAINT消息中实施坐标变换:
(如果你喜欢用MFC, 大概就在 OnPaint消息处理函数中执行)
::SetGraphicsMode(hdc,GM_ADVANCED); // SetWorldTransform will fail unless the graphics mode for the given device context has been set to GM_ADVANCED.
::SetWorldTransform(hdc,&g_XF);
3、最后处理WM_MOUSEMOVE消息
(如果你喜欢用MFC, 大概就在 OnMouseMove消息处理函数中执行)
case WM_MOUSEMOVE:{
int x=LOWORD(lParam), y=HIWORD(lParam); if(x==cx && y==cy) break;
int dx=x-cx, dy=y-cy;
g_XF.eDx+=dx; g_XF.eDy+=dy;
cx=x; cy=y;
InvalidateRect(hWnd,0,true); return 0;
}break;