MFC 中Silder控件的用法

MFC 中Silder控件的用法

 

    言归正传,在MFC的对话框中可以插入一些控件,其中Silder就是常用之一。下面记录了Silder控件的常用操作:

    设置最大值和最小值

        通过函数SetRange来完成,例如:m_Slider.SetRange(1, 5);

    设置当前位置:

        通过函数SetPos完成,例如:m_Slider.SetPos(3);

    获取当前位置:

        使用函数GetPos,例如:m_Slider.GetPos();返回值是一个int类型。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,以下是一个简单的winform自定义Slider控件的代码示例: ```csharp using System; using System.Drawing; using System.Windows.Forms; public class CustomSlider : Control { private int _minimum = 0; private int _maximum = 100; private int _value = 0; public int Minimum { get { return _minimum; } set { _minimum = value; if (_minimum > _maximum) _maximum = _minimum; if (_value < _minimum) _value = _minimum; Invalidate(); } } public int Maximum { get { return _maximum; } set { _maximum = value; if (_maximum < _minimum) _minimum = _maximum; if (_value > _maximum) _value = _maximum; Invalidate(); } } public int Value { get { return _value; } set { if (_value != value) { if (value < _minimum) _value = _minimum; else if (value > _maximum) _value = _maximum; else _value = value; Invalidate(); OnValueChanged(EventArgs.Empty); } } } public event EventHandler ValueChanged; protected virtual void OnValueChanged(EventArgs e) { if (ValueChanged != null) ValueChanged(this, e); } protected override void OnPaint(PaintEventArgs e) { base.OnPaint(e); // 绘制背景 e.Graphics.Clear(BackColor); // 绘制进度条 int barWidth = (int)((Width - 6) * ((double)(_value - _minimum) / (_maximum - _minimum))); Rectangle barRect = new Rectangle(3, (Height - 8) / 2, barWidth, 8); e.Graphics.FillRectangle(Brushes.Blue, barRect); // 绘制边框 e.Graphics.DrawRectangle(Pens.Black, 0, 0, Width - 1, Height - 1); } protected override void OnMouseDown(MouseEventArgs e) { base.OnMouseDown(e); // 根据鼠标位置计算新的值 int newValue = _minimum + (int)((double)(e.X - 3) / (Width - 6) * (_maximum - _minimum)); Value = newValue; } } ``` 这个控件可以通过设置Minimum、Maximum和Value属性来控制进度条的显示,也可以通过订阅ValueChanged事件来响应值的变化。在OnPaint方法,我们使用Graphics对象绘制了一个蓝色的进度条和一个黑色的边框。在OnMouseDown方法,我们根据鼠标位置计算新的值,并调用Value属性来设置它。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值