ComboBox - Combo Select III - Borje

Category: Controls - .Techniques

Date: 02-16-2022

Return to Index


 
'Compilable Example:  (Jose Includes)
#Compiler PBWin 9, PBWin 10
#Compile EXE
#Dim All
%Unicode=1
#Include "win32api.inc"
%IDC_ComboA = 500
%IDC_ComboB = 501
%IDC_ComboC = 502
 
Global hDlg As Dword
 
Function PBMain() As Long
   Dim MyArray(3) As String
   Array Assign MyArray() = "zero", "one", "two", "three"
   Dialog New Pixels, 0, "ComboBox Test",300,300,200,200, %WS_OverlappedWindow, 0 To hDlg
   Control Add ComboBox, hDlg, %IDC_ComboA, MyArray(), 20,10,75,100
   Control Add ComboBox, hDlg, %IDC_ComboB, MyArray(), 20,50,75,100
   Control Add ComboBox, hDlg, %IDC_ComboC, MyArray(), 20,90,75,100
   ComboBox Select hDlg, %IDC_ComboA, 1
   ComboBox Select hDlg, %IDC_ComboB, 2
   ComboBox Select hDlg, %IDC_ComboC, 3
   Dialog Show Modal hDlg Call DlgProc
End Function
 
CallBack Function DlgProc() As Long
   Local w,h As Long
   Select Case Cb.Msg
      Case %WM_InitDialog
         Control Set Focus hDlg, %IDC_ComboC
      Case %WM_Command
         Select Case Cb.Ctl
            Case %IDC_ComboA
               If Cb.CtlMsg = %CBN_SetFocus Then
                  Control Send hDlg, %IDC_ComboA, %EM_SetSel, -1, 0
                  Dialog Set Text hDlg, "A"
               End If
            Case %IDC_ComboB
               If Cb.CtlMsg = %CBN_SetFocus Then
                  Control Send hDlg, %IDC_ComboB, %EM_SetSel, -1, 0
                  Dialog Set Text hDlg, "B"
               End If
            Case %IDC_ComboC
               If Cb.CtlMsg = %CBN_SetFocus Then
                  Control Send hDlg, %IDC_ComboC, %EM_SetSel, -1, 0
                  Dialog Set Text hDlg, "C"
               End If
         End Select
      Case %WM_Size
         Dialog Get Client hDlg To w,h
         Control Set Size hDlg, %IDC_ComboA, w-40,20
         Control Set Size hDlg, %IDC_ComboB, w-40,20
         '         Control Post hDlg, %IDC_ComboA, %CB_SetEditSel, 0, Mak(Long,-1,0)
         '         Control Post hDlg, %IDC_ComboB, %CB_SetEditSel, 0, Mak(Long,-1,0)
   End Select
End Function
 
'gbs_00775
'Date: 03-10-2012


created by gbSnippets
http://www.garybeene.com/sw/gbsnippets.htm