FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
|||
|
|||
Recorrer archivos de un directorio y mostrar graficos en miniaturas
Hola a todos, tengo la siguiente pregunta. alguna recomendacion de como recorrer un arbol de directorios de la PC y que en un panel derecho me vaya mostrando los archivos JPEG o BMP que contenga el directorio en forma de imagenes en miniatura. lo necesitaria con componentes estandar de la paleta de Delphi
Gracias |
#2
|
||||
|
||||
Hola cmfab.
En tu form poné un TDirectoryListBox (pestaña Win31) y un TScrollBox (pestaña Aditional).
Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#3
|
||||
|
||||
Hola a todos.
Ecfisa he probado este codigo y va de fábula, hace tiempo que quería hacer algo parecido para una secuencia de imagenes. Mi duda es si en vez de buscar los datos de un directorio, se pueden sacar las imagenes directamente de una tabla para que solo enseñe las del codigo en pantalla. Me explico, tengo una base de datos con fotos de camiones de bomberos y me gustaria poder visualizar solo las del camion que estoy viendo en este momento, luego que al cambiar de registro me cargue las del nuevo registro y ya rizando el rizo que al hacer click sobre la miniatura me abra la ampliación. Actualmente hago un savetostream para guardar y un loadfromstream para cargar. Muchas gracias Josep |
#4
|
||||
|
||||
Hola jafera.
Si no te interpreto mal, me parece que en tu caso es muchisimo más sencillo. Creo que podrías usar un TDBControlGrid con su propiedad DataSource asociada al TDataSource correspondiente a la tabla. Luego agregas en el TDBControlGrid un TDBImage y en su propiedad DataField seleccionas el campo que corresponde a la imágen. Un saludo.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#5
|
|||
|
|||
justo lo que necesitaba, gracias por todas la srespuestas y por su tiempo
|
#6
|
||||
|
||||
Gracias Ecfisa.
Tu proposición funciona bien, solo que tengo un pequeño problema, al asignarle la imagen el TDBImage, me dice que bitmap image is not valid. He probado con un TImage a secas asignandole el valor y funciona, solo que me muestra una sola foto y no toda la hilera
Gracias de nuevo Josep |
#7
|
||||
|
||||
Hola jafera.
Entiendo el problema pero al menos yo, no pude encontrar en forma directa evento o redefinición de método alguno para hacer la conversión de TJPEGImage a TBitmap, antes de que se produzca la asignación del campo al TDBImage. Se me ocurrió que una opción, si no son muchos datos, podría ser utilizar un TClientDataSet en memoria. Para el ejemplo que te adjunto hice una tabla con sólo dos campos, un campo entero llamado ('ID') y otro blob que contiente la imágen ('IMAGEN'). Datos estos que cargo en el TClientDataSet mediante un TIBQuery. A partir de aquí podés utilizar todos los DBControls a traves del ClientDataSet, es decir que para mostrar información no se precisa más. Pero si existe la posibilidad de que se modifique algún dato deberías actualizar lo realizado al finalizar... Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#8
|
||||
|
||||
Gracias por la respuesta Ecfisa.
He implementado el codigo que me pasaste y como el componente ClientDataSet no lo habia usado nunca me arrojó algún problema. Primero que no encontraba el data provider, le adjunte un dataset provider, luego me dice que no esta declarado el CDS1ID ni el CDS1Imagen (Undeclared Identifier), no se si me dejo alguna cosa la vuelo, ya que repito no había usado jamás este componente. Saludos Josep |
#9
|
||||
|
||||
Hola jafera.
No tendría que darte ningún problema, lo único engorroso es que tenes que crear los campos persistentes que se correspondan a los de tu tabla. Estos campos no existen físicamente solo en memoria, no se requiere de ningún data provider. Los campos persistentes se crean al igual que en cualquier TDataSet. Por ejemplo para crear el campo Imagen: Doble click sobre el componente CDS1 -> Click botón derecho -> New Field y luego: Del mismo modo con los demás campos, por supuesto que Type tendrá que ser del tipo correspondiente al valor que se le asignará. Los nombres CDS1ID y CDS1Imagen se pueden dar arbitrariamente, en este caso coinciden con el nombre del componente + nombre de campo. Si no te queda totalmente claro avisame que adjunto un ejemplo. Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... Última edición por ecfisa fecha: 19-03-2012 a las 13:22:14. |
#10
|
||||
|
||||
Gracias de nuevo.
Es que hoy tengo el coco un poco espeso. Ahora si que los campos aparecen, no sabia que se creaban igual. El nuevo problema es que ahora me aparece el DBImage en blanco y solo uno, aunque el registro tenga 3 imagenes No se, sigo investigando Josep |
#11
|
||||
|
||||
Hola jafera.
Te adjunto el ejemplo con la tabla incluída, crea una carpeta y descomprimelo allí, en el evento OnCreate se asignan los valores necesarios al TIBDatabase. Para evitarte inconvenientes cambié el acceso al predeterminado: user_name: SYSDBA password: masterkey Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... |
#12
|
||||
|
||||
No me deja abrir la tabla, ni con el IBConsole, me da este error:
Unsupported on-disk structure for file C:\EJEMPLO\PRUEBA.FDB; found 32779, support 10. Imagino que es la version de Firebird, yo uso la 1.5.6 Saludos Josep |
#13
|
||||
|
||||
Hola.
Si es eso sin dudas. Pero igual no va a ser problema para que realices la prueba. Desde el IBExpert, create una tabla: Luego desde Delphi, cargala con imágenes de tu disco: Ajustá en el demo los nuevos valores del TIBDatabase y tendrías que poder ejecutarlo sin problemas. Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... Última edición por ecfisa fecha: 20-03-2012 a las 04:46:15. |
#14
|
||||
|
||||
Hola Ecfisa, eres como mi angel de la guarda.
Hoy ya no se si echarme a llorar o que. He puesto un TIBDataSet con su correspondiente DataSource para cargar las imagenes de prueba. Cuando intento ejecutar el código del button1, me da un error de sql tokken unknow -line 2 char 1 from En la tabla he puesto select * from tbimage. Por hoy abandono porque veo que mi Santo Patrón no me ayuda en nada. Saludos Josep |
#15
|
||||
|
||||
jafera, tu tabla se llama tbimagen, o es un campo, si es un campo, cambialo por el nombre de la tabla, y has editados los campo (sobre el ibdataset, raton boton derecho, seleccionas la primera columna el campo indice, seleccionas todos de la segunda columna , marcas el checkbox, pulsas el segundo botón empezando por abajo y aceptas el resultado ya puedes conectar.)
__________________
Un saludo desde Canarias, "El abuelo Cebolleta" |
#16
|
||||
|
||||
Bueno, parece que ya he conseguido que se carguen las imagenes.
En vez de colocar el código en el OnCreate, lo he colocado en el OnChange del DBEdit1 para que cada vez que cambio de registro reemplace los valores de las miniaturas. Pero...... Siempre hay un pero, solo consigo ver una foto en el TDBControilGrid, y moviendome por la barra de desplazamiento va cambiando a la segunda, la tercera, etc, pero seimpre en el primer "frame", no consigo ver toda la ristra de miniaturas. No se si me dejo algun parámetro por ajustar. Gracias Josep |
#17
|
||||
|
||||
Me respondo a mi mismo.
No se que pasaba pero el componente DBImage no habia quedado bien, se movia independientemente del TDBControlGrid. Lo he borrado, lo he vuelto a insertar y ya se ven las imagenes en miniatura. Ahora lo que me pasa es que cuando cierro el form y lo vuelvo a abrir sin cerrar la aplicación, me da un error de Database not asigned. Siguiendo con las imagenes, he modificado la fuente de datos para el TDBControlGrid ya que tenia un IBDataSet en el mismo form con los datos que necesito. Ahora lo que quiero conseguir es que al dar click en la imagen me la abra en grande. Saludos Josep |
#18
|
||||
|
||||
Bueno, pues el componente funciona de verdad.
Ya he conseguido ajustarlo para que me muestre bien las imagenes, antes si me desplazaba a fondo con la barra de desplazamiento horizontal (scroll), me intentaba añadir un registro nuevo, creando una imagen en blanco. Esto lo he solucionado poniendo la propiedad AllowInsert y AllowDelete en false. Lo unico que de momento no consigo es que al hacer click sobre la miniatura me abra una ampliación de la misma. En el form existe un TImage al que le asigno el valor del Blob de la tabla mediante un LoadFromStream en el evento AfterScroll del TIBDataSet. No se si algo de esto me puede servir para pasar este valor desde el click en el DBImage. En el mismo form tengo un DBgrid con los nombres de las fotos y al hacer click en este DBGrid, me cambia el valor de la foto, o sea la imagen. Gracias a todos Saludos Josep |
#19
|
||||
|
||||
Cita:
Si lo que buscas es pasar la miniatura del DBImage al Image para verla ampliada allí, es muy sencillo: Para limpiar el TImage:
Saludos.
__________________
Daniel Didriksen Guía de estilo - Uso de las etiquetas - La otra guía de estilo .... Última edición por ecfisa fecha: 21-03-2012 a las 19:56:59. |
#20
|
||||
|
||||
Gracias Ecfisa, espero que disfrutases de tu aniversario, tal como disfruté yo del mio hace un més.
En cuanto al tema de la asignación, claro que si, ya comenté que tenía el coco en otro sitio y muchas veces las soluciones más simples se vuelven un problema inmenso y sin ver la salida del túnel. Pero.... Otra vez con el pero, como dije utilizé un IBDataSet que tengo en el form para cargar los datos del ClientDataDet en vez de una consulta nueva. Hay alguna posibilidad de que el cursor se mueva en los registros de la tabla cuando hago click en la miniatura? Lo que pasa es que si muevo el cursor en el grid asociado a la tabla con el cursor y luego hago click en la miniatura, el cursor no se mueve y me marca un registro que no es el que estoy visualizando. Saludos Josep |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Recorrer directorio | Pedro-Juan | Conexión con bases de datos | 4 | 09-02-2011 18:50:43 |
Mostrar ficheros de un directorio y subdirectoros | chinchan | C++ Builder | 3 | 11-01-2009 22:26:49 |
Mostrar directorio con ShellExecute | MON___ | API de Windows | 5 | 26-03-2008 13:07:00 |
Borrar archivos de un directorio | nelem | Internet | 6 | 29-10-2007 16:04:00 |
Mostrar un directorio con el explorador de archivos de windows | Jan_polero | API de Windows | 2 | 11-01-2005 18:40:21 |
|