El funcionamiento es muy simple: llamaremos a una función para mostrar el cuadro de diálogo, se le pasarán una serie de parámetros para personalizarlo (entre ellos la lista de opciones). El usuario seleccionará una opción de la lista y cuando presione el botón "Aceptar" de ese cuadro de diálogo se retornará el valor seleccionado, de lo contrario se devolverá una cadena de texto en blanco.
Veamos ahora su funcionamiento.
Para empezar debemos desde nuestro código fuente llamar a la función que genera nuestro inputbox personalizado (un poco más adelante veremos su código fuente).
Dim user As String
user = drawComboInputBox("Seleccione un usuario de la lista:", list, "A123", "Ingresar al sistema")
If user.IsNullOrEmpty(user) = True Then
MsgBox("No seleccionó ningún usuario")
Else
MsgBox(user)
End If
La función drawComboInputBox generará el inputbox con opciones de lista, el primer parámetro es el texto a mostrar dentro de la ventana, el segundo de ellos es un array con las opciones de la lista, el tercero de ellos la opción predeterminada (un texto) y el último de ellos el título de la ventana.
Si ejecutamos esa función, el resultado es el siguiente:
Este es el código fuente del control inputbox con lista de opciones, se encuentra dentro de una clase (frmComboInputBox), se llama a la misma desde una función para crear el diálogo (más abajo se muestra el código que genera la ventana). Por cierto, esta clase forma parte de una librería personal: Manuel's VB.Net Library, el código fuente de la misma se encuentra (no liberada la librería por falta de documentación interna) bajo licencia BSD/GPL, por lo que éste código fuente se puede usar libremente:
'Copyright (c) 2011,
'All rights reserved, BSD/GPL Dual License.
'
'Redistribution and use in source and binary forms, with or without modification, are
'permitted provided that the following conditions are met:
'
'- Redistributions of source code must retain the above copyright notice, this list
' of conditions and the following disclaimer.
'
'- Redistributions in binary form must reproduce the above copyright notice, this list
' of conditions and the following disclaimer in the documentation and/or other materials
' provided with the distribution.
'
'- Neither the name of the <ORGANIZATION> nor the names of its contributors may be used to
' endorse or promote products derived from this software without specific prior written
' permission.
'
'THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS &AS IS& AND ANY EXPRESS
'OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
'AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
'CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
'DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
'DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
'IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
'OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
'
' Creado por SharpDevelop.
' Usuario: 97016178
' Fecha: 11/07/2013
' Hora: 10:11 a.m.
'
' Para cambiar esta plantilla use Herramientas | Opciones | Codificación | Editar Encabezados Estándar
Public Partial Class frmComboInputBox
 
'#### Purpose: Initialize window
'#### Created date: 11/10/2017
'#### Created by username: Juan Manuel Mar Hdz.
'#### Last modified date: 11/10/2017
'#### Last modified username: Juan Manuel Mar Hdz.
Public Sub New()
  
' The Me.InitializeComponent call is required for Windows Forms designer support.
Me.InitializeComponent()
  
'
' TODO : Add constructor code after InitializeComponents
'
End Sub
 
'#### Purpose: Dispose class
'#### Created date: 11/10/2017
'#### Created by username: Juan Manuel Mar Hdz.
'#### Last modified date: 11/10/2017
'#### Last modified username: Juan Manuel Mar Hdz.
'#### Thanks to http://www.vb-helper.com/howto_net_force_gc.html
Protected Overrides Sub Finalize()
MyBase.Finalize
End Sub
 
'#### Purpose: Close window
'#### Created date: 11/10/2017
'#### Created by username: Juan Manuel Mar Hdz.
'#### Last modified date: 11/10/2017
'#### Last modified username: Juan Manuel Mar Hdz.
Sub CmdCancelClick(sender As Object, e As EventArgs)
  
GC.Collect
Me.Visible = False
  
End Sub
 
'#### Purpose: Close window and Return the string
'#### Created date: 11/10/2017
'#### Created by username: Juan Manuel Mar Hdz.
'#### Last modified date: 11/10/2017
'#### Last modified username: Juan Manuel Mar Hdz.
Sub CmdOKClick(sender As Object, e As EventArgs)
  
GC.Collect
Me.Visible = False
  
End Sub
 
'#### Purpose: Return text area
'#### Created date: 11/10/2017
'#### Created by username: Juan Manuel Mar Hdz.
'#### Last modified date: 11/10/2017
'#### Last modified username: Juan Manuel Mar Hdz.
Public Function getText() As String
   
If cboValue.Text.IsNullOrEmpty(cboValue.Text) = True Then
Return ""
Else
Return cboValue.Text
End If
   
End Function
  
