Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Principal > OOP
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

Coloboración Paypal con ClubDelphi

 
 
Herramientas Buscar en Tema Desplegado
  #9  
Antiguo 02-06-2008
Avatar de roman
roman roman is offline
Moderador
 
Registrado: may 2003
Ubicación: Ciudad de México
Posts: 20.269
Poder: 10
roman Es un diamante en brutoroman Es un diamante en brutoroman Es un diamante en bruto
He estado haciendo algunas pruebas con ZEOS y MySQL y me ha funcionado tal como te dije al principio. Quizá el problema lo tengas desde el momento de guardar la imagen, que no se esté guardando correctamente.

En todo caso, por lo que he visto, ni siquiera es necesario usar streams ya que tanto los objetos TBlobField como los gráficos tienen soporte integrado para escribir y leer desde aquellos.

En resumen, me he armado con este par de funciones que me han dado buenos resultados:

Código Delphi [-]
{
  Transfiere el contenido del campo Field al objeto Picture
  El campo debe ser un BLOB con una imagen en formato JPEG
}
procedure FieldToPicture(Field: TField; Picture: TPicture);
var
  Jpeg: TJpegImage;

begin
  if Field is TBlobField then
  begin
    if Field.IsNull then
      Picture.Graphic := nil
    else
    begin
      Jpeg := TJpegImage.Create;

      try
        Jpeg.Assign(Field);
        Picture.Assign(Jpeg);
      finally
        Jpeg.Free;
      end;
    end;
  end;
end;

{
  Transfiere el contenido del objeto Picture al campo Field
  El campo debe ser un BLOB y Picture debe contener una imagen en formato JPEG
}
procedure PictureToField(Picture: TPicture; Field: TField);
begin
  if (Picture.Graphic is TJPegImage) or not Assigned(Picture.Graphic) then
  begin
    Assert(Field.DataSet <> nil);
    
    Field.DataSet.Edit;
    Field.Assign(Picture.Graphic);
  end;
end;

FieldToPicture se usaría para copiar la imagen de un campo Blob a un objeto TPicture, como lo es la propiedad Picture de un componente Image. Lo normal sería usarla en el evento AfterScroll del DataSet:

Código Delphi [-]
procedure TForm1.ZTable1AfterScroll(DataSet: TDataSet);
begin
  FieldToPicture(DataSet.FieldByName('foto'), Image1.Picture);
end;

aunque también iría bien en el AfterCancel para restaurar la imagen original en caso de cancelar la edición.

PictureToField es la inversa y copia el contenido del objeto Picture en el campo. La función se asegura de que Picture contenga un gráfico JPEG. Lo normal aquí sería usarla al cargar una imagen desde un archivo:

Código Delphi [-]
procedure TForm1.btnLoadPictureClick(Sender: TObject);
begin
  if OpenPictureDialog.Execute then
  begin
    Image1.Picture.LoadFromFile(OpenPictureDialog.FileName);
    PictureToField(Image1.Picture, ZTable1.FieldByName('foto'));
  end;
end;

o bien, si queremos borrar la imagen:

Código Delphi [-]
procedure TfrmMain.btnClearPictureClick(Sender: TObject);
begin
  Image1.Picture.Graphic := nil;
  PictureToField(Image1.Picture, ZTable1.FieldByName('foto'));
end;

Como digo, me han funcionado bien con ZEOS y MySQL.

// Saludos

Última edición por roman fecha: 02-06-2008 a las 00:42:24.
Responder Con Cita
 


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Imagen JPG en una base de datos Access edus1984 Conexión con bases de datos 7 08-05-2007 01:52:10
Novato (Cargando imagen con jvDBImage) enecumene Conexión con bases de datos 4 05-06-2006 22:01:36
Base de datos con campo imagen raffagia MS SQL Server 1 03-03-2005 09:32:32
Guardar una archivo de imagen (bmp,jpg..etc), en la base de datos cahosoft Firebird e Interbase 4 31-07-2004 16:53:56
Imagen en base de datos. kwan Conexión con bases de datos 20 29-07-2003 22:48:21


La franja horaria es GMT +2. Ahora son las 09:19:14.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi