Accueil > > > ENSSEMBLE DE TROIS WIDGETS AFFICHEURS POUR TKINTER: AFF7SEG, GALVANOMÈTRE ET BAREGRAPH
ENSSEMBLE DE TROIS WIDGETS AFFICHEURS POUR TKINTER: AFF7SEG, GALVANOMÈTRE ET BAREGRAPH
Information sur la source
Description
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...
Sources du même auteur
Sources de la même categorie
Commentaires et avis
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) color('red') forward(80)bon en fait je voulais tester le module turtle avec l e code ci-d
Un Canvas comme dans Tkinter, mais pour wxPython [ par samurize ]
Slt tout le monde. Voila tout est dans le titre (ou a peu pres ) : Je suis à 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é e python il y a une semaine et jusqu à aujourd'hui aucun problème. Mais voilà, je viens de commencer la cr
help, faire un mastermind en python et en tkinter avant le 24 !!! [ par Crick132 ]
je suis étudiante en 2ème année, je dois ré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
|
Derniers Blogs
ENUMERABLECOLLECTIONENUMERABLECOLLECTION par Matthieu MEZIL
Prenons le scénario suivant. On utilise MVVM. On a les deux classes suivantes dans le model : public class Child { } public class Parent { private ObservableCollection < Child > _children; public ObservableCollection < Child > Children { get {...
Cliquez pour lire la suite de l'article par Matthieu MEZIL [HS] CHROME 6 + MOI = COUP DE GUEULE ![HS] CHROME 6 + MOI = COUP DE GUEULE ! par JeremyJeanson
Attention, le poste qui suit n'est pas la complainte d'une personne : Qui n'aime pas Chrome. D'un anti Google. D'un développeur qui a un poil énorme dans la main. Ceux qui me fréquentent savent que je change de navigateur favori tous les 2 ou 3 mois afin ...
Cliquez pour lire la suite de l'article par JeremyJeanson [WP7] UTILISER UN WRAPPANEL DANS UNE APPLICATION WINDOWS PHONE 7[WP7] UTILISER UN WRAPPANEL DANS UNE APPLICATION WINDOWS PHONE 7 par Audrey
Lors de la réalisation de ma 2ème application Windows Phone 7, j'ai souhaité utiliser un WrapPanel pour afficher plusieurs photos. Mais le contrôle WrapPanel ne fait pas parti de la liste des contrôles inclus dans le SDK de la version Beta des outils pour...
Cliquez pour lire la suite de l'article par Audrey [WP7] BESOIN D'AVOIR DES DONNéES EN CACHE[WP7] BESOIN D'AVOIR DES DONNéES EN CACHE par Nicolas
Les développeurs ASP.NET ont l'habitude de mettre des données en cache pour éviter de requêter a chaque fois la base de données. Et il est toujours utilie de penser que vos utilisateurs mobiles n'ont pas troujours une super connexion 3G/WIFI et un for...
Cliquez pour lire la suite de l'article par Nicolas [TFS] COMMENT FORCER LA SAISIE D'UN AREA OU ITERATION[TFS] COMMENT FORCER LA SAISIE D'UN AREA OU ITERATION par cyril
Lorsque l'on créé un Work Item dans TFS, il est possible de le classer dans un "area" et dans une "iteration". Dans la plupart des types de projet, un "area" correspond à une catégorie, une "iteration" à un numéro de version. Il est possible de cré...
Cliquez pour lire la suite de l'article par cyril
Forum
RE : PYTHON 3.0RE : PYTHON 3.0 par aera group
Cliquez pour lire la suite par aera group RE : PYTHON 3.0RE : PYTHON 3.0 par xeolin
Cliquez pour lire la suite par xeolin RE : PYTHON 3.0RE : PYTHON 3.0 par aera group
Cliquez pour lire la suite par aera group
Logiciels
Bureau de Gestion - ERP Devis Facturation (2.02)BUREAU DE GESTION - ERP DEVIS FACTURATION (2.02)
- Version gratuite du 10/06/2010
Le Bureau de Gestion est un logiciel dédié à la gestion de l'en...
Cliquez pour télécharger Bureau de Gestion - ERP Devis Facturation sDEVIS-FACTURES vlPRO (3.8.0)SDEVIS-FACTURES VLPRO (3.8.0)sDEVIS-FACTURES vlPRO a été mis au point pour permettre besoins des particuliers, créateurs, entr... Cliquez pour télécharger sDEVIS-FACTURES vlPRO LettresFaciles (5.6.0)LETTRESFACILES (5.6.0)LettresFaciles est un logiciel facilitant la création et la rédaction de lettres types.
Son inte... Cliquez pour télécharger LettresFaciles MyPlanning 2010 (5.6.0)MYPLANNING 2010 (5.6.0)MyPlanning 2010 permet de créer des plannings sous la représentation de diagrammes. Plannings pré... Cliquez pour télécharger MyPlanning 2010 Emicsoft Mac DVD en iPad Convertisseur (3.1.16)EMICSOFT MAC DVD EN IPAD CONVERTISSEUR (3.1.16)Emicsoft Mac DVD en iPad Convertisseur, logiciel professionnel de convertir les fichiers DVD en i... Cliquez pour télécharger Emicsoft Mac DVD en iPad Convertisseur
|