Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

ENSSEMBLE DE TROIS WIDGETS AFFICHEURS POUR TKINTER: AFF7SEG, GALVANOMÈTRE ET BAREGRAPH


Description

Cliquez pour voir la capture en taille normale
Regroupe les trois premières sources que j'ai développée avec une modification:
Tous les widgets sont dans des classes qu'il suffit d'importer dans votre programme et d'utiliser comme n'importes quels widgets Tkinter.
 

Source

  • # -*- coding: cp1252 -*-
  • # Enssemble de 3 types d'afficheurs :
  • # Baregraph, Galvanomètre et Afficheur 7 Segments.
  • #la consigne est une valeurncomprise entre 0 et 100.
  • from Tkinter import*
  • class segs(Canvas):
  • def __init__(self,parent):
  • global root,d,u,chiffre,coded,codeu
  • root=parent
  • chiffre={0:[1,2,3,4,5,6], 1:[2,3], 2:[1,2,7,5,4], 3:[1,2,3,4,7], 4:[6,7,2,3], 5:[1,6,7,3,4], 6:[1,6,5,4,3,7], 7:[1,2,3], 8:[1,2,3,4,5,6,7], 9:[1,2,3,4,6,7]}
  • coded={1:[30,50,80,50],7:[30,100,80,100],4:[30,150,80,150],6:[25,55,25,95],2:[85,55,85,95],3:[85,105,85,145],5:[25,105,25,145]}
  • codeu={1:[120,50,170,50],7:[120,100,170,100],4:[120,150,170,150],6:[115,55,115,95],2:[175,55,175,95],3:[175,105,175,145],5:[115,105,115,145]}
  • d=0
  • u=0
  • Canvas.__init__(self)
  • self.create_rectangle(0,0,200,200,fill="white",outline="white")
  • self.create_rectangle(10,30,190,170,width=2,fill="grey")
  • self.create_line(100,30,100,170,width=2)
  • self.create_line(30,50,80,50,width=5,fill="pink")
  • self.create_line(30,100,80,100,width=5,fill="pink")
  • self.create_line(30,150,80,150,width=5,fill="pink")
  • self.create_line(120,50,170,50,width=5,fill="pink")
  • self.create_line(120,100,170,100,width=5,fill="pink")
  • self.create_line(120,150,170,150,width=5,fill="pink")
  • self.create_line(25,55,25,95,width=5,fill="pink")
  • self.create_line(115,55,115,95,width=5,fill="pink")
  • self.create_line(85,55,85,95,width=5,fill="pink")
  • self.create_line(175,55,175,95,width=5,fill="pink")
  • self.create_line(25,105,25,145,width=5,fill="pink")
  • self.create_line(115,105,115,145,width=5,fill="pink")
  • self.create_line(85,105,85,145,width=5,fill="pink")
  • self.create_line(175,105,175,145,width=5,fill="pink")
  • def SetValue(self,consigne):
  • global root,d,u
  • self.create_line(30,50,80,50,width=5,fill="pink")
  • self.create_line(30,100,80,100,width=5,fill="pink")
  • self.create_line(30,150,80,150,width=5,fill="pink")
  • self.create_line(120,50,170,50,width=5,fill="pink")
  • self.create_line(120,100,170,100,width=5,fill="pink")
  • self.create_line(120,150,170,150,width=5,fill="pink")
  • self.create_line(25,55,25,95,width=5,fill="pink")
  • self.create_line(115,55,115,95,width=5,fill="pink")
  • self.create_line(85,55,85,95,width=5,fill="pink")
  • self.create_line(175,55,175,95,width=5,fill="pink")
  • self.create_line(25,105,25,145,width=5,fill="pink")
  • self.create_line(115,105,115,145,width=5,fill="pink")
  • self.create_line(85,105,85,145,width=5,fill="pink")
  • self.create_line(175,105,175,145,width=5,fill="pink")
  • root.update()
  • #Décomposition de la valeur à afficher en unités et dixaines
  • while(consigne>=10):
  • consigne=consigne-10
  • d=d+1
  • u=consigne
  • segu=list(chiffre [u])
  • segd=list(chiffre [d])
  • # Digits allumés
  • for i in segu:
  • self.create_line(codeu[i],width=5,fill="red")
  • for j in segd:
  • self.create_line(coded[j],width=5,fill="red")
  • root.update()
  • class Galva(Canvas):
  • def __init__(self,parent):
  • global valeur,root,aiguille,txt
  • root=parent
  • valeur=0.
  • b=0
  • a=0
  • Canvas.__init__(self)
  • #Dessin du Galva
  • self.create_rectangle(0,0,200,200,fill="white",outline="white")
  • self.create_rectangle(10,10,190,150,width=2,fill="white")
  • self.create_rectangle(10,120,190,150,width=2,fill="grey")
  • self.create_oval(25,25,175,175,width=2)
  • self.create_rectangle(12,60,188,118,fill="white",outline="white")
  • self.create_rectangle(12,121,188,148,fill="grey",outline="grey")
  • self.create_rectangle(10,151,190,200,fill="white",outline="white")
  • self.create_oval(90,125,110,145, width=2,fill="white")
  • self.create_line(108,127,92,143,width=5)
  • self.create_oval(95,100,105,110,fill="red",outline="red")
  • a=(3-(0/50.))*(pi/4)
  • x=100+90*cos(a)
  • y=105-90*sin(a)
  • aiguille=self.create_line(100,105,x,y,width=1,fill="red")
  • txt=self.create_text(12,160, text="0")
  • parent.update()
  • def SetValue(self,consigne):
  • global valeur,root,aiguille,txt
  • parent=root
  • while (int(valeur*100+.5)!=int(consigne*100+.5)):
  • if (valeur<consigne):
  • valeur=valeur+(float(consigne-valeur)/50)
  • float (valeur)
  • a=(3-(valeur/50.))*(pi/4)
  • x=100+90*cos(a)
  • y=105-90*sin(a)
  • self.delete(aiguille)
  • self.delete(txt)
  • aiguille=self.create_line(100,105,x,y,width=1,fill="red")
  • txt=self.create_text(12,160, text=int(valeur) )
  • parent.update()
  • time.sleep(0.002) #Définie l'inertie de l'aiguille (Timer)
  • elif(valeur>consigne):
  • valeur=valeur+(float(consigne-valeur)/50)
  • float (valeur)
  • a=(3-(valeur/50.))*(pi/4)
  • x=100+90*cos(a)
  • y=105-90*sin(a)
  • self.delete(aiguille)
  • self.delete(txt)
  • aiguille=self.create_line(100,105,x,y,width=1,fill="red")
  • txt=self.create_text(12,160, text=int(valeur) )
  • parent.update()
  • time.sleep(0.002) #Définie l'inertie de l'aiguille (Timer)
  • else:
  • float (valeur)
  • a=(3-(valeur/50.))*(pi/4)
  • x=100+90*cos(a)
  • y=105-90*sin(a)
  • self.delete(aiguille)
  • self.delete(txt)
  • aiguille=self.create_line(100,105,x,y,width=1,fill="red")
  • txt=can.create_text(12,160, text=int(valeur) )
  • parent.update()
  • time.sleep(0.002) #Définie l'inertie de l'aiguille (Timer)
  • class Bar(Canvas):
  • def __init__(self,parent):
  • global i,j,txt
  • i,j=25,170
  • Canvas.__init__(self)
  • #Dessin du Galva
  • self.create_rectangle(0,0,200,200,fill="white",outline="white")
  • self.create_rectangle(60,10,140,190,fill="grey")
  • m,j,k,l=25,65,125,175
  • consigne=random.randint(0,100)
  • txt=self.create_text(10,10,text="0")
  • while m<70:
  • self.create_line(70,m,130,m,width=5,fill="pink")
  • m=m+10
  • while m<120:
  • self.create_line(70,m,130,m,width=5,fill="yellow")
  • m=m+10
  • while m<180:
  • self.create_line(70,m,130,m,width=5,fill="aquamarine")
  • m=m+10
  • parent.update()
  • def SetValue(self,consigne):
  • global txt
  • parent=root
  • m,j,k,l=25,65,125,175
  • self.delete(txt)
  • while m<70:
  • self.create_line(70,m,130,m,width=5,fill="pink")
  • m=m+10
  • while m<120:
  • self.create_line(70,m,130,m,width=5,fill="yellow")
  • m=m+10
  • while m<180:
  • self.create_line(70,m,130,m,width=5,fill="aquamarine")
  • m=m+10
  • valeur=int(consigne*0.16)
  • txt=self.create_text(10,10,text=consigne)
  • while valeur>=12:
  • self.create_line(70,j,130,j,width=5,fill="red")
  • valeur=valeur-1
  • j=j-10
  • while valeur>=6:
  • self.create_line(70,k,130,k,width=5,fill="orange")
  • valeur=valeur-1
  • k=k-10
  • while valeur>=0:
  • self.create_line(70,l,130,l,width=5,fill="green")
  • valeur=valeur-1
  • l=l-10
  • parent.update()
