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 :

Gestion des chemins des images avec une base de données...


Sujet :

Bases de données Delphi

  1. #1
    Futur Membre du Club
    Inscrit en
    Juillet 2005
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 13
    Points : 6
    Points
    6
    Par défaut Gestion des chemins des images avec une base de données...
    Voilà, j'essaye de faire un soft de gestion de bédéthéque, je posséde donc une table "TALBUM" qui contient un champ "image" dans lequel je stocke le chemin de l'image correspondant à la couverture de l'album.

    Ma question est double :
    Comment afficher l'image alors que le chemin est stocké dans la base (il s'agit d'une base Access, et j'utilise une ADOTable appelé ADOAlbum pour mes albums) ?
    Comment faire pour demander à l'utilisateur de choisir une image (parcourir...) et sauvegardé le chemin dans la base ?

    J'ai regardé les sujetes parlant déjà de problèmes similaires et je n'ai pas très bien compris, alors est-ce que quelqu'un pourrait me réexpliquer en détail ou m'indiquer un tuto pour les débutants...

    Merci.

  2. #2
    Membre émérite
    Avatar de Thierry Laborde
    Homme Profil pro
    N/A
    Inscrit en
    Avril 2002
    Messages
    1 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : N/A

    Informations forums :
    Inscription : Avril 2002
    Messages : 1 391
    Points : 2 529
    Points
    2 529
    Par défaut
    Salut,

    Pour cet exemple il te faut une form avec un composant Timage (Nom=Image1), 2 composants Tbutton (Noms : btnSelectionnerImage et btnChargeImageDepuisBase) et 1 composant TOpenPictureDialog (Nom : openPicturedialog1).
    Ensuite sur l'évenement OnClick des boutons tu appelles les procédures correspondantes :

    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
     
    procedure TForm1.btnSelectionnerImageClick(Sender: TObject);
    var
      CheminImage:String;
    begin
      openPicturedialog1.Title := 'Selection d'image';
      if openPicturedialog1.Execute then
      begin
        CheminImage:=ExtractFilePath(openPicturedialog1.FileName);
        // Ensuite stocker dans la base de données la variable CheminImage
      end;
    end;
     
    procedure TForm1.btnChargeImageDepuisBaseClick(Sender: TObject);
    var
      CheminImage,NomImage:String;
    begin
      // Récuperer depuis la base de données le chemin de l'image et le mettre dans la variable CheminImage
      NomImage:='Test.bmp';
      img1.Picture.LoadFromFile(CheminImage+NomImage);
    end;
    Dans le premier cas pour selectionner une image tu fais un execute du composant TOpenPictureDialog et tu rècupère le chemin dans la variable CheminImage comme indiqué dans la procédure. Puis tu enregistre tout simplement ta variable dans la base (Je ne connais pas particulièrement ADO et ACCESS donc j'ai mis un commentaire à remplacer).

    Puis dans le 2ème cas pour afficher une image récupéré depuis la base tu mets la valeur de ton chemin dans la variable CheminImage (Toujours pareil, j'ai mis un commentaire), puis tu utilise la fonction loadfromfile du composant Timage pour charger et afficher ton image (Dans mon exemple l'image s'appelle Test.bmp, a toi de mettre le nom correct).

    Voila, c'est un exemple vite fait.

    J'espère que ça répond à tes questions.

  3. #3
    Futur Membre du Club
    Inscrit en
    Juillet 2005
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 13
    Points : 6
    Points
    6
    Par défaut
    Merci de ton explication claire et simple !

    Comment peut-on faire pour que la TOpenPictureDialog retourne le chemin relatif et non pas le chemin absolu ?

    Et sinon comment faire pour récupérer uniquement le nom de l'image et pas le chemin complet ?

  4. #4
    Futur Membre du Club
    Inscrit en
    Juillet 2005
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Juillet 2005
    Messages : 13
    Points : 6
    Points
    6
    Par défaut
    Autre chose, cette méthode ne fonctionne que pour les .bmp pourquoi ? Comment faire pour que ça fonctionne aussi pour les .jpg et les .gif ??

  5. #5
    Membre émérite
    Avatar de Thierry Laborde
    Homme Profil pro
    N/A
    Inscrit en
    Avril 2002
    Messages
    1 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : N/A

    Informations forums :
    Inscription : Avril 2002
    Messages : 1 391
    Points : 2 529
    Points
    2 529
    Par défaut
    Pour le chemin relatif, il faut utiliser la fonction :

    ExpandFileName

    Pour récuperer le nom de l'image d'un fichier va voir au niveau de la FAQ, tu devrais trouver toutes les réponses :

    http://delphi.developpez.com/faq/?pa...ulernomfichier

    Quand au GIF et JPG le Timage ne gère par défaut que les BMP,WMF si tu veux avoir les GIF et JPG tu peux aller voir ici :

    http://www.developpez.net/forums/viewtopic.php?t=29384

    http://delphi.developpez.com/faq/?pa...nserergifanime

    http://www.developpez.net/forums/viewtopic.php?t=360501

    Bon dev.

Discussions similaires

  1. Créer des cube a partir d'une base de données (oracle) avec talend
    Par tahabers dans le forum Développement de jobs
    Réponses: 0
    Dernier message: 18/02/2015, 11h30
  2. insertion des image dans une base de données oracle
    Par tayeb_dev dans le forum Oracle
    Réponses: 2
    Dernier message: 12/08/2011, 01h48
  3. Mettre des images dans une base de donnée
    Par hugo7 dans le forum ASP.NET
    Réponses: 4
    Dernier message: 21/01/2009, 18h46
  4. Comment stocker des images dans une base de données ?
    Par [Silk] dans le forum Bases de données
    Réponses: 4
    Dernier message: 21/07/2005, 11h29
  5. inserer des images dans une base de données
    Par alilou04 dans le forum Bases de données
    Réponses: 2
    Dernier message: 28/06/2004, 18h54

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