Página principal
Artículos y trucos
Catálogo de productos
Ejemplos y descargas
Mis libros
Cursos de formación
Investigación y desarrollo
Libros recomendados
Mis páginas favoritas
Acerca del autor
 
En colaboración con Amazon
 
Intuitive Sight

Columnas de sólo lectura

Este es el típico truco tonto de la página de Marteens. Espero, no obstante, que le sea útil a alguien como lo ha sido para mí.

Usted tienen un rejilla, un TDBGrid. Quiere que alguna de sus columnas sea intocable, que no puedan modificarse los valores que muestra, pero a la vez desea que puedan editarse otras columnas. Fácil, ¿no?. Porque nos basta con asignar True en la propiedad ReadOnly de la columna correspondiente de la rejilla.

¿Y qué tal si, para que el usuario no se confunda más de lo que suele estar, cambiamos el color de la columna utilizando su propiedad Color? Pues que obtenemos un estupendo efecto visual ... excepto que si nos posicionamos sobre una celda de la columna y pulsamos el ratón otra vez, o intentamos escribir, la rejilla hace como si fuese a permitir la edición, aunque realmente no lo permita. Entre otras cosas, la celda "manipulada" vuelve a tener el mismo color blanco de siempre, y le damos una oportunidad al usuario de que se queje como siempre.

¿Por qué pasa esto? Pues porque la rejilla tiene una opción dgEditing en su propiedad Options, y cuando la opción está presente, la rejilla coloca un cuadro de edición sobre la celda en que se intenta esta acción. Siempre. No nos vale apagar definitivamente dgEditing, porque entonces no podríamos editar las otras columnas. Pero la solución es tan sencilla que me da vergüenza contarla: debemos interceptar el evento OnColEnter de la rejilla como muestro a continuación:

procedure TForm1.DBGrid1ColEnter(Sender: TObject);
begin
  if DBGrid1.SelectedField = ElCampoSoloLectura then
    DBGrid1.Options := DBGrid1.Options - [dgEditing]
  else
    DBGrid1.Options := DBGrid1.Options + [dgEditing];
end;

Es casi seguro también que tendrá que hacer lo mismo en el evento OnEnter de la rejilla, por lo que el método anterior posiblemente será compartido por ambos eventos.