Slider Control
Provides a customizable slider control supporting horizontal/vertical orientation, tick styles, selection range, owner-draw, and OLE drag-and-drop.
Enumerations
SldOrientationConstants
Control orientation constants.
| Constant | Value | Description |
|---|---|---|
| SldOrientationHorizontal | 0 | Horizontal orientation |
| SldOrientationVertical | 1 | Vertical orientation |
SldTipSideConstants
Tooltip position constants.
| Constant | Value | Description |
|---|---|---|
| SldTipSideAboveLeft | 0 | Tooltip displayed above/left |
| SldTipSideBelowRight | 1 | Tooltip displayed below/right |
SldTickStyleConstants
Tick style constants.
| Constant | Value | Description |
|---|---|---|
| SldTickStyleBottomRight | 0 | Bottom/right ticks |
| SldTickStyleTopLeft | 1 | Top/left ticks |
| SldTickStyleBoth | 2 | Ticks on both sides |
| SldTickStyleNone | 3 | No ticks |
SldDrawModeConstants
Draw mode constants.
| Constant | Value | Description |
|---|---|---|
| SldDrawModeNormal | 0 | Normal drawing |
| SldDrawModeOwnerDraw | 1 | Owner-draw mode |
SldOwnerDrawItemConstants
Owner-draw item constants.
| Constant | Value | Description |
|---|---|---|
| SldOwnerDrawItemTics | 1 | Tick marks |
| SldOwnerDrawItemThumb | 2 | Slider thumb |
| SldOwnerDrawItemChannel | 3 | Channel |
Properties
Name
Public Property Get Name() As StringReturns the name used to identify the object in code.
Tag
Public Property Get Tag() As String
Public Property Let Tag(ByVal Value As String)Stores extra data needed by the program.
Parent
Public Property Get Parent() As ObjectReturns the object that contains this object.
Container
Public Property Get Container() As Object
Public Property Set Container(ByVal Value As Object)Returns/sets the container of the object.
Left
Public Property Get Left() As Single
Public Property Let Left(ByVal Value As Single)Returns/sets the distance between the left edge of the object and the left edge of its container.
Top
Public Property Get Top() As Single
Public Property Let Top(ByVal Value As Single)Returns/sets the distance between the top edge of the object and the top edge of its container.
Width
Public Property Get Width() As Single
Public Property Let Width(ByVal Value As Single)Returns/sets the width of the object.
Height
Public Property Get Height() As Single
Public Property Let Height(ByVal Value As Single)Returns/sets the height of the object.
Visible
Public Property Get Visible() As Boolean
Public Property Let Visible(ByVal Value As Boolean)Returns/sets whether the object is visible.
ToolTipText
Public Property Get ToolTipText() As String
Public Property Let ToolTipText(ByVal Value As String)Returns/sets the tooltip text displayed when the mouse hovers.
HelpContextID
Public Property Get HelpContextID() As Long
Public Property Let HelpContextID(ByVal Value As Long)Returns/sets the associated context help ID.
WhatsThisHelpID
Public Property Get WhatsThisHelpID() As Long
Public Property Let WhatsThisHelpID(ByVal Value As Long)Returns/sets the associated context help ID.
DragIcon
Public Property Get DragIcon() As IPictureDisp
Public Property Let DragIcon(ByVal Value As IPictureDisp)
Public Property Set DragIcon(ByVal Value As IPictureDisp)Returns/sets the icon displayed during a drag-and-drop operation.
DragMode
Public Property Get DragMode() As Integer
Public Property Let DragMode(ByVal Value As Integer)Returns/sets the drag mode.
hWnd
Public Property Get hWnd() As LongPtrReturns the control handle.
hWndUserControl
Public Property Get hWndUserControl() As LongPtrReturns the UserControl handle.
VisualStyles
Public Property Get VisualStyles() As Boolean
Public Property Let VisualStyles(ByVal Value As Boolean)Returns/sets whether visual styles are enabled. Requires comctl32.dll version 6.0 or later.
BackColor
Public Property Get BackColor() As OLE_COLOR
Public Property Let BackColor(ByVal Value As OLE_COLOR)Returns/sets the background color.
Enabled
Public Property Get Enabled() As Boolean
Public Property Let Enabled(ByVal Value As Boolean)Returns/sets whether the object can respond to user events.
OLEDropMode
Public Property Get OLEDropMode() As OLEDropModeConstants
Public Property Let OLEDropMode(ByVal Value As OLEDropModeConstants)Returns/sets whether the object can act as an OLE drop target.
MousePointer
Public Property Get MousePointer() As CCMousePointerConstants
Public Property Let MousePointer(ByVal Value As CCMousePointerConstants)Returns/sets the type of mouse pointer displayed when hovering. See common enumerations.
MouseIcon
Public Property Get MouseIcon() As IPictureDisp
Public Property Let MouseIcon(ByVal Value As IPictureDisp)
Public Property Set MouseIcon(ByVal Value As IPictureDisp)Returns/sets the custom mouse icon.
MouseTrack
Public Property Get MouseTrack() As Boolean
Public Property Let MouseTrack(ByVal Value As Boolean)Returns/sets whether events are fired when the mouse enters or leaves the control.
RightToLeft
Public Property Get RightToLeft() As Boolean
Public Property Let RightToLeft(ByVal Value As Boolean)Returns/sets the right-to-left display direction.
RightToLeftLayout
Public Property Get RightToLeftLayout() As Boolean
Public Property Let RightToLeftLayout(ByVal Value As Boolean)Returns/sets the right-to-left layout.
RightToLeftMode
Public Property Get RightToLeftMode() As CCRightToLeftModeConstants
Public Property Let RightToLeftMode(ByVal Value As CCRightToLeftModeConstants)Returns/sets the right-to-left mode. See common enumerations.
Min
Public Property Get Min() As Long
Public Property Let Min(ByVal Value As Long)Returns/sets the minimum value.
Max
Public Property Get Max() As Long
Public Property Let Max(ByVal Value As Long)Returns/sets the maximum value.
Value
Public Property Get Value() As Long
Public Property Let Value(ByVal NewValue As Long)Returns/sets the current value.
TickFrequency
Public Property Get TickFrequency() As Long
Public Property Let TickFrequency(ByVal Value As Long)Returns/sets the tick frequency.
Orientation
Public Property Get Orientation() As SldOrientationConstants
Public Property Let Orientation(ByVal Value As SldOrientationConstants)Returns/sets the control orientation.
SmallChange
Public Property Get SmallChange() As Long
Public Property Let SmallChange(ByVal Value As Long)Returns/sets the change amount when pressing arrow keys.
LargeChange
Public Property Get LargeChange() As Long
Public Property Let LargeChange(ByVal Value As Long)Returns/sets the change amount when pressing PageUp/PageDown or clicking the channel.
TickStyle
Public Property Get TickStyle() As SldTickStyleConstants
Public Property Let TickStyle(ByVal Value As SldTickStyleConstants)Returns/sets the tick style.
ShowTip
Public Property Get ShowTip() As Boolean
Public Property Let ShowTip(ByVal Value As Boolean)Returns/sets whether to display the value tooltip.
TipSide
Public Property Get TipSide() As SldTipSideConstants
Public Property Let TipSide(ByVal Value As SldTipSideConstants)Returns/sets the tooltip display position.
SelectRange
Public Property Get SelectRange() As Boolean
Public Property Let SelectRange(ByVal Value As Boolean)Returns/sets whether selection range is enabled.
SelStart
Public Property Get SelStart() As Long
Public Property Let SelStart(ByVal Value As Long)Returns/sets the start position of the selection range.
SelLength
Public Property Get SelLength() As Long
Public Property Let SelLength(ByVal Value As Long)Returns/sets the length of the selection range.
Transparent
Public Property Get Transparent() As Boolean
Public Property Let Transparent(ByVal Value As Boolean)Returns/sets whether the control background is transparent.
HideThumb
Public Property Get HideThumb() As Boolean
Public Property Let HideThumb(ByVal Value As Boolean)Returns/sets whether the slider thumb is hidden.
Reversed
Public Property Get Reversed() As Boolean
Public Property Let Reversed(ByVal Value As Boolean)Returns/sets whether the slider direction is reversed.
DrawMode
Public Property Get DrawMode() As SldDrawModeConstants
Public Property Let DrawMode(ByVal Value As SldDrawModeConstants)Returns/sets the draw mode.
ThumbLeft
Public Property Get ThumbLeft() As SingleReturns the left position of the thumb.
ThumbTop
Public Property Get ThumbTop() As SingleReturns the top position of the thumb.
ThumbWidth
Public Property Get ThumbWidth() As SingleReturns the width of the thumb.
ThumbHeight
Public Property Get ThumbHeight() As SingleReturns the height of the thumb.
ChannelLeft
Public Property Get ChannelLeft() As SingleReturns the left position of the channel.
ChannelTop
Public Property Get ChannelTop() As SingleReturns the top position of the channel.
ChannelWidth
Public Property Get ChannelWidth() As SingleReturns the width of the channel.
ChannelHeight
Public Property Get ChannelHeight() As SingleReturns the height of the channel.
Methods
Refresh
Public Sub Refresh()Forces a complete repaint of the object.
ClearSel
Public Sub ClearSel()Clears the selection range.
GetNumTicks
Public Function GetNumTicks() As LongReturns the number of ticks.
GetTickPosition
Public Function GetTickPosition(ByVal Index As Long) As SingleReturns the position of the specified tick.
OLEDrag
Public Sub OLEDrag()Initiates an OLE drag-and-drop operation.
Drag
Public Sub Drag(Optional ByRef Action As Variant)Starts, ends, or cancels a drag operation.
SetFocus
Public Sub SetFocus()Moves focus to the control.
ZOrder
Public Sub ZOrder(Optional ByRef Position As Variant)Sets the Z-order.
Events
Click
Public Event Click()Fired when the user clicks the control.
Scroll
Public Event Scroll()Fired when the user drags the slider thumb.
Change
Public Event Change()Fired after the value changes.
ContextMenu
Public Event ContextMenu(ByVal X As Single, ByVal Y As Single)Fired when the control is right-clicked.
ModifyTipText
Public Event ModifyTipText(ByRef Text As String)Fired when the tooltip text is about to be displayed, allowing modification of the tooltip text.
ItemDraw
Public Event ItemDraw(ByVal Item As SldOwnerDrawItemConstants, ByRef Cancel As Boolean, ByVal ItemState As Long, ByVal hDC As Long, ByVal Left As Long, ByVal Top As Long, ByVal Right As Long, ByVal Bottom As Long)Fired when an owner-draw item needs to be drawn. Item is the owner-draw item type, Cancel can cancel default drawing, hDC is the device context.
PreviewKeyDown
Public Event PreviewKeyDown(ByVal KeyCode As Integer, ByRef IsInputKey As Boolean)Preview before key down. IsInputKey being True indicates the key is an input key.
PreviewKeyUp
Public Event PreviewKeyUp(ByVal KeyCode As Integer, ByRef IsInputKey As Boolean)Preview before key up.
KeyDown
Public Event KeyDown(KeyCode As Integer, Shift As Integer)Fired when a keyboard key is pressed.
KeyUp
Public Event KeyUp(KeyCode As Integer, Shift As Integer)Fired when a keyboard key is released.
KeyPress
Public Event KeyPress(KeyChar As Integer)Fired when an ANSI key is pressed and released.
MouseDown
Public Event MouseDown(Button As Integer, Shift As Integer, X As Single, Y As Single)Fired when a mouse button is pressed.
MouseMove
Public Event MouseMove(Button As Integer, Shift As Integer, X As Single, Y As Single)Fired when the mouse is moved.
MouseUp
Public Event MouseUp(Button As Integer, Shift As Integer, X As Single, Y As Single)Fired when a mouse button is released.
MouseEnter
Public Event MouseEnter()Fired when the mouse enters the control area.
MouseLeave
Public Event MouseLeave()Fired when the mouse leaves the control area.
OLECompleteDrag
Public Event OLECompleteDrag(Effect As Long)Fired when an OLE drag-and-drop operation completes.
OLEDragDrop
Public Event OLEDragDrop(Data As DataObject, Effect As Long, Button As Integer, Shift As Integer, X As Single, Y As Single)Fired when data is dropped via an OLE drag-and-drop operation.
OLEDragOver
Public Event OLEDragOver(Data As DataObject, Effect As Long, Button As Integer, Shift As Integer, X As Single, Y As Single, State As Integer)Fired when the mouse hovers during an OLE drag-and-drop operation.
OLEGiveFeedback
Public Event OLEGiveFeedback(Effect As Long, DefaultCursors As Boolean)Fired when an OLE drag-and-drop operation gives feedback.
OLESetData
Public Event OLESetData(Data As DataObject, DataFormat As Integer)Fired when an OLE drag-and-drop operation sets data.
OLEStartDrag
Public Event OLEStartDrag(Data As DataObject, AllowedEffects As Long)Fired when an OLE drag-and-drop operation starts.
Code Examples
Basic Usage
' Set up the slider control
With Slider1
.Min = 0
.Max = 100
.Value = 50
.TickFrequency = 10
.SmallChange = 1
.LargeChange = 10
.SelectRange = True
.SelStart = 20
.SelLength = 60
End With
' Respond to value change
Private Sub Slider1_Change()
Debug.Print "Current value: " & Slider1.Value
End Sub
' Customize tooltip text
Private Sub Slider1_ModifyTipText(ByRef Text As String)
Text = "Progress: " & Slider1.Value & "%"
End Sub