Menú

Mostrar Mensajes

Esta sección te permite ver todos los mensajes escritos por este usuario. Ten en cuenta que sólo puedes ver los mensajes escritos en zonas a las que tienes acceso en este momento.

Mostrar Mensajes Menú

Mensajes - Lekim

#141
Cita de: Eleкtro en 29 Marzo 2016, 19:52 PM
...
En resumen, que es lo más normal del mundo, aunque para entenderlo mejor habría que conocer el código fuente de la función SendMessage para ver como funciona, y sobre todo entender a fondo como funciona la cola de mensajes para ventanas Win32, cosa que yo no se a ciencia cierta, lo que si se es que si dejas el tiempo necesario para que se procese el mensaje y se pueda actualizar la UI (unos ms), entonces puedes comprobar como si que se completa la barra de progreso hasta el final:

Código (vbnet) [Seleccionar]
Public NotInheritable Class Form1 : Inherits Form

   Friend WithEvents Timer1 As New System.Windows.Forms.Timer With {.Interval = 20}

   Private Sub Form1_Shown(ByVal sender As Object, ByVal e As EventArgs) _
   Handles MyBase.Shown

       Me.ProgressBar1.Step = 1
       Me.Timer1.Start()

   End Sub

   Private Sub IncreaseProgressBar(ByVal sender As Object, ByVal e As EventArgs) _
   Handles Timer1.Tick

       Me.ProgressBar1.PerformStep()

       If (Me.ProgressBar1.Value = Me.ProgressBar1.Maximum) Then
           Me.Timer1.Stop()
           MsgBox("done") ' unos ms despues de saltar el msgbox verás como se completa la barra.
           MyBase.Close()
       End If

   End Sub

End Class


Saludos.

Ya he probado el código y ocurre igual, el mensaje se muestra antes que que termine la barra. Igual es cosa de mi compu o puede que del framework, porque no recuerdo que antes pasara.  Como solución me fabricaré mi propia barra (que ya tengo un snippet echo para eso) y listo, ya que he comprobado que funciona usando un estilo gráfico propio y el picturebox, en lugar del progressbar.

S2s

#142
Windows / No puedo activar icono volumen y red
30 Marzo 2016, 12:34 PM
Hola

Los iconos de sonido y red me han desaparecido y al intentar activarlos veo que la los cuadritos de activación están deshabilitados y no lo puedo activar.  Supongo que algún HP a accedido al registro de windows y lo ha desactivado pero no se donde es.

Los cuadritos están deshabilitados  :¬¬



Nota: Windows Vista.

Gracias




No puedo usar Gpedit porque es una versión Home Premium y no está disponible




Lo he resuelto simplemente reiniciando explorer.

#143
Es una página creo que alemana, y es sobre trucos para juegos.


European Codebase

y dice esto:
El script devolvió el siguiente error:

El servidor de base de datos (MySQL) no pudo ser contactado!



Akutell es un problema.

Nos esforzamos por ofrecer la solución más rápida posible al problema. Desafortunadamente, no podemos decir cuánto tiempo va a tomar, por favor probarlo en un momento posterior de nuevo. Nos disculpamos y lamentar su inconveniencia El Webmaster





Nota interna:
Número de error:
2054 Texto de error: Conexión a 03:22, no se admite 03:23 y 4.0 del servidor


Solía entrar para buscar trucos, pero ya no se puede.

He probado hacerlo desde TOR, pero tampoco puedo verla.
#144
Hola Elektro

Gracias por el respuesta. La cual al leerla, parce que Net lo has inventado tú ¿Como sabes esas cosas? XD

Sí comprobé que así és, por ejemplo usando sleep antes que se mostrara el mensaje, entoces la barra termina y se muestra el mensaje, pero hace un parón molesto y queda mal. También probé de usar Backgroundworker, pero ocurre exáctamente igual, que la barra termina después de mostrase el mensaje.

Necesita más tiempo para el llenado gráfico de la barra de progreso, que para los valores de la misma.

Ahora no puedo probar tu código porque estoy en XP, y aquí funcionaría bien incluso el que hice yo. Lo probaré mañana.

S2s
#145
Pero...

Como te he comentado también puedes usar REGEX, fíjate que el código parece el mismo pero no es igual. El uno usa Substring y el otro Regex.

Con regex da igual si lo pones así: 1 2 3 o así 1 ,2 ,3 o así  01, 02, 03 sólo tienes que establecer qué carácter o cadena hay entre los números en Pattern.

