In order for this site to work correctly we need to store a small file (called a cookie) on your computer. Most every site in the world does this, however since the 25th of May 2011, by law we have to get your permission first. Please abandon the forum if you disagree.

Para que este foro funcione correctamente es necesario guardar un pequeño fichero (llamado cookie) en su ordenador. La mayoría de los sitios de Internet lo hacen, no obstante desde el 25 de Marzo de 2011 y por ley, necesitamos de su permiso con antelación. Abandone este foro si no está conforme.

Ayuda Browse

Foro de Xailer profesional en español
Responder
buzonjmartial
Mensajes: 100
Registrado: Vie Abr 10, 2009 11:02 pm

Ayuda Browse

Mensaje por buzonjmartial »

Buenos días,

Necesitaría saber si sería posible conseguir el efecto siguiente con un Browse.

Hago una consulta SQL, que devuelve 200 registros por ejemplo y los cargo en un TArrayBrowse. Me muevo hasta la fila 87 por ejemplo, y ahora querría hacer lo siguiente:

Recargar la consulta SQL y posicionarme exactamente donde estaba, para que el usuario no se vuelva loco localizando de nuevo donde estaba posicionado.

¿ Existe alguna manera de conseguirlo ?
Un Saludo,
Joaquín Martínez
Ariel
Mensajes: 26
Registrado: Mar Nov 26, 2019 12:28 pm

Re: Ayuda Browse

Mensaje por Ariel »

Hola,

si es un arraybrowse, podes hacer antes del nuevo sql :
nRecno:= ::oBrowse:nArrayAt
... tu sql ....
::oBrowse:Goto( nRecno )

fijate si funciona y comentanos como te fue.
Saludos.
Avatar de Usuario
ignacio
Site Admin
Mensajes: 9246
Registrado: Lun Abr 06, 2015 8:00 pm
Ubicación: Madrid, Spain
Contactar:

Re: Ayuda Browse

Mensaje por ignacio »

Con datacontrols no hay que hacer absolutamente nada, debería ser todo automático. Si usas un Arraybrowse, la solución propuesta por Ariel me parece correcta

Un saludo
Ignacio Ortiz de Zúñiga
[Equipo de Xailer / Xailer team]
https://www.xailer.com
buzonjmartial
Mensajes: 100
Registrado: Vie Abr 10, 2009 11:02 pm

Re: Ayuda Browse

Mensaje por buzonjmartial »

Buenos días y gracias,

Pero no funciona.

Me vuelvo a explicar, sí se posiciona en ese registro, pero la posición en la pantalla es en la primera línea que se muestra del Browse, pero no en la línea 15 por ejemplo, que es donde estaba
el foco antes de releer la información.

Quiero que las líneas que se están mostrando en este momento en el Browse y el foco, sigan EXACTAMENTE igual que antes de recargar la información.

No me sirve hacer un refreshcurrent() porque han cambiado varias filas, no sólo la actual.
Un Saludo,
Joaquín Martínez
Avatar de Usuario
ignacio
Site Admin
Mensajes: 9246
Registrado: Lun Abr 06, 2015 8:00 pm
Ubicación: Madrid, Spain
Contactar:

Re: Ayuda Browse

Mensaje por ignacio »

Buenos días,

Tenga en cuenta que lo que desea hacer puede fallar si se añade o borra un registro que afecte al browse. No obstante, esta sería la forma de hacerlo:

Código: Seleccionar todo

   WITH OBJECT ::oBrowse
      nPos := :nRowSel  // Guardar posición relativa de la fila activa
     // Recarga del array (Código que usted debe incluir)
      :Refresh(.T.) // Refresco completo del browse
      :nRowSel := nPos // Establecemos la fila activa
      :Refresh( .f. )      // Forzamos un repintado (puede que no sea necesario)
   END WITH
Saludos
Ignacio Ortiz de Zúñiga
[Equipo de Xailer / Xailer team]
https://www.xailer.com
buzonjmartial
Mensajes: 100
Registrado: Vie Abr 10, 2009 11:02 pm

Re: Ayuda Browse

Mensaje por buzonjmartial »

Gracias Ignacio,

Como me ha funcionado ha sido así:

Código: Seleccionar todo

WITH OBJECT ::oBrowse
     nPos := :nArrayAt  // Guardar posición relativa de la fila activa
     // Recarga del array (Código que usted debe incluir)
     ::nArrayAt := nPos // Establecemos la fila activa
     :Refresh( .f. )      // Forzamos un repintado (puede que no sea necesario)
   END WITH

Con nRowSel se posicionaba moviéndose, no se si de esta manera con nArrayAt existe algún inconveniente.
Un Saludo,
Joaquín Martínez
Responder