QuatreCentQuatre


Archive pour June, 2009

SWFAddress’ NavigationManager redux

Dans notre dernier post nous vous avons démontré comment utiliser le NavigationManager. Voici un petit démo qui vous aidera à figurer les propriétés d'un SectionData retourné par le système.

Vous verrez, l'essayer c'est l'adopter!

DÉMO
TÉLÉCHARGER

Utilisation de SWFAddress à travers le NavigationManager

Le NavigationManager de QuatreCentQuatre est une enveloppe ou un Proxy qui sert à titre d’interface à la classe SWFAddress de Asual afin de mieux contrôler son comportement et d’en étendre les fonctionnalités.

SWFAddress d'Asual

SWFAddress est une combinaison de techniques permettant, à travers des classes Javascript et Actionscript, le deep-linking (la possibilité d’accéder à des sections ou des pages directement à partir de la barre d’adresse du fureteur) dans des sites programmés en Flash. Cette technique, en plus de permettre l’utilisation de signets et des boutons Suivant et Précédent du fureteur, est une des meilleures solutions afin d’optimiser son site pour les moteurs de recherche.

SWFAddress

Afin d’utiliser SWFAddress, il suffit d’intégrer l’outil dans le HTML de la façon suivante :

  1. <script type="text/javascript" src="library/swfobject.js"></script>
  2. <script type="text/javascript" src="library/swfaddress.js"></script>
  3. <script type="text/javascript">
  4. var flashvars = {};
  5. var params = {};
  6. var attributes = {id:"flashMovie"};
  7. swfobject.embedSWF("navigationExample.swf", "alternateContent", "100%", "100%", "9.0.124", false, flashvars, params, attributes);
  8. </script>
  9.  

UTILISATION DE SWFADDRESS

L’intégration dans Flash s’effectue ensuite comme suit :

  1. private function init() :void{
  2. SWFAddress.addEventListener(SWFAddressEvent.CHANGE, handleChange, false, 0, true);
  3.  
  4. //Exemple de changement de page, mais une page ‘’/’’ est reçue par défaut au départ de l’application
  5. SWFAddress.setValue(‘’page1’’);
  6. }
  7.  
  8. private function handleChange(evt:SWFAddressEvent):void{
  9. var laSection:String = evt.value;
  10.  
  11. //La seule information obtenue est un string, une condition doit donc être programmée
  12. switch(laSection){
  13. case ‘’X’’ :
  14. //opération afin de changer de section
  15. //Changer le titre de la page (défini manuellement)
  16. //Vérifier si c’est la section demandée n’existe pas, etc…
  17. }
  18. }
  19.  

