Skip to content
Snippets Groups Projects

Compare revisions

Changes are shown as if the source revision was being merged into the target revision. Learn more about comparing revisions.

Source

Select target project
No results found

Target

Select target project
  • Alexandre.Meyer/m1if37-animation
  • Alexandre.Meyer/m2-apprentissage-profond-image
  • Alexandre.Meyer/m2-animation
  • Alexandre.Meyer/hugo-web-minimal
  • Alexandre.Meyer/lifami
  • Alexandre.Meyer/lifapcd
  • Alexandre.Meyer/www
  • Alexandre.Meyer/lifstage
8 results
Show changes
Commits on Source (61)
Showing
with 538 additions and 273 deletions
# Master 1 Informatique - UE M1if37 Animation en synthèse d'image (3 ECTS)
## Contrôle de mouvement
Télécharger [les transparents du cours](documents/NP_controle/M1IF37_CM_CONTROLEUR.pdf)
Télécharger [l'énoncé du TP](documents/NP_controle/M1IF37_TP_CONTROLEUR.pdf)
Accéder [aux ressources pour le TP](TP/NP_controle)
Télécharger [le modèle pour le rapport](documents/NP_controle/M1IF37_TP_CONTROLEUR-modele_rapport.docx)
\ No newline at end of file
# Master 1 Informatique - UE M1if37 Animation en synthèse d'image (3 ECTS)
# Site web et ressources de l'UE UE M1if37 Animation en synthèse d'image
Responsables de l'enseignement : A. Meyer, N. Pronost et F. Zara
Volume horaire : 10h30 CM, 18h TP
[La page de l'UE est ici](http://alexandre.meyer.pages.univ-lyon1.fr/m1if37-animation/)
[]() <img src="images/im1.png" height="150">
[]() <img src="images/im2.png" height="150">
## Objectif de l'UE
L'objectif de l'UE est de donner les bases de l'animation en synthèse d'images. Nous aborderons les deux grandes familles de méthodes. L'animation basée sur des données, par exemple pour l'animation d'humain virtuel (données issues de capture de mouvement). Et l'animation basée sur un modèle physique pour la simulation de phénomènes naturels comme le mouvement de textiles ou de fluide. L'UE laissera une grande part à l'application pratique avec la réalisation de TPs en C++/OpenGL proposant d'animer par exemple des humains virtuels, des vêtements, des cordes, une surface d'eau, etc.
## Explication de la génération
[Les slides de la présentation des options sont ici](documents/M1if37_PresOption.pdf)
Le site web est désormais fabriqué par ```Hugo``` (thème [congo](https://jpanther.github.io/congo/)). les sources se trouvent dans le répertoire ```web```.
Le site web est mis à jour par intégration continue (CI/CD) à chaque fois que vous faites un push (rien besoin d'autre, à part attendre quelques secondes). Le script d'intégration continue est ```.gitlab-ci.yml```. Pour voir le résultat du script de génération, [allez ici](https://forge.univ-lyon1.fr/Alexandre.Meyer/m1if37-animation/-/jobs) ou depuis l'interface dans CI/Jobs.
Le fichier ```site/config.toml``` permet de configurer la génération du site. Mais normalement il n'y a pas besoin d'y toucher.
* Les pages web sont générées à partir du répertoire ```web/content```.
* La page principale du site est ```web/content/_index.html```. Il faut bien laissé le ```_```, il indique qu'il y a des sous-répertoires
* ```web/content/controle``` pour la partie "Conrtôle d'animation". ```web/content/controle/index.md``` produit la page de cette partie.
* ```web/content/personnage``` pour la partie "Animation de personnage virtuel".
* ```web/static``` : les fichiers autres (pdf, images, sujets, etc.) sont à ranger dedans. Par exemple, il y a
* ```web/static/images``` pour les images du site;
* ```web/static/doc``` documents généraux de l'UE;
* ```web/static/doc_controle``` documents de la partie contrôle (NP);
* ```web/static/doc_charanim``` documents de la partie personnage (AM);
## Thématiques abordées
### Animation par modèles physiques (F. Zara) - 4h30 CM, 6h TP
* Concepts physiques (forces, lois de Newton)
* Méthodes d'intégration numérique
* [La page de cette partie](https://perso.liris.cnrs.fr/fzara/Web/M1Animation.html)
## Si Fork
Par défaut, gitlba ajoute de '-' un peu partout, vous pouvez changer l'adresse web dans Settings/General/Advanced/Change path.
### Animation de personnage (A. Meyer) - 4h30 CM, 6h TP
* Animation basée squelette
* Déformation de maillage (skinning)
* [La page de cette partie](https://perso.liris.cnrs.fr/alexandre.meyer/public_html/www/doku.php?id=charanim_m1#master_1_informatique_-_ue_m1if37_animation_en_synthese_d_image)
## Tester le site en local
Pour tester vos mises à jour en local :
* installer hugo : ```sudo apt install hugo```
* dans le répertoire web, faire ```hugo serve```
* dans votre navigateur, entrez l'url ```localhost:8000```
### Contrôle de mouvement (Nicolas Pronost) - 1h30 CM, 6h TP
* Mouvement d'objets rigides articulés
* [La page de cette partie](NP_controle.md)
Vous pouvez aussi essayer de contruire le site en static en faisant juste ```hugo``` : le site sera constuit dans le répertoire public.
## Emploi du temps 2023
![]() <img src="documents/M1if37_edt.png" width="400">
## Modalités de contrôle des connaissances (MCC)
* 1 note de CCF portant sur les 3 parties du cours : examen le mardi 21 juin, de 8h à 9h30, salle : ??, Nautibus
* 3 notes de TP : TP F. Zara, TP A. Meyer, TP N. Pronost (code + rapport + démo ou vidéo)
* Examen écrit : mercredi 22 mai 8h-9h30
* Démo de TP : mercredi 22 mai, de 9h45 à 12h
* Date limite de rendu des 3 archives : mercredi 22 mai 12h
Une archive sera à déposer sur TOMUSS (dans les 3 colonnes correspondantes). Cette archive contiendra le code du TP + un rapport.
Nous vous demandons également de mettre dans les 3 autres colonnes correspondantes de TOMUSS, l'URL pour accéder à une vidéo de votre projet, si vous ne faites pa de démo (car nous ne le compilerons pas forcément, donc il faut montrer tout votre travail).
Toutes les infos sont détaillées ici !
Pour convertir du DOKUWIKI en Markdown, on peut utiliser pandoc??? (todo) ou certains web en ligne.
File deleted
documents/M1if37_edt.png

166 KiB

images/M1if37.png

21.4 KiB

images/im1.png

212 KiB

images/im2.png

67.2 KiB

---
title: "{{ replace .Name "-" " " | title }}"
date: {{ .Date }}
draft: true
draft: false
---
baseURL = "http://alexandre.meyer.pages.univ-lyon1.fr/m1if37-animation/"
title = "Animation en synthèse d'images"
title = "M1if37 Animation en synthèse d'images"
#theme = "etch"
theme = "hugo-flex"
#theme = "ucax"
#theme = "paige"
#theme = "hugo-flex"
theme = "congo"
languageCode = "fr-FR"
enableInlineShortcodes = true
pygmentsCodeFences = true
......@@ -9,32 +12,58 @@ pygmentsUseClasses = true
publishDir = "public"
# [author]
# name = "Alexandre Meyer"
# image = "img/author.jpg"
# headline = "M1if37"
# bio = ""
[params]
description = "Animation en synthèse d'images"
copyright = ""
dark = "auto"
highlight = true
color = "gray" # Any color in CSS syntax
width = "42rem" # Any length in CSS syntax
mainSections = "personnage;controle;posts"
#color = "gray" # Any color in CSS syntax
#width = "52rem" # Any length in CSS syntax
colorScheme = "fire"
# footer= ""
# rss = ""
article.showDate = false
favicon = "favicon.ico"
# [[footer]]
# name = "Privacy"
# url = "https://external-link"
# - name: Aboutaaa
# url: about/
# weight: 1
[menu]
[[menu.nav]]
identifier = "home"
name = "home"
title = "home"
url = "home/"
[[menu.main]]
identifier = "Physique"
name = "Physique"
title = "Physique"
url = "https://perso.liris.cnrs.fr/fzara/Web/M1Animation.html"
weight = 1
[[menu.nav]]
identifier = "controle"
name = "controle"
title = "controle"
url = "controle/"
[[menu.main]]
identifier = "Personnage"
name = "Personnage"
title = "Personnage"
url = "/personnage/"
weight = 2
[[menu.main]]
identifier = "Controle"
name = "Controle"
title = "Controle"
url = "/controle/"
weight = 3
[permalinks]
posts = "/:title/"
......
# baseURL: 'http://alexandre.meyer.pages.univ-lyon1.fr/m1if37-animation/'
# #baseURL: 'http://alexandre.meyer.pages.univ-lyon1.fr/'
# title: Animation en synthèse d'images
# author: Alexandre Meyer
# languageCode: fr-FR
# pygmentsCodeFences: true
# enableRobotsTXT: true
# theme: hugo-flex
# publishDir: public
# params:
# color: gray # Any color in CSS syntax
# width: 42rem # Any length in CSS syntax
# footer: >- # HTML spaces (&#32;) are needed before HTML elements
# Except where otherwise noted, content on this site is licensed under a &#32;
# <a href="http://creativecommons.org/licenses/by/4.0/" rel="license">Creative
# Commons Attribution 4.0 International License</a>.
# rss: To subscribe to this RSS feed, copy its address and paste it into your
# favorite feed reader.
# summaries: false # Set to true to show summaries of posts on homepage
# divider: \a0 # Set to false to remove divider below posts on homepage
# schema: false # Set to true to add Schema.org metadata
# opengraph: false # Set to true to add Open Graph metadata
# twittercards: false # Set to true to add Twitter Cards metadata
# utterances:
# repo: # Set to Utterances repo URL to add Utterances comments
# issueterm: pathname
# theme: github-light
# netlify:
# honeypot: false # Set to true to add honeypot field in contact form
# recaptcha: false # Set to true to add recaptcha challenge in contact form
# # css: # Uncomment to add custom CSS from the assets directory
# # - css/foo.css
# # - bar.css
# # js: # Uncomment to add custom JS from the assets directory
# # - js/foo.js
# # - bar.js
# menu:
# nav:
# - name: Aboutaaa
# url: about/
# weight: 1
# - name: Posts
# url: post/
# weight: 2
# - name: Tags
# url: tags/
# weight: 3
# - name: Categories
# url: categories/
# weight: 4
# - name: RSS
# url: index.xml
# weight: 5
# # baseURL: 'http://alexandre.meyer.pages.univ-lyon1.fr/m1if37-animation/'
# # title: Animation en synthèse d'images
# # author: Alexandre Meyer
# # languageCode: fr-FR
# # pygmentsCodeFences: true
# # enableRobotsTXT: true
# # theme: hugo-flex
# # publishDir: public
# # permalinks:
# # posts: '/:filename/'
# # pages: '/:filename/'
# # params:
# # color: gray
# # width: 42rem
# # description: M1if37 Animation en synthèse d'images
# # # footer: Except where otherwise noted, content on this site is licensed under a
# # # a <a href="http://creativecommons.org/licenses/by/4.0/" rel="license">
# # # Creative Commons Attribution 4.0 International License</a>.
# # # rss: >-
# # # To subscribe to this RSS feed, copy the address in the address bar and paste
# # # it into your favorite feed reader.
# # divider: '\2015\2015' # Set to false to remove divider below posts on homepage
# # schema: true
# # opengraph: true
# # twittercards: true
# # summaries: false
# # utterances:
# # repo: # Set to Utterances repo URL to add Utterances comments
# # issueterm: pathname
# # theme: github-light
# # netlify:
# # honeypot: false # Set to true to add honeypot field in contact form
# # recaptcha: false # Set to true to add recaptcha challenge in contact form
# # # css: # Uncomment to add custom CSS from a list of files
# # # - css/foo.css
# # # - bar.css
# # # js: # Uncomment to add custom JS from a list of files
# # # - js/foo.js
# # # - bar.js
# # # menu:
# # # nav:
# # # - name: M1if37
# # # url: about/
# # # weight: 1
# # # - name: Posts
# # # url: posts/
# # # weight: 2
# # menu:
# # nav:
# # - name: About
# # url: about/
# # weight: 1
# # - name: Blog
# # url: posts/
# # weight: 2
# # - name: M1if37
# # url:
# # weight: 3
# # - name: Categories
# # url: categories/
# # weight: 4theme: hugo-flex
# Master 1 Informatique - UE M1if37 Animation en synthèse d'image (3 ECTS)
Responsables de l'enseignement : [Alexandre Meyer](
http://liris.cnrs.fr/alexandre.meyer), [Nicolas Pronost](
http://liris.cnrs.fr/nicolas.pronost) et [Florence Zara](
http://liris.cnrs.fr/florence.zara) - LIRIS, Université Lyon 1
Volume horaire : 10h30 CM, 19h30 TP
![im_all.png](images/im_all.png)
## Objectif de l'UE
<p style="text-align:justify;">M1if37 est une UE optionnelle de la 1ère année du Master d'Informatique de l'Université Lyon 1. Les cours ont lieu au semestre 2 (printemps). L'objectif de l'UE est de donner les bases de l'animation en synthèse d'images. Nous aborderons les deux grandes familles de méthodes. L'animation basée sur des données, par exemple pour l'animation d'humain virtuel (données issues de capture de mouvement). Et l'animation basée sur un modèle physique pour la simulation de phénomènes naturels comme le mouvement de textiles ou de fluide. L'UE laissera une grande part à l'application pratique avec la réalisation de TPs en C++/OpenGL proposant d'animer par exemple des humains virtuels, des vêtements, des cordes, une surface d'eau, etc.</p>
[Les slides de la présentation des options sont ici.](doc/M1if37_PresOption.pdf)
## Thématiques abordées
### Animation par modèles physiques (F. Zara) - 4h30 CM, 6h45 TP
* Concepts physiques (forces, lois de Newton)
* Méthodes d'intégration numérique
* [La page web de cette partie](https://perso.liris.cnrs.fr/fzara/Web/M1Animation.html)
### Animation de personnage (A. Meyer) - 4h30 CM, 6h45 TP
* Animation basée squelette
* Graphe d'animation
* Capture de mouvement
* [La page web de cette partie](personnage)
### Contrôle de mouvement (Nicolas Pronost) - 1h30 CM, 6h TP
* Mouvement d'objets rigides articulés
* [La page web de cette partie](controle)
## Emploi du temps 2024-2025
![documents/M1if37_edt.png](doc/M1if37_edt.png)
* Cours en salle TD005 Nautibus
* TP en salles TP121, TP123 Nautibus
## Modalités de contrôle des connaissances (MCC)
* **1 note de CCF** portant sur les 3 parties du cours
* **3 notes de TP** : TP F. Zara, TP A. Meyer, TP N. Pronost (code + rapport + démo ou vidéo)
* **Dates des évaluations** :
* Examen écrit : **mercredi 28 mai 2025, 8h à 9h30** en salle C008 Nautibus
* Démo de TP : **mercredi 28 mai 2025, de 9h45 à 13h** en TP121, TP123 Nautibus
* Date limite de rendu des 3 archives : **mercredi 28 mai 2025 13h**
* **Modalité de rendu des TPs :** <p style="text-align:justify;">
* Une archive sera à déposer sur TOMUSS (dans les 3 colonnes correspondantes). Cette archive contiendra le code du TP + un rapport.
* Nous vous demandons également de mettre dans les 3 autres colonnes correspondantes de TOMUSS, l'URL pour accéder à une vidéo de votre projet, si vous ne faites pas de démo (car nous ne le compilerons pas forcément, donc il faut montrer tout votre travail).</p>
about/_index.md
M1if37 about inside
\ No newline at end of file
# Master 1 Informatique - UE M1if37 Animation en synthèse d'image (3 ECTS)
## Contrôle de mouvement
Télécharger [les transparents du cours](documents/NP_controle/M1IF37_CM_CONTROLEUR.pdf)
Télécharger [l'énoncé du TP](documents/NP_controle/M1IF37_TP_CONTROLEUR.pdf)
Accéder [aux ressources pour le TP](TP/NP_controle)
Télécharger [le modèle pour le rapport](documents/NP_controle/M1IF37_TP_CONTROLEUR-modele_rapport.docx)
\ No newline at end of file
# Master 1 Informatique - UE M1if37 Animation en synthèse d'image (3 ECTS)
## Contrôle de mouvement
Télécharger [les transparents du cours](../doc_controle/M1IF37_CM_CONTROLEUR.pdf)
Télécharger [l'énoncé du TP](../doc_controle/M1IF37_TP_CONTROLEUR.pdf)
Accéder [aux ressources pour le TP](../doc_controle/tp.zip)
Télécharger [le modèle pour le rapport](../doc_controle/M1IF37_TP_CONTROLEUR-modele_rapport.docx)
\ No newline at end of file
# Master 1 Informatique - UE M1if37 Animation en synthèse d'image (3 ECTS)
Responsables de l'enseignement : [Alexandre Meyer](
http://liris.cnrs.fr/alexandre.meyer), [Nicolas Pronost](
http://liris.cnrs.fr/nicolas.pronost) et [Florence Zara](
http://liris.cnrs.fr/florence.zara)
Volume horaire : 10h30 CM, 19h30 TP
![im_all.png](images/im_all.png)
## Objectif de l'UE
M1if37 est une UE optionnelle de la 1ère année du Master d'Informatique de l'Université Lyon 1. Les cours ont lieu au semestre 2 (printemps). L'objectif de l'UE est de donner les bases de l'animation en synthèse d'images. Nous aborderons les deux grandes familles de méthodes. L'animation basée sur des données, par exemple pour l'animation d'humain virtuel (données issues de capture de mouvement). Et l'animation basée sur un modèle physique pour la simulation de phénomènes naturels comme le mouvement de textiles ou de fluide. L'UE laissera une grande part à l'application pratique avec la réalisation de TPs en C++/OpenGL proposant d'animer par exemple des humains virtuels, des vêtements, des cordes, une surface d'eau, etc.
[Les slides de la présentation des options sont ici](documents/M1if37_PresOption.pdf)
## Thématiques abordées
### Animation par modèles physiques (F. Zara) - 4h30 CM, 6h30 TP
* Concepts physiques (forces, lois de Newton)
* Méthodes d'intégration numérique
* [La page de cette partie](https://perso.liris.cnrs.fr/fzara/Web/M1Animation.html)
### Animation de personnage (A. Meyer) - 4h30 CM, 6h30 TP
* Animation basée squelette
* Déformation de maillage (skinning)
* [La page de cette partie](https://perso.liris.cnrs.fr/alexandre.meyer/public_html/www/doku.php?id=charanim_m1#master_1_informatique_-_ue_m1if37_animation_en_synthese_d_image)
### Contrôle de mouvement (Nicolas Pronost) - 1h30 CM, 6h30 TP
* Mouvement d'objets rigides articulés
* [La page de cette partie](NP_controle.md)
## Emploi du temps 2023
![documents/M1if37_edt.png](documents/M1if37_edt.png)
## Modalités de contrôle des connaissances (MCC)
* 1 note de CCF portant sur les 3 parties du cours : examen le mardi 21 juin, de 8h à 9h30, salle : ??, Nautibus
* 3 notes de TP : TP F. Zara, TP A. Meyer, TP N. Pronost (code + rapport + démo ou vidéo)
* Examen écrit : mercredi 22 mai 8h-9h30
* Démo de TP : mercredi 22 mai, de 9h45 à 12h
* Date limite de rendu des 3 archives : mercredi 22 mai 12h
Une archive sera à déposer sur TOMUSS (dans les 3 colonnes correspondantes). Cette archive contiendra le code du TP + un rapport.
Nous vous demandons également de mettre dans les 3 autres colonnes correspondantes de TOMUSS, l'URL pour accéder à une vidéo de votre projet, si vous ne faites pa de démo (car nous ne le compilerons pas forcément, donc il faut montrer tout votre travail).
---
title: ""
description: "Partie Animation de personnage"
---
# Partie Animation de personnage
* Alexandre Meyer
* 4h30 CM, 6h30 TP
* [L'ancienne page de cette partie](https://perso.liris.cnrs.fr/alexandre.meyer/public_html/www/doku.php?id=charanim_m1#master_1_informatique_-_ue_m1if37_animation_en_synthese_d_image)
![](../doc_charanim/charanim_tpose.jpg)
## Cours
* [Systèmes articulés : cinématique directe](https://perso.liris.cnrs.fr/alexandre.meyer/teaching/master_charanim/aPDF_COURS_M1/M1_1_SkeletonBasedAnimation.pdf)
* [Edition d'animations, Graphe d'animations](https://perso.liris.cnrs.fr/alexandre.meyer/teaching/master_charanim/aPDF_COURS_M1/M1_2_MotionControlAndEditing.pdf)
* [Capture de mouvements](https://perso.liris.cnrs.fr/alexandre.meyer/teaching/master_charanim/aPDF_COURS_M1/M1_3_MotionCapture.pdf)
## Les vidéos des 3 CM (2020)
[Les vidéos](video)
## Le TP
* [Le code initial](code)
* [TP animation de personnage](tp)
#### Rendu
TP Animation de personnage virtuel
* Les archives sont à rendre sur TOMUSS
* vous devez rendre une archive avec un readme.txt ou readme.md expliquant ce que vous avez fait et comment lancer le programme
* une VIDEO de DEMO ou une démo en LIVE
Barème "Personnage"
* (5 points) TP 1ère partie : affichage d'une animation BVH
* (3 points) Contrôleur d'animation : la base (pilotage au clavier d'un déplacement)
* Machine à état (4 points maximum)
* basique : pour une machine à état de base avec 4 animations : idle, marcher, courir, sauter ou kick
* avancé : une machine à état plus complète avec de nombreuses animations (une dizaine) : voir celles du répertoire motionGraph_second_life, etc.
* Motion Graphe (6 points)
* basique : transition vers un autre animation en cherchant à la volée une transition compatible
* avancé : un motion graph construit automatiquement en pré-calcul
* (3 points) Interpolation entre 2 frames, à utilise pour les transitions ou pour une bonne gestion du temps
* (2 points) Collision entre personnage et sphères (voir le code PhysicalWorld)
* (1 points) bonus de qualité/cohérence de la scène
Le total fait plus que 20 car les points FSM/graphe d'animation sont à comprendre avec un OU : la machine à état rapporte moins de points, car moins difficile.
# Code pour les TP d'animation de personnage en C++ (en M1)
## Les fichiers à recupérer
Le code se base sur gkit2light (une branche) et se récupère avec Git comme ceci:
```
git clone -b master_CharAnim https://forge.univ-lyon1.fr/Alexandre.Meyer/gkit2light.git gkit2light-master_CharAnim
```
qui fait un clone du dépôt gkit2light, branche `master_CharAnim` et range le tout dans le répertoire `gkit2light-master_CharAnim`
ou alors
```
git clone https://forge.univ-lyon1.fr/Alexandre.Meyer/gkit2light.git gkit2light-master_CharAnim
cd gkit2light-master_CharAnim
git checkout master_CharAnim
=> le update avec un nom de branche permet de passer dans une autre branche
```
## Pour compiler sous Linux avec codeblocks
```
cd gkit2light-master_CharAnim
premake5 --file=master_CharAnim.lua codeblocks
```
puis ouvrir le projet `master_CharAnim.cbp`
## Pour compiler sous Linux avec make
```
cd gkit2light
premake5 --file=master_CharAnim.lua gmake
make -f master_CharAnim.make ou juste make
bin/master_CharAnim
```
## Pour compiler sous Linux de chez vous (ubuntu)
* [voir le apt-get install ... ici](http://perso.univ-lyon1.fr/jean-claude.iehl/Public/educ/M1IMAGE/html/group__installation.html)
* `sudo apt install premake4 premake5`
* puis comme indiqué plus haut
## Pour compiler sous Windows chez vous avec VSCode ou CodeBlocks ou VisualStudio
* Installez Git
* Installez Codeblocks ou VSCode avec Mingw OU Visual Studio
* Explorateur de fichier, placez vous dans le répertoire de vos fichiers, bouton droit "git bash here" puis le clone indiqué plus haut ...
* [Téléchargez les librairies (SDL,Glew, etc.) pour Windows ici](https://perso.univ-lyon1.fr/jean-claude.iehl/Public/educ/M1IMAGE/extern_mingw_visual.zip)
* Copiez le répertoire 'extern' dans le répertoire principal de gkit2light
* Vous devez aussi copier toutes les .dll du répertoire extern/mingw/lib OU extern/visual20??/lib dans gkit2light-master_CharAnim/bin (répertoire des exécutables), sinon vous aurez des erreurs à l’exécution des programmes
* Lancez le script `gkit2light-master_CharAnim/premake/premake-CharA.bat` qui va créer les projets makefile/codeblocks/visual` dans le répertoire gkitlight
* Ouvrez le projet `gkit2light-master_CharAnim/gkit2light.cbp` ou `gkit2light-master_CharAnim/build/gkit2light.sln`
## gKitLight la doc
[La documentation est ici.](http://jean-claude.iehl.perso.univ-lyon1.fr/Public/educ/M1IMAGE/index.html)
## Quelques explications sur le code
* 'h' pour l'aide
* 'a'=affiche/enlève les axes; 'g'=affiche/enlève la grille;
* souris bouton gauche= rotation du monde
* souris bouton droit et translation horizontale : pour zoomer
* **Votre code prendra place dans le module src/master_CharAnim/CharAnimViewer.h / .cpp**
* La class CharAnimViewer contient les fonctions init/draw qui s'occupent de l'affichage, elle dispose par héritage de fonction draw_sphere et draw_cylinder
* Pour ajouter des fichiers au projet, regarder le master_CharAnim.lua dans la racine
# TP d'Animation de personnage (M1)
## TP partie 1 : affichage
![](../../doc_charanim/charanim_interpolation.png)
Vous allez créer un module Skeleton.h/.cpp (ce code n'est qu'indicatif, vous êtes libre de vos structures de données). Cette classe va stocker un tableau de toutes les articulations (SkeletonJoint) du squelette et pour chaque articulation stocke l'identifiant de l'articulation parent et la matrice de passage de l'articulation vers le monde.
Le fichier est déjà présent dans le code départ avec des TODO à compléter :
```
class Skeleton
{
public:
struct SkeletonJoint
{
int m_parentId; // Le numéro du père dans le tableau de CAJoint de CASkeleton
Transform m_l2w; // La matrice passant du repère de l'articulation vers le monde
};
Skeleton() {}
//! Créer un squelette ayant la même structure que définit dans le BVH c'est à dire
//! creer le tableau de SkeletonJoint à la bonne taille, avec les parentId initialsé pour chaque case
void init(const BVH& bvh);
//! Renvoie la position de l'articulation i en multipliant le m_l2w par le Point(0,0,0)
Point getJointPosition(int i) const;
//! Renvoie l'identifiant de l'articulation père de l'articulation numéro i
int getParentId(const int i) const;
//! Renvoie le nombre d'articulation
int numberOfJoint() const;
//! Positionne ce squelette dans la position n du BVH.
//! Assez proche de la fonction récursive (question 1), mais range la matrice (Transform)
//! dans la case du tableau. Pour obtenir la matrice allant de l'articulation local vers le monde,
//! il faut multiplier la matrice allant de l'articulation vers son père à la matrice du père allant de
//! l'articulation du père vers le monde.
void setPose(const BVH& bvh, int frameNumber);
protected:
//! L'ensemble des articulations.
//! Remarque : la notion de hiérarchie (arbre) n'est plus nécessaire ici,
//! pour tracer les os on utilise l'information "parentID" de la class CAJoint
std::vector<SkeletonJoint> m_joint;
};
```
Dans le Viewer vous devez :
* Déclarer un Skeleton en variable de la classe
* Ecrire une fonction qui fait l'affichage
```
void CharAnimViewer::skeletonDraw(const Skeleton& ske);
```
* Initaliser l'instance de Skeleton dans la fonction init
* Appeler setPose dans la fonction update
Remarques
* On sépare bien l'affichage de la gestion du squelette pour pouvoir réutiliser le code Skeleton avec une autre librairie d'affichage.
* On ne s'occupe pas du temps pour l'instant mais uniquement du numéro de la posture.
* Vous pouvez trouvez des BVH dans le répertoire data du code de départ. Notamment le fichier robot.bvh pour debuguer.
## TP partie 2 : Contrôleur d'animation
#### Déplacer une sphère au clavier
Ecrivez une class CharacterControler qui à partir des touches claviers contrôlera le déplacement d'un personnage. Dans une 1er temps faites juste déplacer une boule : accélérer, freiner, tourner à droite, tourner à gauche, sauter. Ce contrôleur comportera une position et une vitesse. La vitesse sera modifiée par les flèches (ou un pad) et la position sera mise à jour dans la fonction update du Viewer en utilisant le paramètre "delta" recu par la fonction update.
Une classe de Controller peut ressembler à ceci.
```
class CharacterController
{
public:
CharacterController() : ... {}
void update(const float dt);
void turnXZ(const float& rot_angle_v);
void accelerate(const float& speed_inc);
void setVelocityMax(const float vmax);
const Point position() const;
const Vector direction() const;
float velocity() const;
const Transform& controller2world() const { return m_ch2w; }
protected:
Transform m_ch2w; // matrice du character vers le monde
// le personnage se déplace vers X
// il tourne autour de Y
// Z est sa direction droite
float m_v; // le vecteur vitesse est m_v * m_ch2w * Vector(1,0,0)
float m_vMax; // ne peut pas accélérer plus que m_vMax
};
```
#### Déplacer un personnage au clavier
Dans un 2e temps, votre contrôleur comportera également une série d'animation bvh : attendre, marcher, courir, et donner un coup de pied.
En fonction de l'action que veut faire le joueur appuyant sur des touches vous changerez d'animation. Vous coderez la machine à états
finis (FiniteStateMachine) de l'image ci-dessous. Les cercles sont les états (l'animation en train d'être jouée), les rectangles rouges sont
les éventements et les carrés bleus sont les actions à effectuer (fonction de la classe). Ce changement se fera brutalement. Ne vous
occupez pas non plus des pieds qui glissent sur le sol. Un meilleur contrôle peut-être fait la construction d'un graphe d'animation.
![](../../doc_charanim/fsm.png)
## TP partie 3 : Transition et graphe d'animation
a) Pour améliorer le réalisme, il serait bon de faire les transitions entre deux animations en choisissant deux poses des animations qui sont
proches. Pour cela il faut calculer la distance entre deux poses d'animations (Voir les infos dans le sujet Graphe d'animation).
b) Pour aller encore plus loin, on peut construire un automate de manière complètement automatique. On appelle alors ceci un graphe d'animation. [Voir le sujet détaillé de cette 3e partie ici.](../tp_motiongraph)
a.bis) Indépendamment de la machine à état ou du graphe, si vous voulez gérer le temps de manière plus juste, il faudrait récupérer le temps
réellement écoulé depuis l'affichage précédent. Ceci vous fera ne vous fera pas tomber précisément sur une frame stocké dans le clip (BVH). Il faudra donc interpoler entre les 2 frames. Le résultat sera de l'ordre du détail lors de l'affichage mais si vous voulez que votre moteur
d'animation tourne sur toutes les machines indépendamment du CPU, il faut le faire. Cette interpolation peut également servir pour passer d'un clip à un autre.
## TP partie 4 : Interaction entre le personnage et des sphères physiques
Pour bien comprendre l'animation physique voir la partie de F. Zara.
#### Particules
![](../../doc_charanim/charanim_ball.png)
Dans la fonction init de la class CharAnimViewer indiquez un nombre de particules non nul :
```
m_world.setParticlesCount( 10 );
```
Dans la fonction render, il faut afficher les particules en dé-commentant cette ligne :
```
m_world.draw();
```
Vous verrez alors les particules s'afficher, mais elles ne seront pas animées. Pour calculer la physique sur les particules, il y a deux
classes **PhysicalWorld** et **Particle**. Regardez le fichier Particles.h. Il faudra compléter les fonctions update, collision et groundCollision :
```
void update(const float dt = 0.1f)
void groundCollision()
void collision(const Point& p, const float radius)
```
Le code de update doit mettre à jour la vitesse avec l'équation `F=m.a``a = dv/dt`
Et mettre à jour la position avec l'équation habituelle `p = p + v.t`
Pour plus de détail, voir la partie de F. Zara.
#### Interaction personnage/particules
Pour ajouter l'interaction entre votre personnage et des boules/sphères se trouvant dans l'environnement, il faut appeler `PhysicalWorld::collision` depuis `CharAnimViewer::update` en parcourant toutes les articulations du personnage. Dans un 1er temps, vous pouvez juste faire disparaitre les particules touchées en faisant passer le rayon de la particule à -1 et faire en sorte que les particules de rayon négatif ne soient pas affichées. Puis ajoutez dans `Particle::collision` du code pour déplacer les particules en collisions (résoudre les collisions) et changer leur vecteur vitesse.
## TP 3e partie : graphe d'animation
- [Motion Graph de l'article original](http://www.cs.wisc.edu/graphics/Gallery/kovar.vol/MoGraphs/);
- Des BVH avec squelette compatible pour le graphe sont donné dans le git, répertoire Second_Life.\
Nous avons remarqué dans la partie 1 que la transition d'animation ne fonctionne bien que lorsque les deux poses du squelette sont assez
proches (il faut bien sûr également que les deux squelettes aient la même topologie). L'idée d'un graphe d'animation est de construire un
graphe où chaque noeud correspond à une pose d'une animation et où chaque arrête définit qu'une transition est possible entre les deux poses.
#### Comparaison de deux poses d'animation
Pour construire un graphe d'animation à partir d'une ou plusieurs animations, on doit être capable de comparer deux poses d'animation.
Une distance de 0 indique que les deux poses sont identiques. Une distance grande indique que les 2 poses sont très différentes.
A partir de la classe Skeleton, écrivez la fonction de calcul de distance entre deux poses de squelette. Cette fonction est déjà présente
dans la classe Skeleton plus haut mais en commentaire. Cette fonction calcule itérativement sur toutes les articulations la somme des distances euclidienne entre chaque articulation de deux squelettes aillant la même topologie mais dans des poses différentes.
```
friend float Skeleton::Distance(const Skeleton& a, const Skeleton& b);
```
** Remarque ** : il est important de ne pas tenir compte de la translation et de la rotation de l'articulation racine. Une même pose a
deux endroits du monde doit donner une distance de 0. Dans un 1er temps, votre personnage aura son noeud root centré en (0,0,0), puis dans la dernière partie de cette question, vous traiterez le centre de gravité.
#### Construction du graphe
Ecrivez un module MotionGraph qui contiendra un ensemble de BVH et le graphe d'animation définissant des transitions dans cette ensemble d'animation.
* Un noeud du graphe=(Identifiant d'une animation + un numéro de pose);
* un arc du graphe entre deux poses indique la transition possible entre ces deux poses. Deux poses sont compatibles à la transition quand la distance entre les deux squelettes sont inférieurs à un certain seuil fixé empiriquement.
Vous pouvez créer un module `CACore/CAMotionGraph.h/.cpp`
```
class MotionGraph
{
...
protected:
//! L'ensemble des BVH du graphe d'animation
std::vector<BVH> m_BVH;
//! Un noeud du graphe d'animation est repéré par un entier=un identifiant
typedef int GrapheNodeID;
//! Une animation BVH est repérée par un identifiant=un entier
typedef int BVH_ID;
//! Un noeud du graphe contient l'identifiant de l'animation, le numéro
//! de la frame et les identifiants des noeuds successeurs
//! Remarque : du code plus "joli" aurait créer une classe CAGrapheNode
struct GrapheNode
{
BVH_ID id_bvh;
int frame;
std::vector<GrapheNodeID> ids_next; //! Liste des nœuds successeurs
};
//! Tous les noeuds du graphe d'animation
std::vector<GrapheNode> m_GrapheNode;
};
```
#### Navigation dans le graphe
Une fois ce graphe construit, on peut définir différente manière de
naviguer dedans :
- Un parcours aléatoire dans le graphe (juste pour vérifier que le graphe est ok);
- L'utilisateur donne des directions au clavier => le parcours dans le graphe est conditionné par ces contraintes.
#### Gestion correcte du centre de gravité
Pour chaque arc du graphe, vous devez stocker la transformation (soit une matrice 4x4, soit un quaternion et une translation) du noeud root (souvent le centre de gravité) entre la pose i et la pose i+1. Cette transformation sera appliqué au noeud root de votre personnage quand il empruntera l'arc.