begin process at 2010 09 04 09:53:40
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Graphique

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

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

Les Membres Club peuvent télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip


 Sources du même auteur

Source avec Zip Source avec une capture LES CONTES DE MONTE CRYPTO
Source avec Zip Source avec une capture CALCUL DE RÉSISTANCES
Source avec Zip Source avec une capture BENCHMARK PAR LE CALCUL DE PI MULTITHREAD
Source avec Zip Source avec une capture BENCHMARK PAR LE CALCUL DE PI
Source avec Zip Source avec une capture PROGRESS BAR POUR TKINTER

 Sources de la même categorie

Source avec Zip Source avec une capture PYGTK : CODES ET EXPLICATIONS POUR DÉBUTER par loloof64
TK_WATCH :HORLOGE GRAPHIQUE par afranck64
Source avec une capture DESSIN DE DÉS À ÉCHELLE VARIABLE SUR CANVAS par calogerogigante
BOITE DE CONNEXION USER/PASSWORD POUR PYTHON:TK_LOGIN par afranck64
Source avec Zip Source avec une capture CALCUL DE RÉSISTANCES par amaury74

 Sources en rapport avec celle ci

Source avec Zip Source avec une capture CASSE BRIQUE par elnabo
Source avec Zip Source avec une capture ILLUSTRATION DE SINUS ET DE COSINUS par calogerogigante
Source avec Zip CALCULATRICE SIMPLICISTE SOUS TKINTER par elnabo
Source avec Zip WIDGET TKINTER par gaulthier
Source avec Zip Source avec une capture GALVANOMÈTRE par amaury74

Commentaires et avis

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.

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...

Comparez les prix

CalendriCode

Septembre 2010
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
27282930   

Consulter la suite du CalendriCode

 
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

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 0,749 sec (3)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales