Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in
Toggle navigation
W
WebRadioPi
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Thorfin89
WebRadioPi
Commits
4a2fc25c
Commit
4a2fc25c
authored
Jan 27, 2023
by
Thorfin89
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Finalement la solution n'était pas bonne
parent
e08e98b6
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
16 additions
and
21 deletions
+16
-21
main.py
main.py
+3
-5
pupitre.py
pupitre.py
+13
-16
No files found.
main.py
View file @
4a2fc25c
...
@@ -4,12 +4,10 @@
...
@@ -4,12 +4,10 @@
# import ----------------------------------
# import ----------------------------------
from
vlc
import
Instance
from
vlc
import
Instance
'''
installer le paquet python-vlc :
$ sudo pip3 install python-vlc
installer aussi l'application VLC
'''
''' installer le paquet python-vlc :
$ sudo pip3 install python-vlc
installer aussi l'application VLC '''
from
pupitre
import
Pupitre
from
pupitre
import
Pupitre
...
...
pupitre.py
View file @
4a2fc25c
...
@@ -8,16 +8,12 @@ from tkinter import ttk, Scale, HORIZONTAL, CENTER
...
@@ -8,16 +8,12 @@ from tkinter import ttk, Scale, HORIZONTAL, CENTER
import
csv
import
csv
import
os
import
os
# récupérer le chemin du répertoire courant
''' Pour éviter d'avoir des problèmes de chemin
quand on lance le programme de n'importe quel endroit'''
current_path
=
os
.
getcwd
()
mute
=
False
# le son n'est pas coupé au démarrage
mute
=
False
# le son n'est pas coupé au démarrage
bg_color
=
"gray"
bg_color
=
"gray"
# Chargement du fichier CSV contenant les informations : Nom, Pays, Type, Url, Logo
# Chargement du fichier CSV contenant les informations : Nom, Pays, Type, Url, Logo
with
open
(
current_path
+
"
/data/radios.csv"
,
'r'
,
encoding
=
'utf-8-sig'
)
as
radios_file
:
with
open
(
".
/data/radios.csv"
,
'r'
,
encoding
=
'utf-8-sig'
)
as
radios_file
:
''' utf-8-sig au lieu de utf-8 pour éviter l'erreur sur le nom du 1er champ '
\ufeff
Nom'
''' utf-8-sig au lieu de utf-8 pour éviter l'erreur sur le nom du 1er champ '
\ufeff
Nom'
pour extraire une donnée : radios_list[numéro de la radio][nom du champ]'''
pour extraire une donnée : radios_list[numéro de la radio][nom du champ]'''
...
@@ -40,13 +36,13 @@ class Pupitre:
...
@@ -40,13 +36,13 @@ class Pupitre:
self
.
root
.
attributes
(
'-fullscreen'
,
False
)
# < à basculer sur False pour les tests sur PC
self
.
root
.
attributes
(
'-fullscreen'
,
False
)
# < à basculer sur False pour les tests sur PC
# images des boutons
# images des boutons
self
.
icon_back
=
tk
.
PhotoImage
(
file
=
current_path
+
"
/icons/back.png"
)
self
.
icon_back
=
tk
.
PhotoImage
(
file
=
".
/icons/back.png"
)
self
.
icon_play
=
tk
.
PhotoImage
(
file
=
current_path
+
"
/icons/play.png"
)
self
.
icon_play
=
tk
.
PhotoImage
(
file
=
".
/icons/play.png"
)
self
.
icon_pause
=
tk
.
PhotoImage
(
file
=
current_path
+
"
/icons/pause.png"
)
self
.
icon_pause
=
tk
.
PhotoImage
(
file
=
".
/icons/pause.png"
)
self
.
icon_stop
=
tk
.
PhotoImage
(
file
=
current_path
+
"
/icons/stop.png"
)
self
.
icon_stop
=
tk
.
PhotoImage
(
file
=
".
/icons/stop.png"
)
self
.
icon_forward
=
tk
.
PhotoImage
(
file
=
current_path
+
"
/icons/forward.png"
)
self
.
icon_forward
=
tk
.
PhotoImage
(
file
=
".
/icons/forward.png"
)
self
.
icon_sound
=
tk
.
PhotoImage
(
file
=
current_path
+
"
/icons/sound_up.png"
)
self
.
icon_sound
=
tk
.
PhotoImage
(
file
=
".
/icons/sound_up.png"
)
self
.
icon_mute
=
tk
.
PhotoImage
(
file
=
current_path
+
"
/icons/mute.png"
)
self
.
icon_mute
=
tk
.
PhotoImage
(
file
=
".
/icons/mute.png"
)
self
.
zones
()
# affichage des 3 zones
self
.
zones
()
# affichage des 3 zones
self
.
mosaique
()
# affichage d'une mosaïque de logos des radios
self
.
mosaique
()
# affichage d'une mosaïque de logos des radios
...
@@ -99,7 +95,7 @@ class Pupitre:
...
@@ -99,7 +95,7 @@ class Pupitre:
# potentiomètre de volume
# potentiomètre de volume
# - on charge la configuration du volume sauvegardée
# - on charge la configuration du volume sauvegardée
lecture
=
open
(
current_path
+
"/
webradiopi.cfg"
,
"r"
)
lecture
=
open
(
"
webradiopi.cfg"
,
"r"
)
volume_init
=
lecture
.
read
()
volume_init
=
lecture
.
read
()
lecture
.
close
()
lecture
.
close
()
# - affichage du potentiomètre de volume
# - affichage du potentiomètre de volume
...
@@ -124,9 +120,10 @@ class Pupitre:
...
@@ -124,9 +120,10 @@ class Pupitre:
try
:
try
:
if
radios_list
[
num_radio
][
'Logo'
]
!=
""
:
# si un logo est associé à la radio
if
radios_list
[
num_radio
][
'Logo'
]
!=
""
:
# si un logo est associé à la radio
self
.
logo
[
num_radio
]
=
tk
.
PhotoImage
(
file
=
current_path
+
"/images/"
+
radios_list
[
num_radio
][
'Logo'
])
self
.
logo
[
num_radio
]
=
tk
.
PhotoImage
(
file
=
"./images/"
+
radios_list
[
num_radio
][
'Logo'
])
else
:
# s'il n'y a pas de logo pour la radio
else
:
# s'il n'y a pas de logo pour la radio
self
.
logo
[
num_radio
]
=
tk
.
PhotoImage
(
file
=
current_path
+
"
/images/radio.png"
)
self
.
logo
[
num_radio
]
=
tk
.
PhotoImage
(
file
=
".
/images/radio.png"
)
# création du bouton avec le logo de la radio
# création du bouton avec le logo de la radio
btn_logo
=
tk
.
Button
(
self
.
zone_mosaique
,
image
=
self
.
logo
[
num_radio
])
btn_logo
=
tk
.
Button
(
self
.
zone_mosaique
,
image
=
self
.
logo
[
num_radio
])
# utilisation d'une fonction 'lambda' indexée sur la position du logo
# utilisation d'une fonction 'lambda' indexée sur la position du logo
...
@@ -141,7 +138,7 @@ class Pupitre:
...
@@ -141,7 +138,7 @@ class Pupitre:
def
radio_selected
(
self
,
num_radio
):
def
radio_selected
(
self
,
num_radio
):
self
.
radio_flux
(
radios_list
[
num_radio
][
'Url'
])
self
.
radio_flux
(
radios_list
[
num_radio
][
'Url'
])
# affichage de la radio sélectionnée
# affichage de la radio sélectionnée
self
.
logo_selected
=
tk
.
PhotoImage
(
file
=
current_path
+
"
/images/Large/"
+
radios_list
[
num_radio
][
'Logo'
])
self
.
logo_selected
=
tk
.
PhotoImage
(
file
=
".
/images/Large/"
+
radios_list
[
num_radio
][
'Logo'
])
self
.
lbl_radio_selected
.
config
(
image
=
self
.
logo_selected
)
self
.
lbl_radio_selected
.
config
(
image
=
self
.
logo_selected
)
# print(radios_list[1]['Nom'])
# print(radios_list[1]['Nom'])
self
.
lbl_info_radio
.
config
(
text
=
radios_list
[
num_radio
][
'Nom'
],
font
=
(
'Helvatical bold'
,
20
))
self
.
lbl_info_radio
.
config
(
text
=
radios_list
[
num_radio
][
'Nom'
],
font
=
(
'Helvatical bold'
,
20
))
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment