何度もすみません、もし良ければ下記コードを参考にして下さい。
(標準モジュール)
'*** コンボボックスを作成する関数 *******************************************
Public Declare Function CreateWindowEx Lib "user32" Alias "CreateWindowExA" _
(ByVal dwExStyle As Long, ByVal lpClassName As String, _
ByVal lpWindowName As String, ByVal dwStyle As Long, ByVal x As Long, _
ByVal y As Long, ByVal nWidth As Long, ByVal nHeight As Long, _
ByVal hWndParent As Long, ByVal hMenu As Long, ByVal hInstance As Long, _
lpParam As Any) As Long
'*** 作成したコンボボックスを破棄する関数 ***********************************
Public Declare Function DestroyWindow Lib "user32" (ByVal hwnd As Long) As Long
'*** コンボボックスの項目を追加する関数 *************************************
Public Declare Function SendMessage Lib "user32" Alias "SendMessageA" (ByVal hwnd As Long, _
ByVal wMsg As Long, ByVal wParam As Long, lParam As Any) As Long
Public Const WS_CHILD = &H40000000 '子ウィンドウ
Public Const WS_VISIBLE = &H10000000 '表示する
Public Const CBS_DROPDOWN = &H2& 'Styleプロパティ(ドロップダウン)
Public Const CBS_SORT = &H100& 'Sortedプロパティ(並び替える)
Public Const CB_ADDSTRING = &H143 '項目追加
Public lngRet As Long '戻り値
Public Sub CreateComb()
Dim lngSendRet As Long '戻り値
'*** ComboBox1という名前で既存のフォームにStyle(ドロップダウンコンボ) ******
'*** Sorted(True)のコンボボックスを作成 ******
lngRet = CreateWindowEx(0, "ComboBox", "ComboBox1", _
WS_CHILD Or WS_VISIBLE Or CBS_DROPDOWN Or CBS_SORT, _
0, 0, 100, 100, Form1.hwnd, 0, 0, 0)
'*** 作成したコンボボックスの項目を追加 ************************************
lngSendRet = SendMessage(lngRet, CB_ADDSTRING, 0, ByVal "a")
lngSendRet = SendMessage(lngRet, CB_ADDSTRING, 0, ByVal "い")
lngSendRet = SendMessage(lngRet, CB_ADDSTRING, 0, ByVal "あ")
End Sub
Public Sub DestroyComb()
'*** 作成したコンボボックスを破棄 ******************************************
lngRet = DestroyWindow(lngRet)
End Sub
(フォーム)
Private Sub Form_Load()
Call CreateComb
End Sub
Private Sub Form_Unload(Cancel As Integer)
Call DestroyComb
End Sub
上記を実行されますとコンボボックスが作成され、
a
あ
い
という項目が3行追加され並び替えも正しく行われました。
コンボボックスのStyle、Sortedプロパティはデザイン時にしか設定が
出来ないので、上記方法を記載しましたが他に良い方法があるかも知れません。