# -*- coding: cp1252 -*-
# Enssemble de 3 types d'afficheurs :
# Baregraph, Galvanomètre et Afficheur 7 Segments.
#la consigne est une valeurncomprise entre 0 et 100.

from Tkinter import*
class segs(Canvas):
    def __init__(self,parent):
        global root,d,u,chiffre,coded,codeu
        root=parent
        chiffre={0:[1,2,3,4,5,6], 1:[2,3], 2:[1,2,7,5,4], 3:[1,2,3,4,7], 4:[6,7,2,3], 5:[1,6,7,3,4], 6:[1,6,5,4,3,7], 7:[1,2,3], 8:[1,2,3,4,5,6,7], 9:[1,2,3,4,6,7]}
        coded={1:[30,50,80,50],7:[30,100,80,100],4:[30,150,80,150],6:[25,55,25,95],2:[85,55,85,95],3:[85,105,85,145],5:[25,105,25,145]}
        codeu={1:[120,50,170,50],7:[120,100,170,100],4:[120,150,170,150],6:[115,55,115,95],2:[175,55,175,95],3:[175,105,175,145],5:[115,105,115,145]}
        d=0
        u=0
        Canvas.__init__(self)
        self.create_rectangle(0,0,200,200,fill="white",outline="white")
        self.create_rectangle(10,30,190,170,width=2,fill="grey")
        self.create_line(100,30,100,170,width=2)
        self.create_line(30,50,80,50,width=5,fill="pink")
        self.create_line(30,100,80,100,width=5,fill="pink")
        self.create_line(30,150,80,150,width=5,fill="pink")
        self.create_line(120,50,170,50,width=5,fill="pink")
        self.create_line(120,100,170,100,width=5,fill="pink")
        self.create_line(120,150,170,150,width=5,fill="pink")
        self.create_line(25,55,25,95,width=5,fill="pink")
        self.create_line(115,55,115,95,width=5,fill="pink")
        self.create_line(85,55,85,95,width=5,fill="pink")
        self.create_line(175,55,175,95,width=5,fill="pink")
        self.create_line(25,105,25,145,width=5,fill="pink")
        self.create_line(115,105,115,145,width=5,fill="pink")
        self.create_line(85,105,85,145,width=5,fill="pink")
        self.create_line(175,105,175,145,width=5,fill="pink")

    def SetValue(self,consigne):
        global root,d,u
        self.create_line(30,50,80,50,width=5,fill="pink")
        self.create_line(30,100,80,100,width=5,fill="pink")
        self.create_line(30,150,80,150,width=5,fill="pink")
        self.create_line(120,50,170,50,width=5,fill="pink")
        self.create_line(120,100,170,100,width=5,fill="pink")
        self.create_line(120,150,170,150,width=5,fill="pink")
        self.create_line(25,55,25,95,width=5,fill="pink")
        self.create_line(115,55,115,95,width=5,fill="pink")
        self.create_line(85,55,85,95,width=5,fill="pink")
        self.create_line(175,55,175,95,width=5,fill="pink")
        self.create_line(25,105,25,145,width=5,fill="pink")
        self.create_line(115,105,115,145,width=5,fill="pink")
        self.create_line(85,105,85,145,width=5,fill="pink")
        self.create_line(175,105,175,145,width=5,fill="pink")
        root.update()
    
        #Décomposition de la valeur à afficher en unités et dixaines
        while(consigne>=10):
            consigne=consigne-10
            d=d+1
        u=consigne
            
        segu=list(chiffre [u])
        segd=list(chiffre [d])
        # Digits allumés
        for i in segu:
            self.create_line(codeu[i],width=5,fill="red")
            
        for j in segd:
            self.create_line(coded[j],width=5,fill="red")

        root.update()