SWFAddress présente aussi plusieurs outils pour, par exemple :

  • Ouvrir des liens externes
  • Reculer dans l’historique
  • Monter de niveau hiérarchique (section1/section1-1 vers section1/)
  • Changer le titre de la page (dans quel cas SWFAddress doit être déclaré sous la balise dans le html.

Note : SWFAddress, quand il est utilisé adéquatement, remplace et surclasse le moteur d’indexation des fichiers swf des moteurs de recherche populaires tels que Google, c’est pourquoi il est important d’inclure un fichier robots.txt afin d’empêcher ceux-ci d’indexer automatiquement les fichiers gérés par SWFAddress ou le NavigationManager.
Exemple de fichier robots.txt :

  1. Sitemap: http://www.asual.com/sitemap.xml
  2. User-agent: *
  3. Disallow: /*.swf*
  4.  

 
 
NAVIGATIONMANGER

Le mandat de SWFAddress est de permettre le deep-linking et cet objectif est atteint. Toutefois, des mécanismes personnalisés doivent être mis en place afin d’en régir le fonctionnement ainsi que les cas d’exception. Que faites-vous si vous voulez que la description des sections soit chargée à l’externe, passer à la section suivante, assigner des descriptions aux sections, obtenir les infos de son parent ou encore que vous désirez savoir à quel niveau hiérarchique se trouve la section courante? Vous devrez programmer vos propres mécanismes ou utiliser le NavigationManager.

Propriétés et méthodes publiques

Structure du NavigationManager de QuatreCentQuatre

Structure du NavigationManager de QuatreCentQuatre


 
 
Étant donné que le NavigationManager est une enveloppe à SWFAddress, les classes de ce dernier seront requises et l’intégration Javascript s’effectuera de la même façon.
 
 

  1.  
  2. <script type="text/javascript" src="library/swfobject.js"></script>
  3. <script type="text/javascript" src="library/swfaddress.js"></script>
  4. <script type="text/javascript">
  5. var flashvars = {};
  6. var params = {};
  7. var attributes = {id:"flashMovie"};
  8. swfobject.embedSWF("navigationExample.swf", "alternateContent", "100%", "100%", "9.0.124", false, flashvars, params, attributes);
  9. </script>
  10.  

Le NavigationManager fonctionne selon un schéma XML qui peut être défini manuellement ou chargé à l’externe, voici un exemple de la structure du XML requis.

  1.  
  2. <response>
  3. <header>
  4. </header>
  5.  
  6. <body>
  7. <page>
  8. <item type="default">
  9. <description>Section 1</description>
  10. <tag>section1</tag>
  11. <ressource>sectionclasses.Section1</ressource>
  12. <subitems>
  13. <item type="normal">
  14. <description>Ceci est la section 1.1</description>
  15. <tag>section1-1</tag>
  16. <ressource>sectionclasses.Section1_1</ressource>
  17. </item>
  18. <item type="normal">
  19. <description>Ceci est la section 1.2</description>
  20. <tag>section1-2</tag>
  21. <ressource>sectionclasses.Section1_2</ressource>
  22. </item>
  23. </subitems>
  24. </item>
  25. < item type="notfound">
  26. <description>Section not found</description>
  27. <tag>sectionnotfound</tag>
  28. <ressource>sectionclasses.Section1</ressource>
  29. </ item>
  30. </page>
  31. </body>
  32. </response>
  33.  

Les informations d’une section doivent se retrouver à l’intérieur d’une balise <item> et doivent se situer à l’intérieur du node <page> qui sert de conteneur aux informations de la navigation.

Les informations à retrouver sont les suivantes :

  • L’attribut type qui peut valoir normal au default. Une valeur default indique que cette section est celle qui sera chargée par défaut lors de l’initialisation du système (au lieu de « / »)
  • La balise tag, qui sera utilisée comme identifiant dans la barre d’addresse et pour google analytics.
  • La balise description, qui est une valeur qui peut servir, par exemple, à nommer le bouton qui mènera à la section ou encore au titre de la page si la propriété useDescriptionAsTitle a une valeur de true.
  • La balise ressource, que vous pourrez utiliser afin de spécifier à quelle ressource (classe, fichier swf ou lien externe) la section est liée.
  • Une balise subitems optionnelle qui contiendra des nodes items qui seront considérés les enfants de l’item courant.

Notez qu’un deuxième node de structure similaire mais d’un type notfound peut être placé à la racine de l’arbre afin de régir la section utilisée lorsqu’une page reçue n’est pas définie dans le XML. Si ce node facultatif n’est pas défini, la page par défaut sera utilisée.

UTILISATION DU NAVIGATION MANAGER

L’intégration dans Flash est simple :

  1.  
  2. private function init() :void{
  3. NavigationManager.instance.addEventListener(NavigationManagerEvent.SECTION_CHANGED, handleSectionChanged, false, 0, true);
  4. NavigationManager.instance.addEventListener(NavigationManagerEvent.MENU_XML_LOAD_COMPLETE,
  5. handleMenuLoadComplete, false, 0, true);
  6. NavigationManager.instance.loadMenuXML(new URLRequest(‘’menu.xml’’));
  7. }
  8.  
  9. private function handleSectionChanged (evt: NavigationManagerEvent):void{
  10. //Référence vers la section courante
  11. var laSection:SectionData = evt.section;
  12. //ou
  13. var laSection2:SectionData =NavigationManager.instance.getCurrentSection();
  14. //On pourrait créer une section à partir de la ressource :
  15. var sectionClass:Class = getDefinitionByName(e.section.ressource) as Class;
  16. var currentSection <img src='http://blog.quatrecentquatre.com/wp-includes/images/smilies/icon_biggrin.gif' alt=':D' class='wp-smiley' /> isplayObject = new sectionClass() as SectionObject
  17. addChild(currentSection);
  18. }
  19.  
  20. private function handleMenuLoadComplete (evt: NavigationManagerEvent):void{
  21. //Effectue les operations afin de créer le menu
  22. var iterator:ISubSectionIterator = NavigationManager.instance.sectionsList;
  23. var length:int = iterator.numSubSections;
  24. for (var i:int = 0; i < length; i++) {
  25. var laSection:SectionData = iterator.getSubSectionAt(i);
  26. }
  27. }
  28.  

Comme on peut le constater, il peut être pratique d’écouter sur l’événement MENU_XML_LOAD_COMPLETE afin de savoir si le XML est chargé alors que l’événement SECTION_CHANGED est utile afin de savoir quand une section a changé. Notez que l’événement SECTION_CHANGED ne sera jamais diffusé avant que la fin du chargement du XML externe ou avant l’assignation manuelle du XML à travers la fonction NavigationManager.instance. sectionsList. setMenuStructure().


PRATIQUES À ADOPTER

  • Dans les items associée à une section (un bouton de menu par exemple) implémentez une propriété qui entreposera une référence vers le SectionData de la section qu’ils représentent afin de faciliter l’utilisation du système. En plus, l’espace mémoire requis sera plus petit qu’une valeur textuelle de son chemin enregistrée dans un String.
  • Si vous avez plus d’un menu pour la navigation, vous pouvez les englober dans des nodes à la racine du groupe qui serviront ni plus ni moins de conteneurs aux sous-sections qu’ils contiendront. Pour y accéder individuellement lors de la création dynamique des menus, vous pouvez utiliser la fonction NavigationManager.instance.sectionsList.getSectionByTag(‘’conteneur X’’) à partir duquel vous pourrez accéder à ses enfants. De plus, la structure dans Google Analytics n’en sera que plus claire étant donné que la section sera identifée comme suit : conteneurX/sectionY

 
 
BIBLIOGRAPHIE
SWFAddress Bad Practices
http://www.asual.com/blog/swfaddress/2007/05/18/swfaddress-bad-practices.html
SWFAddress and robots.txt
http://www.asual.com/blog/swfaddress/2008/11/25/swfaddress-and-robots-txt.html

Télécharger la version 1.0 du NavigationManager:
LIEN