'#### Purpose: Update message
'#### Created date: 11/10/2017
'#### Created by username: Juan Manuel Mar Hdz.
'#### Last modified date: 11/10/2017
'#### Last modified username: Juan Manuel Mar Hdz.
Public Sub Update(message As String, items() As String, Optional defaultvalue As String = "", Optional title As String = "")
  
Dim i As Long
  
If title.IsNullOrEmpty(title) = False Then
Me.Text = title.Trim
Else
Me.Text = ""
End If
   
cboValue.Items.Clear
   
For i=0 To items.Length - 1
If items(i).IsNullOrEmpty(items(i)) = False Then
cboValue.Items.Add(items(i))
End If
     
Next
   
If defaultvalue.IsNullOrEmpty(defaultvalue) = False Then
cboValue.Text = defaultvalue.Trim
Else
cboValue.Text = ""
End If
   
If message.IsNullOrEmpty(message) = False Then
lblMsg.Text = message.Trim
Else
lblMsg.Text = ""
End If
End Sub
 
'#### Purpose: Close window
'#### Created date: 11/10/2017
'#### Created by username: Juan Manuel Mar Hdz.
'#### Last modified date: 11/10/2017
'#### Last modified username: Juan Manuel Mar Hdz.
Sub frmComboInputBoxFormClosing(sender As Object, e As FormClosingEventArgs)
  
e.Cancel = False
  
GC.Collect
Me.Visible = False
  
End Sub
End Class
Para llamar a la clase haremos uso de la siguiente función:
Private frmcombo As frmComboInputBox = Nothing
Private msgbutton As MsgBoxResult = Nothing
Public Function drawComboInputBox(message As String, list() As String, Optional defaulttext As String = "", Optional title As String = "") As String
   
Dim mystr As String = ""
If IsNothing(frmcombo) = True Then
frmcombo = New frmComboInputBox()
End If
   
frmcombo.Update(message.Trim, list, defaulttext, title)
   
Try
msgbutton = frmcombo.ShowDialog
Catch ex As Exception
End Try
If msgbutton = MsgBoxResult.Ok Then
mystr = frmcombo.getText
Else
mystr = ""
End If
   
Try
    
frmcombo.Visible = False
Return mystr
  
Catch exp As Exception
Return ""
End Try
  