class Galva(Canvas):
    def __init__(self,parent):
        global valeur,root,aiguille,txt
        root=parent
        valeur=0.
        b=0
        a=0

        Canvas.__init__(self)
        #Dessin du Galva
        self.create_rectangle(0,0,200,200,fill="white",outline="white")
        self.create_rectangle(10,10,190,150,width=2,fill="white")
        self.create_rectangle(10,120,190,150,width=2,fill="grey")
        self.create_oval(25,25,175,175,width=2)
        self.create_rectangle(12,60,188,118,fill="white",outline="white")
        self.create_rectangle(12,121,188,148,fill="grey",outline="grey")
        self.create_rectangle(10,151,190,200,fill="white",outline="white")
        self.create_oval(90,125,110,145, width=2,fill="white")
        self.create_line(108,127,92,143,width=5)
        self.create_oval(95,100,105,110,fill="red",outline="red")
        a=(3-(0/50.))*(pi/4)
        x=100+90*cos(a)
        y=105-90*sin(a)
        aiguille=self.create_line(100,105,x,y,width=1,fill="red")
        txt=self.create_text(12,160, text="0")
            
        parent.update()

    def SetValue(self,consigne):
        global valeur,root,aiguille,txt
        parent=root
        
        while (int(valeur*100+.5)!=int(consigne*100+.5)):
            if (valeur<consigne):
                valeur=valeur+(float(consigne-valeur)/50)
                float (valeur)
                a=(3-(valeur/50.))*(pi/4)
                x=100+90*cos(a)
                y=105-90*sin(a)
                self.delete(aiguille)
                self.delete(txt)
                aiguille=self.create_line(100,105,x,y,width=1,fill="red")
                txt=self.create_text(12,160, text=int(valeur) )
                parent.update()
                time.sleep(0.002)       #Définie l'inertie de l'aiguille (Timer)
                

            elif(valeur>consigne):
                valeur=valeur+(float(consigne-valeur)/50)
                float (valeur)
                a=(3-(valeur/50.))*(pi/4)
                x=100+90*cos(a)
                y=105-90*sin(a)
                self.delete(aiguille)
                self.delete(txt)
                aiguille=self.create_line(100,105,x,y,width=1,fill="red")
                txt=self.create_text(12,160, text=int(valeur) )
                parent.update()
                time.sleep(0.002)       #Définie l'inertie de l'aiguille (Timer)
                

            else:
                float (valeur)
                a=(3-(valeur/50.))*(pi/4)
                x=100+90*cos(a)
                y=105-90*sin(a)
                self.delete(aiguille)
                self.delete(txt)
                aiguille=self.create_line(100,105,x,y,width=1,fill="red")
                txt=can.create_text(12,160, text=int(valeur) )
                parent.update()
                time.sleep(0.002)       #Définie l'inertie de l'aiguille (Timer)

