IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Bases de données Delphi Discussion :

Afficher une image JPG qui se trouve dans une bdd


Sujet :

Bases de données Delphi

  1. #1
    Membre expérimenté
    Avatar de Harry
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juillet 2002
    Messages
    1 224
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2002
    Messages : 1 224
    Points : 1 331
    Points
    1 331
    Par défaut Afficher une image JPG qui se trouve dans une bdd
    Comment afficher une image JPG qui se trouve dans une bdd (sans l'enregistrer sur le HD)?

    Le composant DBImage ne semble gérer que les BMP.

    Merci

  2. #2
    Membre expérimenté
    Avatar de Harry
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juillet 2002
    Messages
    1 224
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2002
    Messages : 1 224
    Points : 1 331
    Points
    1 331
    Par défaut
    Ce qu'il me faudrait idéalement c'est un composant DBImage qui gère les JPG.
    Pour l'instant j'ai regardé sur torry.net (entre autres) et j'ai pas trouvé.

  3. #3
    Fxg
    Fxg est déconnecté
    Membre éclairé
    Homme Profil pro
    ingénieur financier
    Inscrit en
    Septembre 2003
    Messages
    511
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : ingénieur financier

    Informations forums :
    Inscription : Septembre 2003
    Messages : 511
    Points : 838
    Points
    838
    Par défaut
    Voila un petit bout de code tiré d'un de mes programmes et qui affiche une image jpeg dont le nom est enregistré dans la base. Ce n'est pas le fichier jpeg qui est dans la base mais seulement son nom pour des raisons de taille..

    En espérant que cela convienne

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
     
    {Chargement du fichier jpg sur modification du Titre du Livre}
    procedure TForm1.DBEdit1Change(Sender: TObject);
     
    Var
    nom_image : string;
     
    begin
    nom_image:=Datamodule2.TLivre.FieldbyName('ch_image_livre').AsString;
    if nom_image = '' then
      begin
        jp:=nil;
        Image2.Picture.assign(jp);
      end
      else
      begin
        jp:=nil;
        Stream:=nil;
        jp:=tjpegimage.Create;
        jp.loadFromFile(Datamodule2.TLivre.FieldByName('ch_image_livre').AsString);
        stream:=tmemorystream.Create;
        jp.SaveToStream(stream);
        stream.Position:=0;
        jp.LoadFromStream(Stream);
        Image2.Picture.assign(jp);
      end;
    end;
    Avant j'ai bien sur déclaré comme variable :

    jp : TJpegImage;
    Stream : TMemoryStream;

    + jpeg dans mon uses.

  4. #4
    Membre expérimenté
    Avatar de Harry
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juillet 2002
    Messages
    1 224
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2002
    Messages : 1 224
    Points : 1 331
    Points
    1 331
    Par défaut
    Nope, c pas ce que je veux, ca c facile :p, c'est la technique sue j'utilisait avant en fait, depuis pour utiliser rave report j'ai été contraint d'intégrer les photos dans la BDD. (a 100% dans la bdd et pas juste le lien).

    La seule technique que j'ai trouvé c'est d'enregister le contenu du champ avec un save to file et de le recharger de suite après avec la meme technique que toi.
    La seule chose c'est que ce n'est pas très propre ni très efficace de passer par un fichier temporaire. J'aurais préféreé un systeme tout en code donc je suis toujours preneur si quelqu'un trouve un composant equivalent au DBImage qui prendrait en compte les fichiers JPG.

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    95
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2003
    Messages : 95
    Points : 107
    Points
    107
    Par défaut
    Le composant EDBimage fait ca tres bien, avec sources freeware.
    peut etre sur torry, je ne sais plus.
    Je crois que c'est ici : http://delphi.about.com/library/bluc/vcl/edbimage.zip
    .

  6. #6
    Membre habitué Avatar de alexmorel
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    196
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : Suisse

    Informations forums :
    Inscription : Septembre 2003
    Messages : 196
    Points : 157
    Points
    157
    Par défaut Essai avec sa
    J'ai pour les BMP !! Pour insere les images

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    With requete_query do
      Begin
         Active:=False;
         Sql.clear;
         Sql.Add('Insert into ta_table(id_ta_table, images) ' 
                  +' Values(3, :mon_image));
                         {On lui donne le chemin de l'image a charger dans la base}
          Parameters.ParaByName('mon_image').LoadFromFile(le_chemin, ftBlob);
           ExecSql;
       End;
    Et pour la recupere

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
     
    Var MS:TMemoryStream;
    Begin
    MS:=TMemoryStream.Create;
     
    With Query_recupere Do
      Begin
          Active:=false;
          Sql.Clear;
          SQl.Add('Select image from ta_table where id_ta_table=3');
          ExecSql;
          Active:=True
       End;
    Try
                  {On auve dans leStream}
      TBlobField(Query_recupere .FieldByName('image')).saveToStream(MS);
                   {On se déplace au début du Stream}   
      MS.Position:=0;
                     {On affiche l'image}
      DBImage.Picture.Bitmap.LoadFromStream(MS);
    Finally
      MS.Free;   {On libere la memoire du Stream}
    End;
    Si tu trouve pour les JPG previens Moi j'en ai aussi besoin

  7. #7
    Membre expérimenté
    Avatar de Harry
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juillet 2002
    Messages
    1 224
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2002
    Messages : 1 224
    Points : 1 331
    Points
    1 331
    Par défaut
    En fait la seule technique qui semble marcher, et pas si lent que ca en fait, c'est d'utiliser le disque dur en temporaire avec un saveToFile sur le champ puis un loadFromFile sur le picture d'un Timage.

Discussions similaires

  1. Réponses: 8
    Dernier message: 07/06/2009, 21h31
  2. ouvrir une image .JPG qui n'est pas dans la base
    Par merocean dans le forum Requêtes et SQL.
    Réponses: 19
    Dernier message: 12/02/2009, 22h22
  3. Afficher un mot qui se trouve dans une phrase.
    Par XpFive dans le forum VB 6 et antérieur
    Réponses: 6
    Dernier message: 02/08/2008, 20h47
  4. Réponses: 2
    Dernier message: 12/06/2006, 13h35
  5. [C#]Comment executer du code qui se trouve dans une string ?
    Par freddyboy dans le forum Windows Forms
    Réponses: 4
    Dernier message: 28/02/2005, 17h31

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo