[Gvsig_usuarios] Barra de progreso en un script

Joaquin Jose del Cerro Murciano jjdelcerro en gvsig.org
Lun Jul 3 12:01:44 CEST 2017


El 3 de julio de 2017, 10:41, Ovidio Ribeira <alboredos en hotmail.es>
escribió:

> Perfecto, Joaquín
>

Uuiiis, se me ha olvidado comentarte un efecto segundario de este cambio.
El codigo del metodo "Procesar_click" ahora se ejecutara en un hilo de
ejecucion separado. Esto hace que la aplicacion no se quede "colgada"
mientras se esta ejecutando; pero claro, los botones de "Sair" y "Procesar"
siguen activos y el usuario puede darles a mitad del proceso. El de "Sair"
no es muy grave, se cerrara la ventana pero seguira activo el proceso, no
lo termina. El de "Procesar" es mas grave. Volveria a lanzar otra vez el
proceso en paralelo al que ya se esta ejecutando. Y asi una vez por cada
una que se le diese al boton. Habria que "protegerse" un poco en el codigo
frente a esas cosas.

Por un lado yo deshabilitaria el boton "Procesar" al entrar en el metodo y
lo volveria a habilitar al salir.


  def Procesar_click(self,*args):
    try:
      self.Procesar.setEnabled(False)

      features = gvsig.currentLayer().features()
      self.BarraEstado.setMaximum(features.getSize())
      self.BarraEstado.setIndeterminate(False)
      count = 0
      self.BarraEstado.setValue(count)
      for f in features:
        self.BarraEstado.setValue(count)
        clave1 = f.PARCELA_RV
        self.clave.setText( str(int(clave1)))
        print count
        print clave1
        count=count+1

    finally:
      self.Procesar.setEnabled(True)


la contruccion try/finally nos garantiza que siempre se ejecute lo que hay
en el finally al acabar de ejecutarse el codigo que hay dentro del try, sea
por que llega al final, por que se salga a mitad de el con un return o por
que se produzca un error y se aborte la ejecucion de este.

Lo del boton "Sair", yo lo que haria seria declarar un attributo mas en la
clase, algo como "cancelarProceso", ponerlo a True cuando se entre en el
metodo "Sair_click" y preguntar por el en el bucle del evento
"Procesar_click". Algo como:

class BarraEstado(FormPanel):

    def __init__(self):

FormPanel.__init__(self,os.path.join(os.path.dirname(__file__),"lista.xml"))
      self.setPreferredSize(290,200) #tamaño
      self.Procesar_click.setSynchronous(False)
      self.cancelarProceso = False  # <========

    def Sair_click(self,*args):
      self.cancelarProceso = True  # <========
      self.hide()

    def Procesar_click(self,*args):
      try:
        self.Procesar.setEnabled(False)

        features = gvsig.currentLayer().features()
        self.BarraEstado.setMaximum(features.getSize())
        self.BarraEstado.setIndeterminate(False)
        count = 0
        self.BarraEstado.setValue(count)
        for f in features:
          if self.cancelarProceso:     # <========
            return                     # <========
          self.BarraEstado.setValue(count)
          clave1 = f.PARCELA_RV
          self.clave.setText( str(int(clave1)))
          print count
          print clave1
          count=count+1

      finally:
        self.Procesar.setEnabled(True)
        self.cancelarProceso = False   # <========

Cuando estas trabajando con varios hilos de ejecucion puede serte de
utilidad la herramienta "Herramientas->Thread list" que hay en el editor de
scripts.
Te permite ver los hilos que hay en ejecucion y desde hay puedes
cancelarlos (mejor que solo intentes cancelar los que hayas creado tu,
gvSIG tiene los suyos que mejor no tocar).
Ahi puedes comprobar (antes de hacer los cambios que he sugerido) como al
pulsar en el boton "Procesar" se crea el hilo de ejecucion de tu proceso, y
como aunque le des ha salir este sigue en ejecucion, y lo mas importante si
lanzas un proceso largo y quieres cancelarlo puedes hacerlo desde ahi.
Precisaras tener instalado el plugin ScriptingComposerTools para tener esta
herramienta.


Espero que te sirba.
Un saludo

Joaquin



