Cómo seleccionar elemento ComboBox por índice

Iniciado por novalida, 10 Diciembre 2010, 22:47 PM

0 Miembros y 1 Visitante están viendo este tema.

raul338

novalida, el itemdata es un espacio extra (como una variable mas), pongas lo que le pongas, no afecta en nada en absoluto al ComboBox.

Ya sabes que los indices empiezan de 0, lo que puedes hacer es que el item que quieres seleccionar, le restes uno. ej

Código (vb) [Seleccionar]
ComboBox1.ListIndex = Abs(Val(Text1.Text)) - 1

No te preocupes del -1, en caso de que el text este vacio (o no tenga numeros) el resultado es -1, lo que significa que ningun item se seleccionara (estara vacio, bueno, eso depende del estilo del combo)

Si quieres seleccionar enero poniendo 1, seleccionara el 0. Esto funciona a menos que el combobox este ordenado y el orden afecte el orden de los indices. Para estos casos no queda otra que hace ComboBox1.Text = "Enero" y que windows se encarge de buscarlo :xD

novalida

raul338 , sí, tienes razón, esa sería la respuesta más lógica, pero lo que pretendía era no hacer referencia a la propiedad .Text, pues no queda muy elegante para asegurar la integridad al trabajar con una base de datos, cayendo fácilmente en la creación de una aplicación hard code.


BlackZeroX

#12
.
Cada item del Combo al indicarle el indice 1, 2 etc, no implica que sea su identificador solo le dice al objeto que quieres que el nuevo item sea ese indice Todos los demas "items" solo son recorridos.

Aquí un pequeño ejemplo que arme.

Código (Vb) [Seleccionar]

' // Se Requieren Dos controles ComboBox llamados
' // cmb_calendarioEspejo
' // cmb_calendario
' // Ejemplo por BlackZeroX.

Option Explicit

Private Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" (pDst As Any, pSrc As Any, ByVal ByteLen As Long)
Private Declare Function VarArrPtr Lib "msvbvm60" Alias "VarPtr" (arr() As Any) As Long

Private Sub cmb_calendario_Click()
Dim lng_iNow                As Long
   lng_iNow = cmb_calendario.ListIndex
   Caption = lng_iNow
   If cmb_calendarioEspejo.ListCount - 1 >= lng_iNow Then
       cmb_calendarioEspejo.ListIndex = lng_iNow
   End If
End Sub

Private Sub Form_Load()
Dim Meses()                 As Variant
   Meses = Array("Enero", "Febrero", "Marzo", "Abril", "Mayo", "Junio", "Julio", "Agisto", "Septiembre", "Octubre", "Noviembre", "Diciembre")
   Debug.Print FillObjectWithArray(cmb_calendario, Meses)
   Debug.Print FillObjectWithArray(cmb_calendarioEspejo, Meses)
   
   '   //  Pruebas Index...
   Call cmb_calendario.AddItem("caca5", 1)
   Call cmb_calendario.AddItem("caca4", 1)
   Call cmb_calendario.AddItem("caca3", 1)
   Call cmb_calendario.AddItem("caca2", 1)
   Call cmb_calendario.AddItem("caca1", 1)
End Sub

Private Function FillObjectWithArray(ByRef Obj As Object, ThisData() As Variant, Optional PropertyName As String = "AddItem")
Dim lng_i                   As Long
   If ItsIniArray(VarArrPtr(ThisData)) Then
       For lng_i = LBound(ThisData()) To UBound(ThisData())
           Call CallByName(Obj, PropertyName, VbMethod, ThisData(lng_i))
           FillObjectWithArray = FillObjectWithArray + 1
       Next lng_i
   End If
End Function

Public Function ItsIniArray(ByVal PtrToArray As Long) As Boolean
Dim lng_Ptr                 As Long
   Call CopyMemory(lng_Ptr, ByVal PtrToArray, 4)
   ItsIniArray = lng_Ptr <> 0
End Function



Si estas con Ado solo pasale un en la propiedad "DataSource" el RecordSet y listo se llenara automaticamente el ComboBox.

Dulces Lunas!¡.
.
The Dark Shadow is my passion.

raul338

novalida, Eso depende del entorno de la conexion que uses. Yo siempre trabajo en entorno desconectado (no enlazo controles, sino que hago una clase que haga las llamadas, la propiedad Text no invoca al evento Change, por lo que no se entra en un ciclo infinito)

De todas formas no es que sea algo "uuuyyy que feo", creeme, hay cosas peores :xD

BlackZeroX, no entendi tu punto  :-\  :silbar:

BlackZeroX

#14
.
por lo que lei quiere agregar un tecto que lo identifique el index, bueno solo agrege dicho codigo como ejemplo ya que si agrega indicando el Index es erroneo, es decir, si agregue en un caso anterior un objeto con Index 2 por ejemplo y ya tengo 42 elementos solo le indico al objeto que agregue dicho elemento en la posicion 3 de la lista ( esto se ve claramente en el codigo anterior ).

Ahora lo que veo que que si va a trabajar con una BDD es mejor que cree una tabla donde agregue los meses, por ende, con ADO ya en el programna solo realiza dicha consulta y lo vacia en un RecordSet y el mismo lo vacia en la propiedad DataSource si no me equivoco claro... De esta manera se agregan los elementos en la posicion deseada con su ID indicado y en orden (obviamente si le hace un additem en un index ya ocupado habra un error como ya expuse)


De manera mas breve... del por que puse el codigo de arriba...

Cita de: novalida en 11 Diciembre 2010, 00:14 AM

Al hacer lo que me proponéis siempre sale un elemento por debajo. Es decir, el índice del combobox es 0, pero yo le indiqué para el elemento "Enero" el índice 1. Al indicarle en el textbox el índice 1 me cambia el combobox a "Febrero" y no "Enero".
:S


Lo que pasa que de forma interna el comboBox, no trabaja con "tags" en los elementos es decir si le indicas 1 no vale

Ahora si trabajas con una BDD el ID deberia de empezar por 0, pero oigual DataSource del ComboBox NO ASEGURA QUE cada elemento se encuentre definido por un Index, esto ya deberas de manejarlo en un RecordSet en memoria y no en un control, ya que la mayoria de los controles que trabajan con elementos y su consulta es por propiedad index habitualmente estos empiesan SIN SALTARSE desde 0 hasta CantidadDeElementos -1

Dulces Lunas!¡.
The Dark Shadow is my passion.

pushuno

novalida, buscando una solucion a lo mismo entre en tu post y como no pude encontrar en ningun lado una respuesta me armé una funcion que se encargue de esto.


Public Function seleccionarPorItemData(cmb As ComboBox, sel As Integer)
Dim i As Integer

    For i = 0 To cmb.ListCount - 1
          If (CStr(cmb.ItemData(i)) = sel) Then 'compara el valor del que buscamos con los itemdata de todos
                cmb.ListIndex = i 'si lo encuentra marca como seleccionado el item
          End If
    Next
End Function


espero te sirva, abrazo Pushuno!

KaRoMe

Se que en este momento ni al caso pero x si alguien entra a leer el detalle que no notaron es q el queria decirle al combo box que al introducir el 1 pusiera enero cuando en realidad la lista arranca en 0 osea solo era de decirle al textbox que le restara 1 al numero que el usuario ingresara