您的位置:首页 > 编程语言 > C语言/C++

VC++ 中滑动条(slider控件)使用 [转+补充]

2013-12-31 01:49 344 查看
滑动控件slider是Windows中最常用的控件之一。一般而言它是由一个滑动条,一个滑块和可选的刻度组成,用户可以通过移动滑块在相应的控件中显示对应的值。通常,在滑动控件附近一定有标签控件或编辑框控件,用于显示相应的值。滑动控件在应用程序中用途级为广泛,如在桌面的属性中就可以看到。为此,让我们一起来看一下它的实现方法。

(1)在VC++ 2008中新建一个对话框文档的工程。

(2)打开资源管理器,在对话框中放置一个EDIT控件,然后在它旁边放上一个Slider控件。基本的框架已经完成了。

(3)对Slider控件右击,选择“建立类向导”,对刚才的Slider控件定义一个变量m_Slider,类型为CSliderCtrl。

(4)在对话框初始化的代码BOOL CMyTestDlg::OnInitDialog(),后添加相应的属性。

以下是常用的属性设置函数:

  * GetRange,SetRange函数

  用于查询和设置滑动条的取值范围,默认为0~100。函数定义形式如下:

void GetRange(int &nMin,int &nMax) const;
void SetRange(int nMin,int nMax,BOOL bRedrGETaw=FALSE);

  * GetPos,SetPos函数

  用于查询和设置滑动条的当前值。函数定义形式如下:

int GetPos() const;
int SetPos(int nPos);

  * GetLineSize,SetLineSize函数

  用于查询和设置在按一下右或左箭头时滑块的移动量,默认为1个单位。函数定义形式如下:

int GetLineSize() const;
int SetLineSize(int nSize);

  * GetPageSize,SetPageSize函数

  用于查询和设置函滑块和块移动量,块移动量是指当按下PgUp或PgDown时滑块的移动量。函数定 义形式如下:

int GetPageSize() const;
int SetPageSize(int nSize);

  * SetTicFreq函数

  用于设置滑动条刻度的频度。默认为一个单位一个函数。函数定义形式如下:

void SetTicFreq(int nFreq);

  * SetTic函数

  用于在指定的位置设置刻度。Windows默认的刻度是均匀的。函数定义形式如下:

BOOL SetTic(int nTic);

  * ClearTics函数

  用于清除所有的刻度。函数定义形式如下:

void ClearTics(BOOL bRedraw=FALSE);

//对话框类初始化
BOOL CMyTestDlg::OnInitDialog()

{
CDialog::OnInitDialog();

// TODO:  在此添加额外的初始化
m_Slider.SetRange(-100,100);
m_Slider.SetPos(-21);
m_Slider.SetTicFreq(10);//需要在slider控件属性栏中,将Auto ticks, Tick Marks两项设为True

//m_Slider.EnableWindow(FALSE);//初始化Slider空间无效

return TRUE; // return TRUE unless you set the focus to a control
// 异常: OCX 属性页应返回 FALSE

}


  即:设置范围为-100到100,初始化位置为-21,刻度为每10个单位一个。

(5)现在我们加入事件过程代码。

  选择Slider的“事件”然后选择第一个过程(NM_CUSTOMDRAW)随后加入以下代码:

void CMyTestDlg::OnNMCustomdrawSlider1(NMHDR* pNMHDR, LRESULT* pResult)
{
UpdateData(TRUE);
m_Int=m_Slider.GetPos();
UpdateData(FALSE);

//
*pResult = 0;
}


  其中m_Int是定义的EDIT控件的类型为INT的变量。至此我们的编辑工作结束了。

(6)编译运行程序试试吧,很方便就使用了Slider 控件。



原文转自:http://www.vckbase.com/index.php/wv/246.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: