按键盘上方向键 ← 或 → 可快速上下翻页,按键盘上的 Enter 键可回到本书目录页,按键盘上方向键 ↑ 可回到本页顶部!
————未阅读完?加入书签已便下次继续阅读!
要将每一步长设定的太大或太小。)
SetPos:指定滑块控件滑块的位置。
void SetPos( int nPos ):参数nPos指定滑块控件滑块的新位置并
将滑块移至该位置。
SetSelection:指定滑块控件中当前可选的范围 (在当前滑块控件中
指定。)
void SetSelection( int nMin; int nMax ):二参数指定变化范围
的最小,最大值。如果需要在设置时便显示选择的范围,应该在调用
该函数后立即调用函数Invalidate对滑块控件进行重绘。否则,滑块
控件在设定选择范围后选择范围并不在滑块控件中显示。(但在窗口
重绘时该范围将被指示出。)
ClearSelection:清除选择范围。
void ClearSel( BOOL bRedraw = FALSE ):bRedraw指明在清除选择
范围后滑块控件是否重绘。当其为TRUE时选择范围的失去立即显示出
来,为FALSE时则选择范围指示只能在窗口进行重绘时被清除。
在本节的最后,我们讲一下滑块控件的消息处理。在前面的介绍中,
我们已经提到,对于滑块控件我们所需要处理的消息很少。通过
Spy++监视我们可以看出的确如此。下面,我们就来看看消息
WM_HSCROLL (对水平滑块控件,对竖直滑块控件消息应为
WM_VSCROLL;但由于它们的处理近似,在下面的介绍中我们仅以水平
滑块控件为例进行讲解)的处理。
首先我们必须辨别清楚消息WM_HSCROLL是否为我们所期望的滑块控件
发出。在例程中,我们使用了下面的代码进行识别:
// 。。。
CSliderCtrl *pSlider=(CSliderCtrl *)pScrollBar;
if(pSlider==&m_TrackBar)
// 。。。
在这段代码中,我们首先对程序发送的消息进行转换,这在第一条语
句中完成。它将该消息转换为工具条消息。然后,在紧跟着的一条语
句中,我们判断该滑块控件消息究竟是那一个滑块控件发出的。(毕
竟,在该窗口中,很有可能不止一个滑块控件 !)
…………………………………………………………Page 275……………………………………………………………
接下来,我们就可以对该消息进行分类处理了。在我们的程序中,为
了简单起见,对每一个消息,我们简单的调用宏TRACE将用户的选择
输出。在用户的程序中,可能需要对它们进行别的更有意义的处理,
在这里就不详述了。至于对该控制的各个消息的具体含义,读者结合
其名称 自不难理解。
l 注意:
l 宏TRACE有些类似于C语言的标准格式化输出函数printf,它能一
次输 出不超过256个字符 (超过此限制时导致一个ASSERT被发
出)。利用它,我们可以很方便地对程序进行调试。但需要注意
的是,该宏仅仅在程序调试状态下起作用,在程序的发行版中,
该宏被展开为空。
// TrackBarDlg。cpp : implementation file
//
#include 〃stdafx。h〃
// 。。。。
//以上部分为AppWizard生成的标准代码,从略
// 。。。
BEGIN_MESSAGE_MAP(CTrackBarDlg; CDialog)
//{{AFX_MSG_MAP(CTrackBarDlg)
ON_WM_SYSMAND()
ON_WM_PAINT()
ON_WM_QUERYDRAGICON()
ON_WM_HSCROLL()
ON_BN_CLICKED(IDC_CLEAR_BUTTON; OnClearButton)
ON_BN_CLICKED(IDC_SET_BUTTON; OnSetButton)
//以上三处为我们通过ClassWizard加入的消息响应
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
…………………………………………………………Page 276……………………………………………………………
// CTrackBarDlg message handlers
BOOL CTrackBarDlg::OnInitDialog()
{
CDialog::OnInitDialog();
// Add 〃About。。。〃 menu item to system menu。
// IDM_ABOUTBOX must be in the system mand range。
ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
ASSERT(IDM_ABOUTBOX 《 0xF000);
// 。。。
SetIcon(m_hIcon; FALSE); // Set small icon
// TODO: Add extra initialization here
m_TrackBar。SetRange(10;100);
m_TrackBar。SetTicFreq(10);
m_TrackBar。SetPos(10);
char szBuffer'81';
sprintf(szBuffer;〃10〃);
m_EditControl。SetWindowText(szBuffer);
//此处为编辑框控制处理,在学习完第四章后,读者应该已经能理解上述代码
return TRUE; // return TRUE unless you set the focus to a control
//Exception:OCX Property Pages should return FALSE
}
//下面为一系统消息处理范例
void CTrackBarDlg::OnSysmand(UINT nID; LPARAM lParam)
{
if ((nID & 0xFFF0) == IDM_ABOUTBOX)
{
…………………………………………………………Page 277……………………………………………………………
CAboutDlg dlgAbout;
dlgAbout。DoModal();
}
else
{
CDialog::OnSysmand(nID; lParam);
}
}
// If you add a minimize button to your dialog; you will need the code below
// to draw the icon。 For MFC applications using the document/view model;
// this is automatically done for you by the framework。
void CTrackBarDlg::OnPaint()
{
if (IsIconic())
{
// 。。。。
}
else
{
// 。。。
}
//假如在滑块控件中没有在设置范围后立即重绘,建议读者仔细看一下上面代码
}
// The system calls this to obtain the cursor to display while the user drags
// the minimized window。
HCURSOR CTrackBarDlg::OnQueryDragIcon()
…………………………………………………………Page 278……………………………………………………………
{
return (HCURSOR) m_hIcon;
}
void CTrackBarDlg::OnHScroll(UINT nSBCode; UINT nPos; CScrollBar* pScrollBar)
{
// TODO: Add your message handler code here and/or call default
//the trackbar sends an WM_HSCROLL(or WM_VSCROLL if the trackbar is vertical)
//message telling the position of the slider has changed!
//this iagnostic message shows what parameters are passed to our OnHScroll()
//handler
char szBuffer'81';
CSliderCtrl *pSlider=(CSliderCtrl *)pScrollBar;
if(pSlider==&m_TrackBar)
{
switch(nSBCode)
{
case TB_BOTTOM:TRACE(〃TB_BOTTOM n〃);break;
case TB_TOP:TRACE(〃TB_TOPn〃);break;
case TB_ENDTRACK:TRACE(〃TB_ENDTRACK n〃);break;
case TB_LINEDOWN:TRACE(〃TB_LINEDOWN n〃);break;
case TB_LINEUP:TRACE(〃TB_LINEUP n〃);break;
case TB_PAGEDOWN:TRACE(〃TB_PAGEDOWN n〃);break;
case TB_PAGEUP:TRACE(〃TB_PAGEUP n〃);break;
case TB_THUMBPOSITION:TRACE(〃TB_THUMBPOSITION n〃);break;
case TB_THUMBTRACK:TRACE(〃TB_THUMBTRACK n〃);break;
default:
…………………………………………………………Page 279……………………………………………………………
TRACE(〃