> Saludos y gracias
>
>
> ------------------------------
> *De:* gvsig_usuarios-bounces en listserv.gva.es <gvsig_usuarios-bounces@
> listserv.gva.es> en nombre de Joaquin Jose del Cerro Murciano <
> jjdelcerro en gvsig.org>
> *Enviado:* lunes, 3 de julio de 2017 9:41
>
> *Para:* Lista de Usuarios de gvSIG
> *Asunto:* Re: [Gvsig_usuarios] Barra de progreso en un script
>
>
>
> El 3 de julio de 2017, 9:01, Ovidio Ribeira <alboredos en hotmail.es>
> escribió:
>
>> Buenos dia Joaquín, gracias por tu ayuda.
>>
>> Probe lo que me dijiste pero la barra de estada no se "mueve" durante el
>> proceso,  si que aparece completa al terminarlo, y por la consola si que se
>> va incrementando el contador de las iteraciones, la base del script es la
>> siguiente:
>>
>>
>>
> # encoding: utf-8
>>
>> import gvsig
>> from gvsig import *
>> from gvsig.libs.formpanel import FormPanel
>> from gvsig.libs.formpanel import *
>> import os
>>
>> class BarraEstado(FormPanel):
>>
>>     def __init__(self):
>>       FormPanel.__init__(self,os.path.join(os.path.dirname(__file_
>> _),"lista.xml"))
>>       self.setPreferredSize(290,200) #tamaño
>>
>>     def Sair_click(self,*args):
>>       self.hide()
>>
>>     def Procesar_click(self,*args):
>>       features = gvsig.currentLayer().features()
>>       self.BarraEstado.setMaximum(features.getSize())
>>       self.BarraEstado.setIndeterminate(False)
>>       count = 0
>>       self.BarraEstado.setValue(count)
>>       for f in features:
>>         self.BarraEstado.setValue(count)
>>         clave1 = f.PARCELA_RV
>>         self.clave.setText( str(int(clave1)))
>>         print count
>>         print clave1
>>         count=count+1
>> def main(*args):
>>
>>     l = BarraEstado()
>>     l.showTool(u"Xestión")#Remove this lines and add here your code
>>
>>
>> En la etiqueta también solo muestra la última y al final del proceso,
>> ¿Que estoy haciendo mal?
>>
>
>
> Perdona, se me olvido ese detalle, muy rapido conteste.
>
> Hay un problema de hilos de ejecucion.
> Para explicarlo de forma simple, serial algo como que todas las cosas de
> swing se ejecutan en un mismo hilo de ejecucion, incluidos los venetos. Y
> ese hilo lo tienes pillado haciendo tu proceso. Asi que aunque actualizas
> controles graficos estos no se refrescan hasta que termina el proceso y el
> hilo de swing vuelva a poder refrescar los controles graficos. Momento en
> que se ejecutan todas las actualizaciones de golpe y te aparece la barra ya
> al final. Si tu proceso se ejecutase en otro hilo de ejecucion distinto al
> de swing, este estaria libre para atender las peticiones que actualizacion
> de controles graficos y podria ir actualizandose los controles conforme se
> vayan precisando (esto puedo causar otros problemas, pero para lo que vas a
> realizar en tu proceso y en general para lo que se suele hacer desde
> scripting lo vamos a oviar).
>
> Commo eso ya se me dio en algun otro momento, añadi algo de api del
> FormPanel para poder tratarlo de forma simple.
> Prueba a añadir la linea
>
>       self.Procesar_click.setSynchronous(False)
>
> Al final del metodo __init__.
>
> Es un pequeño hack del FormPanel para indicar que ese evento se ejecute de
> forma asincrona, en otro hilo de ejecucion. El ya se encargara de contruir
> otro hilo de ejecucion y ejecutar tu evento en el.
> Ya me comentas si asi te funciona.
>
> Un saludo
> Joaquin
>
>
>
>
>
>> Saludos y gracias
>>
>> Ovidio
>>
>>
>>
>>
>> ------------------------------
>> *De:* gvsig_usuarios-bounces en listserv.gva.es <
>> gvsig_usuarios-bounces en listserv.gva.es> en nombre de Joaquin Jose del
>> Cerro Murciano <jjdelcerro en gvsig.org>
>> *Enviado:* viernes, 30 de junio de 2017 12:14
>> *Para:* Lista de Usuarios de gvSIG
>> *Asunto:* Re: [Gvsig_usuarios] Barra de progreso en un script
>>
>>
>>
>> El 30 de junio de 2017, 10:57, Ovidio Ribeira <alboredos en hotmail.es>
>> escribió:
>>
>>> Tengo un script con una interfaz grafica creada con Abeille, pero no sé
>>> como se puede integrar una barra de estado con el proceso de iteración
>>> sobre una capa, se agradece la ayuda.
>>>
>>>
>> Hola.
>>
>> Asi, muy rapido, sin pensarlo mucho y sin probar lo que te pongo aqui,
>> solo a modo de idea...
>>
>> En abeille tiene un componenten JProgressbar en la toolbar de componentes.
>> Es un componente standard de swing, su javadoc puedes encontrarlo en
>>
>>   https://docs.oracle.com/javase/7/docs/api/javax/swing/JProgressBar.html
>>
>> Prueba a meterlo en tu formulario, y luego solo tienes que usarlo desde
>> tu script.
>> Tiene dos o tres metodos interesantes. Aqui te dejo un pequeño caso de
>> uso:
>>
>>   features = gvsig.currentLayer().features()
>>
>>   self.pgbProgreso.setMaximum(features.getSize())
>>   self.pgbProgreso.setIndeterminate(False)
>>   count = 0
>>   for f in features:
>>     self.pgbProgreso.setValue(count)
>>
>>     # Ahora hacemos lo que sea que haya que hacer con la feature.
>>     procesar(f)
>>
>>     count += 1
>>
>> Puedes añadir alguna etiqueta mas en el forlario y vas añadiendo en ella
>> informacion sobre lo que vas haciendo.
>> Ten cuidado de no actualizar etiquetas del formulario a lo bestia, por
>> ejemplo en cada iteracion sobre una capa
>> gigantesca, eso puede relentizar el proceso.
>>
>> Espero que sirva.
>>
>> Un saludo
>> Joaquin
>>
>>
>>
>>
>>> Gracias y Saludos
>>>
>>> _______________________________________________
>>> gvSIG_usuarios mailing list
>>> gvSIG_usuarios en listserv.gva.es
>>>
>>> Para ver histórico de mensajes, editar sus preferencias de usuario o
>>> darse de baja en esta lista, acuda a la siguiente dirección:
>>>
>>> https://listserv.gva.es/cgi-bin/mailman/listinfo/gvsig_usuarios
>>>
>>>
>>
>>
>> --
>> --------------------------------------
>> Joaquin Jose del Cerro Murciano
>> Development and software arquitecture manager at gvSIG Team
>> jjdelcerro en gvsig.com
>> jjdelcerro en gvsig.org
>> gvSIG Association
>> www.gvsig.com
>> www.gvsig.org
>>
>> _______________________________________________
>> gvSIG_usuarios mailing list
>> gvSIG_usuarios en listserv.gva.es
>>
>> Para ver histórico de mensajes, editar sus preferencias de usuario o
>> darse de baja en esta lista, acuda a la siguiente dirección:
>>
>> https://listserv.gva.es/cgi-bin/mailman/listinfo/gvsig_usuarios
>>
>>
>
>
> --
> --------------------------------------
> Joaquin Jose del Cerro Murciano
> Development and software arquitecture manager at gvSIG Team
> jjdelcerro en gvsig.com
> jjdelcerro en gvsig.org
> gvSIG Association
> www.gvsig.com
> www.gvsig.org
>
> _______________________________________________
> gvSIG_usuarios mailing list
> gvSIG_usuarios en listserv.gva.es
>
> Para ver histórico de mensajes, editar sus preferencias de usuario o darse
> de baja en esta lista, acuda a la siguiente dirección:
>
> https://listserv.gva.es/cgi-bin/mailman/listinfo/gvsig_usuarios
>
>


-- 
--------------------------------------
Joaquin Jose del Cerro Murciano
Development and software arquitecture manager at gvSIG Team
jjdelcerro en gvsig.com
jjdelcerro en gvsig.org
gvSIG Association
www.gvsig.com
www.gvsig.org
------------ próxima parte ------------
Se ha borrado un adjunto en formato HTML...
URL: <http://listserv.gva.es/pipermail/gvsig_usuarios/attachments/20170703/22f9c488/attachment.html>


Más información sobre la lista de distribución gvSIG_usuarios