REGEX
Código (vbnet) [Seleccionar]
       
       ListBox1.Items.Add("01 ,02 ,03")
       ListBox1.Items.Add("3 ,4 ,5")
       ListBox1.Items.Add("15 ,35 ,45")
       ListBox1.Items.Add("15 ,35 ,55")
       ListBox1.Items.Add("25 ,35 ,45")
       ListBox1.Items.Add("45 ,55 ,65")
       ListBox1.Items.Add("57 ,58 ,59")

       Dim Pattern As String = " ,"
       Dim Digito() As String

       Dim ClearList As New List(Of String)(ListBox1.Items.OfType(Of String))

       For Each Item As String In ClearList
           Digito = System.Text.RegularExpressions.Regex.Split(Item, Pattern)
           If CInt(Digito(1)) = CInt(Digito(0)) + 1 And
              CInt(Digito(2)) = CInt(Digito(1)) + 1 Then
               ListBox1.Items.Remove(Item)
           End If
       Next

Fíjate que hay una línea en la que la he puesto sin el cero delante, y no da error:

ListBox1.Items.Add("3 ,4 ,5")

OTRAS CONDICIONES
Puedes cambiar las condiciones fácilmente.


Este código borra las combinaciones cuyo tercer número tiene dos valores mayor que el segundo.
Por ejemplo:

1 ,2 ,4
2, 3, 5

Código (vbnet) [Seleccionar]
     
       ListBox1.Items.Add("01 ,02 ,03")
       ListBox1.Items.Add("3 ,4 ,5")
       ListBox1.Items.Add("15 ,35 ,45")
       ListBox1.Items.Add("15 ,35 ,55")
       ListBox1.Items.Add("25 ,35 ,37")
       ListBox1.Items.Add("45 ,55 ,57")
       ListBox1.Items.Add("57 ,58 ,60")

       Dim Pattern As String = " ,"
       Dim Digito() As String

       Dim ClearList As New List(Of String)(ListBox1.Items.OfType(Of String))

       For Each Item As String In ClearList
           Digito = System.Text.RegularExpressions.Regex.Split(Item, Pattern)
           If CInt(Digito(2)) = CInt(Digito(1)) + 2 Then
               ListBox1.Items.Remove(Item)
           End If
       Next



Este otro combina las condiciones anteriores, borra las líneas que tengan números correlativos y además las que tengan el tercer número dos veces mayor que el segundo.


Código (vbnet) [Seleccionar]
       ListBox1.Items.Add("01 ,02 ,03")
       ListBox1.Items.Add("3 ,4 ,5")
       ListBox1.Items.Add("15 ,35 ,45")
       ListBox1.Items.Add("15 ,35 ,55")
       ListBox1.Items.Add("25 ,35 ,37")
       ListBox1.Items.Add("45 ,55 ,57")
       ListBox1.Items.Add("57 ,58 ,60")

       Dim Pattern As String = " ,"
       Dim Digito() As String

       Dim ClearList As New List(Of String)(ListBox1.Items.OfType(Of String))

       For Each Item As String In ClearList
           Digito = System.Text.RegularExpressions.Regex.Split(Item, Pattern)
           If CInt(Digito(2)) = CInt(Digito(1)) + 2 Or
               CInt(Digito(1)) = CInt(Digito(0)) + 1 And
              CInt(Digito(2)) = CInt(Digito(1)) + 1 Then
               ListBox1.Items.Remove(Item)
           End If
       Next



Espero te sirva.
#146
Sería mejor que lo pusieras así 01, 25, 06, para no tener que hacer la distinción de se es un dígito o dos, porque si no te va a dar error cuando hayan dos dígitos ya que cambia las posiciones.


   
Código (vbnet) [Seleccionar]

       ListBox1.Items.Add("01 ,02 ,03")
       ListBox1.Items.Add("03 ,04 ,05")
       ListBox1.Items.Add("15 ,35 ,45")
       ListBox1.Items.Add("15 ,35 ,55")
       ListBox1.Items.Add("25 ,35 ,45")
       ListBox1.Items.Add("45 ,55 ,65")
       ListBox1.Items.Add("57 ,58 ,59")

       '//Elimina combinaciones correlativas
        Dim ClearList As New List(Of String)(ListBox1.Items.OfType(Of String))

       For Each Digito As String In ClearList
           If CInt(Digito.Substring(4, 2)) = CInt(Digito.Substring(0, 2)) + 1 And
                CInt(Digito.Substring(8, 2)) = CInt(Digito.Substring(4, 2)) + 1 Then
               ListBox1.Items.Remove(Digito)
           End If
       Next





Para ser más precisos se podría usar Regex, pero si fijo vas a usar dos dígitos, y pones los números del uno al 10 así, 01, 02, 03 .. no hace falta.




Otra forma sería como he comentado con Regex. En este caso no importa si el número tiene uno, dos, tres, etc, dígitos. Pero es importante establecer qué carácter o cadena habrá entre ellos en Pattern.


