gambas-source-code/app/examples/Control/LCDLabel/.src/TimeBox.class

153 lines
2.8 KiB
Text
Raw Normal View History

' Gambas class file
Export
Inherits UserControl
Public Const _Properties As String = "*,Action,Value,ReadOnly,Border=True"
'Public Const _DefaultEvent As String = "Click"
Public Const _DefaultSize As String = "24,4"
Public Const _Similar As String = "TextBox"
Public Const _DrawWith As String = "TextBox"
Property Value As Date
Property ReadOnly As Boolean
Property Border As Boolean
Private $hBorder As DrawingArea
Private $hMinute As MaskBox
Private $hSecond As MaskBox
Private $hLabel As Label
Private $bBorder As Boolean = True
Public Sub _new()
$hBorder = New DrawingArea(Me) As "Border"
$hBorder.Arrangement = Arrange.Horizontal
$hBorder.Padding = Style.FrameWidth
$hBorder.Margin = True
$hMinute = New MaskBox($hBorder) As "MinuteBox"
$hMinute.Expand = True
$hMinute.Border = False
$hMinute.Mask = "00"
$hMinute.Alignment = Align.Center
$hMinute.ShowDefault = True
$hLabel = New Label($hBorder)
$hLabel.Text = " : "
$hLabel.AutoResize = True
$hSecond = New MaskBox($hBorder) As "SecondBox"
$hSecond.Expand = True
$hSecond.Border = False
$hSecond.Mask = "00"
$hSecond.Alignment = Align.Center
$hSecond.ShowDefault = True
End
Private Function Value_Read() As Date
Try Return Time(0, CInt($hMinute.Text), CInt($hSecond.Text))
End
Private Sub Value_Write(Value As Date)
$hMinute.Text = Format(Minute(Value), "00")
$hSecond.Text = Format(Second(Value), "00")
End
Private Function ReadOnly_Read() As Boolean
Return $hMinute.ReadOnly
End
Private Sub ReadOnly_Write(Value As Boolean)
$hMinute.ReadOnly = Value
$hSecond.ReadOnly = Value
End
Private Function Border_Read() As Boolean
Return $bBorder
End
Private Sub Border_Write(Value As Boolean)
$bBorder = Value
$hBorder.Padding = If($bBorder, Style.FrameWidth, 0)
$hBorder.Margin = $bBorder
End
Public Sub MinuteBox_GotFocus()
$hBorder.Refresh
$hMinute.SelectAll
End
Public Sub SecondBox_GotFocus()
$hBorder.Refresh
$hSecond.SelectAll
End
Public Sub MinuteBox_LostFocus()
$hBorder.Refresh
End
Public Sub SecondBox_LostFocus()
$hBorder.Refresh
End
Public Sub MinuteBox_MouseWheel()
$hMinute.Text = Format(Max(0, Min(59, CInt($hMinute.Text) + If(Mouse.Forward, -1, 1))), "00")
End
Public Sub SecondBox_MouseWheel()
Dim dVal As Date
dVal = Value_Read()
Try dVal = DateAdd(dVal, gb.Second, If(Mouse.Forward, 10, -10))
If Not Error Then Value_Write(dVal)
End
Public Sub MinuteBox_Change()
If $hMinute.Pos = $hMinute.Length Then
$hSecond.SetFocus
Endif
End
Public Sub Border_Draw()
Dim iBg As Integer = Color.TextBackground
If Me.Background <> Color.Default Then iBg = Me.Background
If $bBorder Then
Style.PaintBox(0, 0, Me.W, Me.H, Style.StateOf($hMinute) Or Style.StateOf($hSecond), iBg)
Else
Paint.FillRect(0, 0, Me.W, Me.H, iBg)
Endif
End