class Bar(Canvas):
    def __init__(self,parent):
        global i,j,txt
        i,j=25,170

        Canvas.__init__(self)
        #Dessin du Galva
        self.create_rectangle(0,0,200,200,fill="white",outline="white")
        self.create_rectangle(60,10,140,190,fill="grey")
        m,j,k,l=25,65,125,175
        consigne=random.randint(0,100)
        txt=self.create_text(10,10,text="0")
        while m<70:
            self.create_line(70,m,130,m,width=5,fill="pink")
            m=m+10
        while m<120:
            self.create_line(70,m,130,m,width=5,fill="yellow")
            m=m+10
        while m<180:
            self.create_line(70,m,130,m,width=5,fill="aquamarine")
            m=m+10
            
        parent.update()

    def SetValue(self,consigne):
        global txt
        parent=root
        
        m,j,k,l=25,65,125,175
        self.delete(txt)
        while m<70:
            self.create_line(70,m,130,m,width=5,fill="pink")
            m=m+10
        while m<120:
            self.create_line(70,m,130,m,width=5,fill="yellow")
            m=m+10
        while m<180:
            self.create_line(70,m,130,m,width=5,fill="aquamarine")
            m=m+10
        valeur=int(consigne*0.16)
        txt=self.create_text(10,10,text=consigne)
        while valeur>=12:
            self.create_line(70,j,130,j,width=5,fill="red")
            valeur=valeur-1
            j=j-10
        while valeur>=6:
            self.create_line(70,k,130,k,width=5,fill="orange")
            valeur=valeur-1
            k=k-10
        while valeur>=0:
            self.create_line(70,l,130,l,width=5,fill="green")
            valeur=valeur-1
            l=l-10
        parent.update()