Código (vbnet) [Seleccionar]
   
      ListBox1.Items.Add("1 ,2 ,3") '<-Se borrará
       ListBox1.Items.Add("3 ,4 ,5") '<-Se borrará
       ListBox1.Items.Add("3 ,24 ,18")
       ListBox1.Items.Add("15 ,35 ,45")
       ListBox1.Items.Add("16 ,17 ,18") '<-Se borrará
       ListBox1.Items.Add("45 ,55 ,65")
       ListBox1.Items.Add("57 ,58 ,59") '<-Se borrará
       ListBox1.Items.Add("346 ,348 ,350")
       ListBox1.Items.Add("350 ,351 ,352") '<-Se borrará

       Dim Pattern As String = " ,"
       Dim Digito() As String

       '//Elimina combinaciones correlativas
      Dim ClearList As New List(Of String)(ListBox1.Items.OfType(Of String))
 
       For Each Item As String In ClearList
           Digito = System.Text.RegularExpressions.Regex.Split(Item, Pattern)
           If CInt(Digito(1)) = CInt(Digito(0)) + 1 And
           CInt(Digito(2)) = CInt(Digito(1)) + 1 Then
               ListBox1.Items.Remove(Item)
           End If
       Next

       '//Lo que hace Regex.Split es devolver los valores que están entre espacio y coma  --> " ,"
       '//Si hay tres números las posiciones serían:
       '//0[ ,]1[ ,]2
       '//Digito(0) devuelve el primer número
       '//Digito(1) devuelve el segundo número
       '//Digito(2) devuelve el tercer número


Devuelve:

3 ,24 ,18
15 ,35 ,45
45 ,55 ,65
346 ,348 ,350

#147
También valdría CInt, creo que mejor incluso ya que son números pequeños:

Código (vbnet) [Seleccionar]
  ListBox1.Items.Add("1 ,2 ,3")
       ListBox1.Items.Add("1 ,4 ,5")
       ListBox1.Items.Add("1 ,3 ,4")
       ListBox1.Items.Add("1 ,3 ,5")
       ListBox1.Items.Add("2 ,3 ,4")
       ListBox1.Items.Add("4 ,5 ,6")
       ListBox1.Items.Add("6 ,7 ,8")

       '//Elimina combinaciones correlativas
       Dim ClearList As New List(Of String)
       ClearList.AddRange(ListBox1.Items.OfType(Of String))
       For Each Digito As String In ClearList
           If CInt(Digito.Substring(3, 1)) = CInt(Digito.Substring(0, 1)) + 1 And
                CInt(Digito.Substring(6, 1)) = CInt(Digito.Substring(3, 1)) + 1 Then
               ListBox1.Items.Remove(Digito)
           End If
       Next
#148
Amos a ver  ::)

Esa es la razón de que me haya molestado en explicar esto:

Simplemente hace una comparación de dígitos línea por línea:

Linea -->  a b c

si b= a+1 y c = b+1 entonces borra la línea

A la hora de usar  Substring, hay que tener en cuenta el lugar de los dígitos:

0]A[1]espacio[2]B[3]espacio[4]C

A está en la posición 0 --> (0, 1)
B está en la posición 2 --> (2, 1)
C está en la posición 4 --> (4, 1)



Si tu lo tienes puesto en el ListBox así ("1 ,2 ,3")

La posición de los dígitos cambia. Como yo no soy adivino y no se como lo tienes pues te he puesto el ejemplo en base a como lo has mostrado tu;

1 2 3 *********correlativos
1 4 5
1 3 4
1 3 5
2 3 4*********correlativo
4 5 6 ********correlativo
6 7 8 ********correlativo


¿Verdad que no lo has puesto así? 1 ,4 ,5. Pues eso.

Si copias mi código tal cual en un nuevo form y con un único listbox y lo pones en el evento load te funciona.  Lo que pasa es que como he dicho tu lo dentrás así con las comas.

1 ,2 ,3





A ver así  ::)

Código (vbnet) [Seleccionar]
       ListBox1.Items.Add("1, 2, 3")
       ListBox1.Items.Add("1, 4, 5")
       ListBox1.Items.Add("1, 3, 4")
       ListBox1.Items.Add("1, 3, 5")
       ListBox1.Items.Add("2, 3, 4")
       ListBox1.Items.Add("4, 5, 6")
       ListBox1.Items.Add("6, 7, 8")

       '//Elimina combinaciones correlativas
       Dim ClearList As New List(Of String)
       ClearList.AddRange(ListBox1.Items.OfType(Of String))
       For Each Digito As String In ClearList
           If CDbl(Digito.Substring(3, 1)) = CDbl(Digito.Substring(0, 1)) + 1 And
                CDbl(Digito.Substring(6, 1)) = CDbl(Digito.Substring(3, 1)) + 1 Then
               ListBox1.Items.Remove(Digito)
           End If
       Next




