kivy_les_fichiers_kv
Différences
Ci-dessous, les différences entre deux révisions de la page.
Les deux révisions précédentesRévision précédenteProchaine révision | Révision précédenteProchaine révisionLes deux révisions suivantes | ||
kivy_les_fichiers_kv [2018/11/28 06:31] – [Nommage pour le fichier kv] serge | kivy_les_fichiers_kv [2020/01/20 18:32] – [Expressions Valeur et mots réservés] serge | ||
---|---|---|---|
Ligne 2: | Ligne 2: | ||
<WRAP center round box 60% centeralign> | <WRAP center round box 60% centeralign> | ||
**{{tagpage> | **{{tagpage> | ||
+ | **[[http:// | ||
</ | </ | ||
===== Le langage kivy dans les fichiers *.kv ===== | ===== Le langage kivy dans les fichiers *.kv ===== | ||
- | * [[https:// | + | * [[https:// |
- | * Ce qui suit est une adaptation de [[http:// | + | * Ce qui suit est une adaptation de kivy-vision.fr |
- | ===== kv ===== | + | ===== Ressources sur les fichiers |
* [[http:// | * [[http:// | ||
* [[http:// | * [[http:// | ||
- | * [[http:// | ||
- | ==== Nommage pour le fichier kv ==== | + | ===== Nommage pour le fichier kv ===== |
* [[http:// | * [[http:// | ||
- | === Exemple === | + | ==== Exemple |
**app_with_kv.py** | **app_with_kv.py** | ||
Ligne 55: | Ligne 55: | ||
Si vous ne respectez pas la convention, vous n' | Si vous ne respectez pas la convention, vous n' | ||
- | ==== Comment adapter un main.py avec Builder.load_string() pour un fichier *.kv ==== | + | ===== Comment adapter un main.py avec Builder.load_string() pour un fichier *.kv ===== |
Permet de comprendre comment les éléments du fichier kv sont lu! | Permet de comprendre comment les éléments du fichier kv sont lu! | ||
Ligne 118: | Ligne 118: | ||
text: "bla bla !" | text: "bla bla !" | ||
</ | </ | ||
- | ==== Explications sur les fichiers *.kv ==== | + | ===== Pricipes des fichiers *.kv ===== |
=== Règles === | === Règles === | ||
Ligne 132: | Ligne 132: | ||
Des templates seront utilisés pour construire des morceaux de votre application, | Des templates seront utilisés pour construire des morceaux de votre application, | ||
- | ==== Syntaxe d'un fichier kv ==== | + | ===== Syntaxe d'un fichier kv ===== |
Le fichier peut contenir des défitions de règles, un widget racine et des templates: | Le fichier peut contenir des défitions de règles, un widget racine et des templates: | ||
Ligne 138: | Ligne 138: | ||
<code python> | <code python> | ||
# Syntaxe de la définition d'une règle. Plusieurs règle peuvent partager la même définition. | # Syntaxe de la définition d'une règle. Plusieurs règle peuvent partager la même définition. | ||
- | #(as in CSS). Remarquez les caractère <>; Ils font parti de la définition. | + | #(as in CSS). Remarquez les caractère <>; Ils font partie |
< | < | ||
# .. definitions .. | # .. definitions .. | ||
Ligne 182: | Ligne 182: | ||
Lorsque vous indiquez la valeur d'une propriété, | Lorsque vous indiquez la valeur d'une propriété, | ||
- | ==== self ==== | + | === self === |
- | Le mot clé self fait référence à l' | + | Le mot clé self fait référence à l' |
<code python> | <code python> | ||
- | Button: | + | < |
- | text: "My state is {}" | + | |
+ | | ||
</ | </ | ||
- | ==== root ==== | + | === root === |
Ce mot clé n'est disponible que dans la définition des règles, et représente le widget racine de la règle (la première instance de la règle). Ce n'est pas le widget racine de tous les widgets. | Ce mot clé n'est disponible que dans la définition des règles, et représente le widget racine de la règle (la première instance de la règle). Ce n'est pas le widget racine de tous les widgets. | ||
Ligne 224: | Ligne 225: | ||
return root | return root | ||
</ | </ | ||
- | ==== app ==== | + | === app === |
Ce mot clé se réferre toujours à l' | Ce mot clé se réferre toujours à l' | ||
Ligne 235: | Ligne 236: | ||
Avec TestApp(App) retourne testapp | Avec TestApp(App) retourne testapp | ||
- | ==== args ==== | + | === args === |
Ce mot clé est disponible dans les on_action callbacks. Il fait référence aux arguments passés au callback: | Ce mot clé est disponible dans les on_action callbacks. Il fait référence aux arguments passés au callback: | ||
Ligne 254: | Ligne 255: | ||
</ | </ | ||
Attention, l'id ne sera pas disponible dans l' | Attention, l'id ne sera pas disponible dans l' | ||
+ | |||
+ | ===Exemple de récupération d'une propriété d'une autre class=== | ||
+ | Extrait de [[kivy_application_android_smart_citizen|Kivy: | ||
+ | {{ :: | ||
+ | Cet exemple pourrait être un excercice dans une interro surprise! On applique bêtement le cours ! Mais, M' | ||
+ | * app: Ce mot clé se réferre toujours à l' | ||
+ | * root: Ce mot clé n'est disponible que dans la définition des règles, et représente le widget racine de la règle, soit SmartCitizen | ||
+ | * ids: [[https:// | ||
+ | * get_screen(' | ||
+ | * owner_detail: | ||
===== Lien entre valeurs et propriétés ===== | ===== Lien entre valeurs et propriétés ===== | ||
- | Lorsque vous utilisez le langage Kivy, vous aurez remarqué que nous effectuons un certains travail en tâche de fond pour faire que les choses se déroulent correctement. Vous devriez savoir que les propriétés | + | Lorsque vous utilisez le langage Kivy, vous aurez remarqué que nous effectuons un certains travail en tâche de fond pour faire que les choses se déroulent correctement. Vous devriez savoir que les propriétés |
Le langage Kivy détecte les propriétés dans votre expression value et créé des callbacks pour mettre à jour automatiquement la propriété en utilisant votre expression lorsqu' | Le langage Kivy détecte les propriétés dans votre expression value et créé des callbacks pour mettre à jour automatiquement la propriété en utilisant votre expression lorsqu' | ||
Ligne 273: | Ligne 284: | ||
<code python> | <code python> | ||
Button: | Button: | ||
- | text: 'Plop world' if self.state == ' | + | text: ' |
</ | </ | ||
Le texte du bouton change en fonction de l' | Le texte du bouton change en fonction de l' | ||
Ligne 404: | Ligne 415: | ||
</ | </ | ||
- | {{tag> | + | =====Définir l' |
+ | |||
+ | <code python> | ||
+ | from kivy.app import App | ||
+ | from kivy.lang import Builder | ||
+ | |||
+ | kv = ''' | ||
+ | < | ||
+ | step: 1 | ||
+ | Label: | ||
+ | text: ' | ||
+ | size: self.texture_size | ||
+ | top: root.center_y - sp(20) | ||
+ | center_x: root.value_pos[0] | ||
+ | ''' | ||
+ | |||
+ | class ShortenText(App): | ||
+ | def build(self): | ||
+ | return Builder.load_string(kv) | ||
+ | |||
+ | ShortenText().run() | ||
+ | </ | ||
+ | équivaut à | ||
+ | <code python> | ||
+ | from kivy.app import App | ||
+ | from kivy.lang import Builder | ||
+ | from kivy.uix.slider import Slider | ||
+ | |||
+ | kv = ''' | ||
+ | < | ||
+ | step: 1 | ||
+ | Label: | ||
+ | text: ' | ||
+ | size: self.texture_size | ||
+ | top: root.center_y - sp(20) | ||
+ | center_x: root.value_pos[0] | ||
+ | ''' | ||
+ | |||
+ | class LabeledSlider(Slider): | ||
+ | pass | ||
+ | |||
+ | class ShortenText(App): | ||
+ | def build(self): | ||
+ | return Builder.load_string(kv) | ||
+ | |||
+ | ShortenText().run() | ||
+ | </ | ||
+ | {{tag> |
kivy_les_fichiers_kv.txt · Dernière modification : 2020/10/29 13:50 de serge