|
【CSplitterWnd技巧三】能拖动的带背景颜色的分割条(2) } CMySplitter::~CMySplitter() { } BEGIN_MESSAGE_MAP(CMySplitter, CSplitterWnd) ON_WM_LBUTTONDOWN() ON_WM_MOUSEMOVE() ON_WM_RBUTTONDOWN() END_MESSAGE_MAP() void CMySplitter::OnLButtonDown(UINT nFlags, CPoint point) { //拖动splitter拖动条,能够拖动窗口 ::PostMessage(AfxGetMainWnd()->GetSafeHwnd(),WM_NCLBUTTONDOWN,HTCAPTION,MAKELPARAM(point.x,point.y)); CWnd::OnLButtonDown(nFlags,point); } void CMySplitter::OnMouseMove(UINT nFlags, CPoint point) { //跳过调用CSplitterWnd::OnMouseMove,因为他会引起光标的改变 CWnd::OnMouseMove(nFlags, point); } BOOL CMySplitter::PreCreateWindow(CREATESTRUCT& cs) { //窗口类名必须在类的域类有效,否则::CreateWindowEx得到的是无效的类名。 //将会导致创建文档失败的错误。 m_clsName = AfxRegisterWndClass(0, ::LoadCursor (NULL, IDC_ARROW), ::CreateSolidBrush(RGB(255,95,17))); cs.lpszClass = (const char* )m_clsName; return CSplitterWnd::PreCreateWindow(cs); } ================================================== 说明: 1,要实现用拖动条拖动窗口,不能简单的用技巧2介绍的OnNcHitTest返回HTCAPTION来解决。因为这样只能拖动分割窗口,不能拖动主窗口。这里用在左键按下的时候 ::PostMessage(AfxGetMainWnd()->GetSafeHwnd(),WM_NCLBUTTONDOWN,HTCAPTION,MAKELPARAM(point.x,point.y)),通过给主窗口发送带HTCAPTION的WM_NCLBUTTONDOWN消息来实现。 2,默认的分割窗口的类名是AfxMDIFrame42d,它和MDI程序中的主窗口差不多,没有背景刷。在这里注册了一个新的窗口类,并指定了背景刷。要注意的是,窗口类名不能在PreCreateWindow中申明,应该放在类的申明中,作为类的成员函数。
|