0]A[1]espacio[2],[3]B[4]espacio[5],[6]C

A está en la posición 0 --> (0, 1)
B está en la posición 3 --> (3, 1)
C está en la posición 6 --> (6, 1)

Lo explicaré mejor:

Donde Dígito es una cadena tal como A ,B ,C

Digito.Substring(6, 1) devuelve UN  carácter que se encuentra en la posición SEIS empezando desde la izquierda. O sea que si mueves el cursor 6 veces se pondrá justo delante de C en este caso [A ,B ,C] y devuelve justo ese carácter.

S2s



A ver que me he hecho un lío con las comas XD, pero funcionaba igual jeje

Código (vbnet) [Seleccionar]
       ListBox1.Items.Add("1 ,2 ,3")
       ListBox1.Items.Add("1 ,4 ,5")
       ListBox1.Items.Add("1 ,3 ,4")
       ListBox1.Items.Add("1 ,3 ,5")
       ListBox1.Items.Add("2 ,3 ,4")
       ListBox1.Items.Add("4 ,5 ,6")
       ListBox1.Items.Add("6 ,7 ,8")

       '//Elimina combinaciones correlativas
       Dim ClearList As New List(Of String)
       ClearList.AddRange(ListBox1.Items.OfType(Of String))
       For Each Digito As String In ClearList
           If CDbl(Digito.Substring(3, 1)) = CDbl(Digito.Substring(0, 1)) + 1 And
                CDbl(Digito.Substring(6, 1)) = CDbl(Digito.Substring(3, 1)) + 1 Then
               ListBox1.Items.Remove(Digito)
           End If
       Next
#149
Cita de: #!drvy en 27 Marzo 2016, 16:32 PM
Los festivos son los que mas dinero dan.


Ya estamos, con el dinero se justifica todo.


Cita de: #!drvy en 27 Marzo 2016, 16:32 PM
Sin duda queda mucho que hacer con eso de "aconfesional" (seguir pagando las visitas del papa por ejemplo...)

De acuerdo

Cita de: #!drvy en 27 Marzo 2016, 16:32 PM
pero hay que recordar que España fue y sigue siendo en su mayoría católica y que la gente tiene tradiciones.

Habría que preguntarse quienes, quien o qué es el artífice de dichas tradiciones. Si comenzamos a tirar de la cuerda al otro extremo yo creo que encontraríamos a la presencia, la constancia, la perseverancia y la imposición de la Iglesia Católica, en el pasado y ahora, me parece a mí.

En fin, yo creo que el Artículo 16 y la foto que he puesto de ejemplo, hablan por sí solos y no hace falta más.

Lo del tema económico, la tradición, etc. son justificaciones que alguien a mencionado y que yo he tratado de rebatir pero que no vienen al caso.  El comentario inicial creo que ha quedad bien claro. Todo lo demás son justificaciones y si no, lo dicho, quiten la etiqueta de aconfesional. En cualquier caso es semi-aconfesional.

Si vamos al tema económico, en mi opinión, las personas que se declarasen creyentes de una u otra religión deberían pagar un impuesto. Y con eso se pagan  las fiestas y las celebraciones.  Entonces veríamos si hay mayoría católica  :xD.

Tengo que recordar "y las demás confesiones." y en palabras de Orubatusu - "El estado debe de ir acorde con la sociedad..."·-. Pues sería interesante que todas esas personas que vivan en España, sea de la religión que sean, excepto la católica (que bastantes fiestas tienen) que demanden al Estado español días festivos, pero para toda España.

Entonces los católicos y cristianos dirán, ¿Pero porqué tengo yo que hacer fiesta si este día a mi ni me viene ni me va?¿Porqué me tengo que esperar hasta mañana o pasado mañana para ir al Banco para abrir una cuenta? ¿Porque...? Pero conociendo el patio, seguro que la gente encantada, porque en España por un día de fiesta se apuntan a un bombardeo.

Menos fiestas y más trabajar.

S2s








#150
Cita de: MCKSys Argentina en 28 Marzo 2016, 23:00 PM
Acabo de probar tu ejemplo y el mensaje se muestra cuando la barra llega al final...

La propiedad maximum es la por default (100).

Es raro...

Gracias por probarlo. Pues si que es raro. Ejecutaré la aplicación en otra compu, haber que pasa.




Ya lo he probado.

Lo he ejecutado en XP dentro de VirtualBox y funciona bien.

Luego he cambiado el tema de windows a Windows Clásico y entonces si que termina.

Sólo ocurre cuando se ve así: