使用MFC重绘CSliderCtrl时啥时候收到NM_CUSTOMDRAW消息?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用MFC重绘CSliderCtrl时啥时候收到NM_CUSTOMDRAW消息?相关的知识,希望对你有一定的参考价值。
使用MFC重绘CSliderCtrl时什么时候收到NM_CUSTOMDRAW消息?我在自绘CSliderCtrl时添加了该消息的响应函数onCustomDraw,但是却始终没有执行,我用MessageBox测试,没有执行该函数,是不是需要设置什么属性啊?或者更改style?
ON_NOTIFY_REFLECT(NM_CUSTOMDRAW, &CMyListCtrl::OnNMCustomdraw)ON_NOTIFY : Comes from a child control to the parent. This macro goes in the parent's message map.
ON_NOTIFY_REFLECT: Comes from a child control, but is "reflected" back to the child (by the parent)so the child can handle its own notification. This macro goes in the child's message map.
ON_NOTIFY_REFLECT_EX: Same as previous, except that the handler function returns a BOOL, indicating whether or not the message should be routed on to parent classes for possible handlers. Note that the reflected message is handled before the notification message.
我的理解就是一般情况下,ON_NOTIFY是子控件把消息发送给父窗口,由父窗口来处理消息,消息处理函数在父控件的类里面。
如果用了ON_NOTIFY_REFLECT反射,就是说这个消息由子窗口自己来处理
最后再附赠你一个ON_NOTIFY_REFLECT_EX,你仔细观察的话的话会发现很多消息反射形如ON_COMMAND, ON_NOTIFY, ON_RANGE等等,它们都有个扩展形式ON_COMMAND_EX, ON_NOTIFY_EX, ON_RANGE_EX, 微软这么干有什么意图呢,就是这样的:如果你的ON_NOTIFY_REFLECT_EX(消息, 消息处理函数)中的第二个参数也就是消息处理函数的返回值是bool类型的,且返回值是TRUE,那么就是说这个消息会既发给子控件又发给父窗口,即又在子控件里处理该消息,又在父窗口里处理该消息,如果返回值是FLASE的话或者是其他类型的返回值的话,就只发给子控件了,这个时侯ON_NOTIFY_REFLECT_EX就相当于ON_NOTIFY_REFLECT。
ON_COMMAND_EX等同理。 参考技术A 楼主学习MFC用的什么书啊?
在MFC应用程序中的CStatusBar中添加CSliderCtrl
我想在CSliderCtrl
添加到CStatusBar
。为此 - 在CMainFrame类中创建了CSliderCtrl - 在CMainFrame::OnCreate()
中添加了用于创建状态栏和滑块控件的代码
bStatus = m_ZoomSlider.Create(
WS_CHILD | WS_VISIBLE,
CRect(0, 0, 100, 30),
&m_StatusBar,
56666);
事情很好。
现在我希望此滑块位于状态栏的右侧。为此,我在状态栏中添加了一个INDICATOR,我试图得到这个指标的矩形并将滑块放在那个矩形上。
CRect rectSlider;
m_StatusBar.GetItemRect(1, &rectSlider);
bStatus = m_ZoomSlider.Create(
WS_CHILD | WS_VISIBLE,
rectSlider,
&m_StatusBar,
56666);
这里rectSlider具有负值,导致滑块不可见。
我需要知道这是否是这样做的正确方法。任何建议的建议都会非常有帮助。
我正在使用Visual Studio 2005。
我想你应该使用GetRect而不是GetItemRect
无法显示滑块控件,因为其Z顺序不正确。因此,重新调整大小以正确重新定位滑块。 &CWnd :: wndTop表示将窗口放在Z顺序的顶部 首先,在MainFrame.h中定义CSliderCtrl * m_pZoomSlider以下代码使用延迟初始化模式:在需要时初始化,在销毁帧时释放分配的内存。
BEGIN_MESSAGE_MAP(CMainFrame, CFrameWnd)
...
ON_WM_SIZE()
END_MESSAGE_MAP()
void CMainFrame::SetSliderPosition(int pos)
{
if (!m_pZoomSlider) {
CRect rectSlider;
m_wndStatusBar.GetItemRect(1, &rectSlider);
rectSlider.DeflateRect(1, 1); // 1 pixel border...
m_pZoomSlider = new CSliderCtrl();
m_pZoomSlider->Create(WS_CHILD | WS_VISIBLE, rectSlider, &m_wndStatusBar, ID_INDICATOR_SCALE_SLIDER);
m_pZoomSlider->SetRange(1, 100);
}
RECT rc;
m_wndStatusBar.GetItemRect(pos, &rc);
// Reposition the slider control correctly!
m_pZoomSlider->SetWindowPos(&CWnd::wndTop, rc.left, rc.top, rc.right - rc.left, rc.bottom - rc.top, 0);
}
void CMainFrame::OnSize(UINT nType, int cx, int cy)
{
CFrameWnd::OnSize(nType, cx, cy);
SetSliderPosition(1); //index of indicator of status bar
}
BOOL CMainFrame::DestroyWindow()
{
if (m_pZoomSlider) {
m_pZoomSlider->DestroyWindow();
delete m_pZoomSlider;
}
return CFrameWnd::DestroyWindow();
}
以上是关于使用MFC重绘CSliderCtrl时啥时候收到NM_CUSTOMDRAW消息?的主要内容,如果未能解决你的问题,请参考以下文章