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

Python Discussion :

Bouton sur une image


Sujet :

Python

  1. #1
    Membre habitué
    Homme Profil pro
    Webdesigner
    Inscrit en
    Avril 2020
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Webdesigner

    Informations forums :
    Inscription : Avril 2020
    Messages : 11
    Par défaut Bouton sur une image
    bonjour à vous tous,

    Après de multiples recherches( ici, stack..)
    je cherche à afficher un bouton sur une image

    mon image fait 100*100 qui s'appelle "mascotte3.png"
    mon bouton est placé à 50*50 donc au milieu
    mon bouton s'appelle " coucou"

    Y aurait il une notion dessous dessus ?

    mon image s'affiche correctement. Mais pas mon bouton
    Qui parmi, vous aurais une idée du pourquoi du comment?

    je vous laisse le code pour l'exemple

    Merci à vous tous et vous toutes pour votre aide

    ------------------------------------------------------------------------
    import tkinter as tk
    from PIL import Image, ImageTk

    # Chargement de l'image
    image = Image.open("Nouveau dossier\mascotte3.png")

    # affichage de l'image
    image.show()

    # Création du widget d'image
    img_widget = ImageTk.PhotoImage(image)

    # Création de la fenêtre Tkinter
    root = tk.Tk()



    # Création du bouton et placement sur l'image
    button = tk.Button(root, image=img_widget)
    button.place(x=50, y=50)
    button.text("coucou")

    # Affichage de la fenêtre Tkinter
    root.mainloop()



    ---------------------------------------------------------

  2. #2
    Membre Expert
    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    1 539
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 1 539
    Par défaut
    pour commencer, quand je rentres ton code, j'ai des erreurs lors de l'appel à ImageTk qui me dit qu'il n'y a pas de fenêtre Tkinter de créer (logique, tu ne le fais qu'après)
    Ensuite, à la création de ton bouton, tu demandes d'utiliser l'image en tant qu'image de fond du bouton
    button.text("coucou") ne fonctionne pas (chez moi) au contraire de python button["text"]="coucou" (peut-être un changement dans les versions plus récentes de python, j'utilise la 3.9.7)
    Pour finir, il faut utiliser le paramètre compound pour indiquer la position du texte par rapport à l'image
    button["compound"]="center pour positionner le texte au centre par dessus l'image

  3. #3
    Membre habitué
    Homme Profil pro
    Webdesigner
    Inscrit en
    Avril 2020
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Webdesigner

    Informations forums :
    Inscription : Avril 2020
    Messages : 11
    Par défaut
    bonjour

    merci pour la réponse
    Côté python , je suis en version 3.11.

    quant à la ligne de code, je vais essayer

    merci en tout cas

  4. #4
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 830
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 830
    Billets dans le blog
    1
    Par défaut
    Bonjour
    Citation Envoyé par keymael Voir le message
    Côté python , je suis en version 3.11.
    Moi suis en 3.10 sous Linux et chez-moi ton code n'a pas fonctionné. Il m'a dit "RuntimeError: Too early to create image: no default root window".

    J'ai donc déplacé la ligne root = tk.Tk() en début de code, adapté les instructions mentionnées par umfred button["text"]="coucou" et button["compound"]="center" et là ça marche.
    Et l'instruction image.show() ne me semble pas primordiale pour le bouton (elle ne fait qu'afficher l'image dans l'OS).

    Citation Envoyé par keymael Voir le message
    je vous laisse le code pour l'exemple
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  5. #5
    Membre habitué
    Homme Profil pro
    Webdesigner
    Inscrit en
    Avril 2020
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Webdesigner

    Informations forums :
    Inscription : Avril 2020
    Messages : 11
    Par défaut
    Rebonjour,


    En effet, cela va mieux!
    Merci beaucoup.

    Du coup, j'ai déplace mon bouton sous mes images pour le moment...
    Je verrais par la suite pour les coller sur chaque image...mon bouton va etre plus petit que mes images.

    Et il me reste à aligner mes images

    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
    28
    29
     
     
    import tkinter as tk
    from PIL import Image, ImageTk 
     
    # Créer une fenêtre Tkinter
    root = tk.Tk()
     
    # Charger l'image
    image = Image.open("Nouveau dossier\mascotte3.png")
    photo = ImageTk.PhotoImage(image)
    # Charger l'image
    image2 = Image.open("Nouveau dossier\logo.png")
    photo2 = ImageTk.PhotoImage(image2)
     
    # Créer un widget Label pour afficher l'image
    label_image = tk.Label(root, image=photo)
    label_image.pack()
     
    # Créer un widget Label pour afficher l'image
    label_image = tk.Label(root, image=photo2)
    label_image.pack()
     
    # Créer un bouton en dessous de l'image
    button = tk.Button(root, text="Cliquez ici!")
    button.pack()
     
    # Lancer la boucle principale Tkinter
    root.mainloop()
    Images attachées Images attachées  

  6. #6
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 830
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 830
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par keymael Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    # Charger l'image
    image = Image.open("Nouveau dossier\mascotte3.png")
    photo = ImageTk.PhotoImage(image)
    # Charger l'image
    image2 = Image.open("Nouveau dossier\logo.png")
    photo2 = ImageTk.PhotoImage(image2)
     
    # Créer un widget Label pour afficher l'image
    label_image = tk.Label(root, image=photo)
    label_image.pack()
     
    # Créer un widget Label pour afficher l'image
    label_image = tk.Label(root, image=photo2)
    label_image.pack()
    Tu n'es pas obligé de nommer chaque variable temporaire d'un nom différent. Tu peux très bien utiliser "image" et "photo" à chaque fois. Voire même ne pas utiliser de variable intermédiaire.
    Et essaye de prendre l'habitude d'utiliser les outils dédiés à la manipulation de chemins, cela rendra ton code plus portable...
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    import pathlib
    for img in ("mascotte3", "logo"):
    	# Créer un widget Label pour afficher l'image
    	tk.Label(root, image=ImageTk.PhotoImage(Image.open(pathlib.Path("Nouveau dossier", "%s.png" % img)))).pack()
    # for
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  7. #7
    Membre habitué
    Homme Profil pro
    Webdesigner
    Inscrit en
    Avril 2020
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Webdesigner

    Informations forums :
    Inscription : Avril 2020
    Messages : 11
    Par défaut
    Citation Envoyé par Sve@r Voir le message
    Tu n'es pas obligé de nommer chaque variable temporaire d'un nom différent. Tu peux très bien utiliser "image" et "photo" à chaque fois. Voire même ne pas utiliser de variable intermédiaire.
    Et essaye de prendre l'habitude d'utiliser les outils dédiés à la manipulation de chemins, cela rendra ton code plus portable...
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    import pathlib
    for img in ("mascotte3", "logo"):
    	# Créer un widget Label pour afficher l'image
    	tk.Label(root, image=ImageTk.PhotoImage(Image.open(pathlib.Path("Nouveau dossier", "%s.png" % img)))).pack()
    # for

    waoouhh !!
    je ne soupçonnais même pas l'existence d'une telle balise!
    je prends note de tes remarques....je l'intègre à mon code

    en tout cas, merci pour vos coups de main

  8. #8
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 738
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 738
    Par défaut
    Citation Envoyé par keymael Voir le message
    je ne soupçonnais même pas l'existence d'une telle balise!
    Et accessoirement, les formats bmp, gif et png sont supportés par l'Image de Tk: pas besoin de passer par PIL.Image pour les lire.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  9. #9
    Membre habitué
    Homme Profil pro
    Webdesigner
    Inscrit en
    Avril 2020
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Webdesigner

    Informations forums :
    Inscription : Avril 2020
    Messages : 11
    Par défaut
    Citation Envoyé par wiztricks Voir le message
    Et accessoirement, les formats bmp, gif et png sont supportés par l'Image de Tk: pas besoin de passer par PIL.Image pour les lire.

    - W


    bonjour!

    je prends note de ceci également!
    merci encore

  10. #10
    Expert confirmé Avatar de papajoker
    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2013
    Messages
    2 323
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nièvre (Bourgogne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2013
    Messages : 2 323
    Par défaut
    bonjour
    Citation Envoyé par Sve@r Voir le message
    outils dédiés à la manipulation de chemins
    Si on fait le pointilleux, Path est pour la manipulation de fichier et PurePath est pour la manipulation de noms de fichiers/chemins.

  11. #11
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 830
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 830
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par keymael Voir le message
    je ne soupçonnais même pas l'existence d'une telle balise!
    Tu parles de pathlib ou juste du fait de boucler sur les deux images?

    pathlib c'est le nouveau truc à la mode mais sinon, de façon plus "old-school", tu as os.path
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    >>> import os
    >>> os.path.join("/", "xxx", "yyy")
    '/xxx/yyy'
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  12. #12
    Membre habitué
    Homme Profil pro
    Webdesigner
    Inscrit en
    Avril 2020
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Webdesigner

    Informations forums :
    Inscription : Avril 2020
    Messages : 11
    Par défaut
    import pathlib
    for img in ("mascotte3", "logo"):
    # Créer un widget Label pour afficher l'image
    tk.Label(root, image=ImageTk.PhotoImage(Image.open(pathlib.Path("Nouveau dossier", "%s.png" % img)))).pack()
    # for

    Ce qui signifie dans ton exemple :
    Nouveau dossier = dossier des images
    %s.png = 1ere image
    %img = image suivante
    Est ce bien cela?

    ce qui devrait donner
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    tk.Label(root, image=ImageTk.PhotoImage(Image.open(pathlib.Path("Nouveau dossier", "image1.png", "image2.png")))).pack()

  13. #13
    Membre habitué
    Homme Profil pro
    Webdesigner
    Inscrit en
    Avril 2020
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Webdesigner

    Informations forums :
    Inscription : Avril 2020
    Messages : 11
    Par défaut
    Citation Envoyé par Sve@r Voir le message
    Tu parles de pathlib ou juste du fait de boucler sur les deux images?

    pathlib c'est le nouveau truc à la mode mais sinon, de façon plus "old-school", tu as os.path
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    >>> import os
    >>> os.path.join("/", "xxx", "yyy")
    '/xxx/yyy'

    Idem ici..
    je suppose que le / est le répertoire des images
    xxx = image 1
    yyy = Image 2


    Par contr je ne saisi pas cette instruction
    '/xxx/yyy' en fin de ligne...A quoi sert elle ??

    merci encore

  14. #14
    Expert confirmé Avatar de papajoker
    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2013
    Messages
    2 323
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nièvre (Bourgogne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2013
    Messages : 2 323
    Par défaut
    Citation Envoyé par keymael Voir le message
    %s.png = 1ere image
    %img = image suivante
    Est ce bien cela?
    Désolé mais il y a toute une éducation à faire, connaitre les boucles est un minimum

    Idem ici..
    je suppose que le / est le répertoire des images
    Désolé, encore perdu, tout est dans la doc de cette fonction
    '/xxx/yyy' en fin de ligne...A quoi sert elle ??
    Après lecture de la doc, on comprend que c'est le résultat de cette fonction (avec ces paramètres)

  15. #15
    Membre habitué
    Homme Profil pro
    Webdesigner
    Inscrit en
    Avril 2020
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Webdesigner

    Informations forums :
    Inscription : Avril 2020
    Messages : 11
    Par défaut
    Citation Envoyé par papajoker Voir le message
    Désolé mais il y a toute une éducation à faire, connaitre les boucles est un minimum


    Désolé, encore perdu, tout est dans la doc de cette fonction
    bon tant pis pour moi...
    je vais me mettre à la lecture

  16. #16
    Expert confirmé Avatar de papajoker
    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2013
    Messages
    2 323
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nièvre (Bourgogne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2013
    Messages : 2 323
    Par défaut
    Et pour apprendre/comprendre, il est toujours bon de faire des mini-tests.
    créer un fichier de 2 lignes n'est pas trop compliqué
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    for img in ("mascotte3", "logo"):
        print("Nouveau dossier", "%s.png" % img)
    une fois bien compris, on intègre pathlib.Path()

  17. #17
    Membre habitué
    Homme Profil pro
    Webdesigner
    Inscrit en
    Avril 2020
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Webdesigner

    Informations forums :
    Inscription : Avril 2020
    Messages : 11
    Par défaut
    Citation Envoyé par papajoker Voir le message
    Et pour apprendre/comprendre, il est toujours bon de faire des mini-tests.
    créer un fichier de 2 lignes n'est pas trop compliqué
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    for img in ("mascotte3", "logo"):
        print("Nouveau dossier", "%s.png" % img)
    une fois bien compris, on intègre pathlib.Path()
    en effet...
    y a du boulot..

  18. #18
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 830
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 830
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par keymael Voir le message
    Par contr je ne saisi pas cette instruction
    '/xxx/yyy' en fin de ligne...A quoi sert elle ??
    C'est le mode intéractif de Python, appelé "idle", qui permet de taper de petites instructions pour vérifier. Donc on tape les instructions après le prompt ">>>" et Python affiche le résultat (ici "/xxx/yyy") juste en dessous.
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

Discussions similaires

  1. [Python 3.X] Créer un champ de saisie ou un bouton sur une image
    Par Riseba dans le forum GUI
    Réponses: 0
    Dernier message: 04/09/2014, 20h06
  2. Faire suivre un bouton sur une image centrée
    Par amateursf dans le forum Mise en page CSS
    Réponses: 3
    Dernier message: 06/09/2013, 19h27
  3. Plusieurs boutons sur une image de fond
    Par LordDaedalus dans le forum Agents de placement/Fenêtres
    Réponses: 2
    Dernier message: 08/02/2010, 10h28
  4. [FLEX] Ajouter un bouton sur une image
    Par miya dans le forum MXML
    Réponses: 2
    Dernier message: 02/03/2009, 17h29
  5. [Javascript Debutant]Comment positionner des boutons sur une Image?
    Par bylka dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 25/07/2007, 13h07

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