End Function
Como podemos ver, se llama a la clase que genera la ventana (por cierto hay que tener los archivos de la interfaz, se incluyen al final de este post) y se invoca al evento update, mediante el cual es posible personalizar la apariencia de la ventana y luego mediante el método getText obtenemos el valor seleccionado. Es todo, con ello ya tenemos un inputbox que muestra una lista de opciones.
¿Te gustó este post?, entonces si lo deseas puedes apoyarnos para continuar con nuestra labor, gracias.
Veamos ahora su funcionamiento.
Para empezar debemos desde nuestro código fuente llamar a la función que genera nuestro inputbox personalizado (un poco más adelante veremos su código fuente).
Dim user As String
user = drawComboInputBox("Seleccione un usuario de la lista:", list, "A123", "Ingresar al sistema")
If user.IsNullOrEmpty(user) = True Then
MsgBox("No seleccionó ningún usuario")
Else
MsgBox(user)
End If
La función drawComboInputBox generará el inputbox con opciones de lista, el primer parámetro es el texto a mostrar dentro de la ventana, el segundo de ellos es un array con las opciones de la lista, el tercero de ellos la opción predeterminada (un texto) y el último de ellos el título de la ventana.
Si ejecutamos esa función, el resultado es el siguiente:
Este es el código fuente del control inputbox con lista de opciones, se encuentra dentro de una clase (frmComboInputBox), se llama a la misma desde una función para crear el diálogo (más abajo se muestra el código que genera la ventana). Por cierto, esta clase forma parte de una librería personal: Manuel's VB.Net Library, el código fuente de la misma se encuentra (no liberada la librería por falta de documentación interna) bajo licencia BSD/GPL, por lo que éste código fuente se puede usar libremente:
'Copyright (c) 2011,
'All rights reserved, BSD/GPL Dual License.
'
'Redistribution and use in source and binary forms, with or without modification, are
'permitted provided that the following conditions are met:
'
'- Redistributions of source code must retain the above copyright notice, this list
' of conditions and the following disclaimer.
'
'- Redistributions in binary form must reproduce the above copyright notice, this list
' of conditions and the following disclaimer in the documentation and/or other materials
' provided with the distribution.
'
'- Neither the name of the <ORGANIZATION> nor the names of its contributors may be used to
' endorse or promote products derived from this software without specific prior written
' permission.
'
'THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS &AS IS& AND ANY EXPRESS
'OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
'AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
'CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
'DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
'DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
'IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
'OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
'
' Creado por SharpDevelop.
' Usuario: 97016178
' Fecha: 11/07/2013
' Hora: 10:11 a.m.
'
' Para cambiar esta plantilla use Herramientas | Opciones | Codificación | Editar Encabezados Estándar
Public Partial Class frmComboInputBox
'#### Purpose: Initialize window
'#### Created date: 11/10/2017
'#### Created by username: Juan Manuel Mar Hdz.
'#### Last modified date: 11/10/2017
'#### Last modified username: Juan Manuel Mar Hdz.
Public Sub New()
' The Me.InitializeComponent call is required for Windows Forms designer support.
Me.InitializeComponent()
'
' TODO : Add constructor code after InitializeComponents
'
End Sub
'#### Purpose: Dispose class
'#### Created date: 11/10/2017
'#### Created by username: Juan Manuel Mar Hdz.
'#### Last modified date: 11/10/2017
'#### Last modified username: Juan Manuel Mar Hdz.
'#### Thanks to http://www.vb-helper.com/howto_net_force_gc.html
Protected Overrides Sub Finalize()
MyBase.Finalize
End Sub
'#### Purpose: Close window
'#### Created date: 11/10/2017
'#### Created by username: Juan Manuel Mar Hdz.
'#### Last modified date: 11/10/2017
'#### Last modified username: Juan Manuel Mar Hdz.
Sub CmdCancelClick(sender As Object, e As EventArgs)
GC.Collect
Me.Visible = False
End Sub
'#### Purpose: Close window and Return the string
'#### Created date: 11/10/2017
'#### Created by username: Juan Manuel Mar Hdz.
'#### Last modified date: 11/10/2017
'#### Last modified username: Juan Manuel Mar Hdz.
Sub CmdOKClick(sender As Object, e As EventArgs)
GC.Collect
Me.Visible = False
End Sub
'#### Purpose: Return text area
'#### Created date: 11/10/2017
'#### Created by username: Juan Manuel Mar Hdz.
'#### Last modified date: 11/10/2017
'#### Last modified username: Juan Manuel Mar Hdz.
Public Function getText() As String
If cboValue.Text.IsNullOrEmpty(cboValue.Text) = True Then
Return ""
Else
Return cboValue.Text
End If
End Function
'#### Purpose: Update message
'#### Created date: 11/10/2017
'#### Created by username: Juan Manuel Mar Hdz.
'#### Last modified date: 11/10/2017
'#### Last modified username: Juan Manuel Mar Hdz.
Public Sub Update(message As String, items() As String, Optional defaultvalue As String = "", Optional title As String = "")
Dim i As Long
If title.IsNullOrEmpty(title) = False Then
Me.Text = title.Trim
Else
Me.Text = ""
End If
cboValue.Items.Clear
For i=0 To items.Length - 1
If items(i).IsNullOrEmpty(items(i)) = False Then
cboValue.Items.Add(items(i))
End If
Next
If defaultvalue.IsNullOrEmpty(defaultvalue) = False Then
cboValue.Text = defaultvalue.Trim
Else
cboValue.Text = ""
End If
If message.IsNullOrEmpty(message) = False Then
lblMsg.Text = message.Trim
Else
lblMsg.Text = ""
End If
End Sub
'#### Purpose: Close window
'#### Created date: 11/10/2017
'#### Created by username: Juan Manuel Mar Hdz.
'#### Last modified date: 11/10/2017
'#### Last modified username: Juan Manuel Mar Hdz.
Sub frmComboInputBoxFormClosing(sender As Object, e As FormClosingEventArgs)
e.Cancel = False
GC.Collect
Me.Visible = False
End Sub
End Class
Para llamar a la clase haremos uso de la siguiente función:
Private frmcombo As frmComboInputBox = Nothing
Private msgbutton As MsgBoxResult = Nothing
Public Function drawComboInputBox(message As String, list() As String, Optional defaulttext As String = "", Optional title As String = "") As String
Dim mystr As String = ""
If IsNothing(frmcombo) = True Then
frmcombo = New frmComboInputBox()
End If
frmcombo.Update(message.Trim, list, defaulttext, title)
Try
msgbutton = frmcombo.ShowDialog
Catch ex As Exception
End Try
If msgbutton = MsgBoxResult.Ok Then
mystr = frmcombo.getText
Else
mystr = ""
End If
Try
frmcombo.Visible = False
Return mystr
Catch exp As Exception
Return ""
End Try
End Function
Como podemos ver, se llama a la clase que genera la ventana (por cierto hay que tener los archivos de la interfaz, se incluyen al final de este post) y se invoca al evento update, mediante el cual es posible personalizar la apariencia de la ventana y luego mediante el método getText obtenemos el valor seleccionado. Es todo, con ello ya tenemos un inputbox que muestra una lista de opciones.
¿Te gustó este post?, entonces si lo deseas puedes apoyarnos para continuar con nuestra labor, gracias.
No hay comentarios. :
Publicar un comentario