FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
||||
|
||||
Cambiar el ancho de las columnas
Hola una vez más, compañeros del club.
Probé hace tiempo a hacer peticiones SQL a una tabla ACCESS mediante ADO, todo me fué perfectamente. El fallo está ahora en que, como es normal, las columnas tienen el mismo ancho que carácteres pueden tener, haciéndo que el usuario tenga que ir haciendo scroll hacia los laterales continuamente. ¿Cómo podría evitar esto? ¿Cómo puedo hacer que tengan un ancho exacto o que el ancho se adecúe al campo más largo?. Muchísimas gracias. P.d.: Pongo este post en Varios pues no se si debería ir a SQL o POO... aunque creo que va a ser POO.. ruego a los moderadores que lo cambien al sitio adecuado.
__________________
:) |
#2
|
||||
|
||||
Cita:
La página actualmente no está accesible, pero aquí tienes direcciones desde donde puedes descargarlo. El componente: http://www.torry.net/db/visible/db_grids/texdbgrid.zip Una demo: http://www.torry.net/db/visible/db_g...bgriddemos.zip Si aun así deseas implementarlo, puedes hacerlo tú mismo recorriendo el Dataset asociado al Grid y guardando el ancho del texto más largo de cada columna; Finalmente asignas ese ancho a cada una de las columnas. Un par de cosas, ten en cuenta que si la tabla es muy grande el proceso puede tardar bastante, y que no funcionará si estás trabajando en modo "clServer" (es decir, que no cargas todos los registros en local), ya que lo que tú necesitas implica recorrer el DataSet entero. Te diré que yo finalmente descarté ésta opción por lo comentado anteriormente, y lo cambié por la opción de guardar el ancho de las columnas una vez que éste se ha modificado; De ésta forma el usuario la 1ª vez que entra en la pantalla de Grid, sí debe hacer Scroll y configurar el ancho de las columnas a su gusto, pero ésta configuración se graba al salir de forma que la siguiente vez la configuración ya es correcta.
__________________
Germán Estévez => Web/Blog Guía de estilo, Guía alternativa Utiliza TAG's en tus mensajes. Contactar con el Clubdelphi P.D: Más tiempo dedicado a la pregunta=Mejores respuestas. |
#3
|
|||
|
|||
Hola,
Además de los enlaces y soluciones que te indica Neftalí, yo utilizo un pequeño truco: la función SUBSTRING. Realmente sólo la he utilizado en SQL Server y no sé si en Access estará disponible, pero creo que sí. Observa en el siguiente ejemplo como utilizo la función SubString para concatenar varios campos y mostrarlos con la longitud deseada y con una cabecera(título) único. 'SELECT Ape1, Part1, Ape2, Part2, Nomb, Numer, Bloq, Port, Esca, Planta, Puer, CodPos, P.NIden AS Identificador, SUBSTRING(RTRIM(P.Telfno)+SPACE(1)+RTRIM(P.Telfno1),1,20) AS Telefonos, SUBSTRING(RTRIM(C.TVia)+SPACE(1)+RTRIM(C.NVia),1,35) AS Domicilio, P.Id AS IdPer, P.CVia AS PCVia, TSPar, TSImpar FROM Personas P INNER JOIN Calles C ON P.CVia=C.CVia WHERE Id='+QuotedStr(XIdPersona.Caption) Esta solución es algo más primitiva pero fácil y útil. Rafita.
__________________
Rafita. |
#4
|
||||
|
||||
Perdon Rafita.. pero no entendí muy bien lo de la función SubString... ¿Qué hace?... de igual modo, pregunto antes de pulsar F1... a si que dame un poco de tiempo a buscarlo...
Neftali, muchas gracias por tu respuesta... miraré los componentes y diré que tal. Muchísimas gracias a ambos, de verdad
__________________
:) |
#5
|
|||
|
|||
Hola compañero,
Perdona el retraso, pero últimamente no doy abasto. Cita:
Rafa.
__________________
Rafita. |
#6
|
||||
|
||||
Si, pero eso coge varios textos y los combina en uno, haciéndo la columna ajustada... Pero.. ¿Cómo consigo adecuar el ancho de las columnas a uno PREDEFINIDO?
Muchas gracias, rafita, por tu respuesta
__________________
:) |
#7
|
||||
|
||||
Cita:
¿Quieres ajustar el ancho de una columna? F1 -> TColumn // Saludos |
#8
|
||||
|
||||
Una forma rápida de hacerlo:
Declara una variable Columns de tipo TDBGridColumns que creas al incio: Columns := TDBGridColumns.Create(nil, TColumn); y destruyes al final Columns.Free; Cuando abras la tabla le asignas las columnas:
Al cerrar la tabla guardas la columnas:
// Saludos |
#9
|
||||
|
||||
Bueno, comentar que lo conseguí minutos después de escribir mi último post.. no he podido responder antes por culpa del WinXP.. que no le da la gana de funcionar bien (escribo ahora mismo desde RedHat).
Nada más simple.. y tonto.. pero que me ha traido de cabeza. así predeterminaba el ancho de las columnas en cada consulta, y fijándome en cada valor de regreso de la consulta SQL pues he puesto los index por orden. MUchísimas gracias a todos!!
__________________
:) |
|
|
|