Conclusion

En espérant qu'ils puissent servir à quelqu'un...
 

Fichier Zip

Pour les "Membres Club", vous pouvez télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip

Commentaires et avis

signaler à un administrateur
Commentaire de fredmj le 01/12/2008 10:05:12

L'initiative est positive, même si il doit déjà en exister pas mal du même type.
Je n'ai pas encore essayé ces sources, mais j'ai déjà une petite remarque : Il serait utile d'avoir une règle (ou jauge) gradué sur chacun des widgets en plus du chiffre indicateur. Si une appli nécessite plusieurs jauges, c'est indispensable pour juger rapidement de l'ensemble des valeurs.

signaler à un administrateur
Commentaire de amaury74 le 02/12/2008 18:08:02

J'avais pensé pensé à graduer les indicateurs, mais comme les indications sont en pourcentages, les informations transmises pour les indicateurs sont tout de même très explicites.
Pour faire dans la précision, il faudra préférer un widget Label mis à jour régulièrement.
Ces widgets sont essentiellement conçus pour rendre une application plus conviviale.

Ajouter un commentaire

Discussions en rapport avec ce code source dans le forum

scrollbar dans scrollbox avec TKinter [ par MHI ] Est-ce que quelqu'un sait comment ajouter les scrollbar à une scrollbox :J'ai essayé ceci :lstFile = Tkinter.Listbox(frmMain)lstFile.place(x = 20, y = checkButton avec TKinter [ par MHI ] comment faire pour tester si un checkButton est coché ? Probleme avec TKinter [ par titasse ] Bonjour, je debute en python. J'ai un probleme lorsque je veux importer TKinter avec la commande from TKinter import * j'ai le message suivant : Imp au sujet de Tkinter et le module turtle [ par nico1900 ] from turtle import *forward(120)left(90)&nbsp;color('red')&nbsp;forward(80)bon en fait je voulais tester le module turtle&nbsp;avec&nbsp;l e code ci-d Un Canvas comme dans Tkinter, mais pour wxPython [ par samurize ] Slt tout le monde. &nbsp; Voila tout est dans le titre (ou a peu pres&nbsp; ) : &nbsp; Je suis &#224; la recherche d'un module pouvant s'integrer da Taille de widgets sous Tkinter [ par Uims ] Bonjour, Quelqu"un saurait comment definir la taille d'un widgets sous tkinter??? Exemple: fen 1 = Tk(taille=600) J'espere que je me fait comprend Ouverture d'un fichier windows (avec Tkinter) [ par Uims ] Bonjour, Je travaille sous python et Tkinter et j'aurai voulu savoir comment dire a python de demarrer (comme on clique sur un fichier) une applicati Tkinter et Python [ par Telimektar1er ] Voila j'ai commenc&#233; e python il y a une semaine et jusqu &#224; aujourd'hui aucun probl&#232;me. Mais voil&#224;, je viens de commencer la cr&#23 help, faire un mastermind en python et en tkinter avant le 24 !!! [ par Crick132 ] je suis &#233;tudiante en 2&#232;me ann&#233;e, je dois r&#233;aliser un mastermind en python avec 8 couleurs et 5 combinaisons possibles.si quelqu'un Importer une image dans Tkinter... [ par skools ] Bonjour à tous, Et pardon à ceux à qui j'ai envoyé des messages perso, je n'arrivais pas à poster un suget dans le forum... Voilà, après des heures d


Nos sponsors

Sondage...

CalendriCode

Juillet 2009
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
2728293031  

Consulter la suite du CalendriCode

Téléchargements

Logiciels à télécharger sur le même thème :

Comparez les prix Nouvelle version

Photothèque Nouveau !



Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés
Temps d'éxécution de la page : 0,374 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.