Programmation » [JS]
    Catégorie:  
       
    [JS]
    Publié le 04/07/2011 @ 10:34:23,
    Par Tang
    Salut à tous,

    J'ai un ami qui a un problème et je me suis dit que vous trouveriez certainement la solution :

    J'aimerais faire tourner un script en boucle sur un dossier contenant plusieurs fichiers de traces GPS à afficher sur une carte OpenStreetMap.

    Voilà l'exemple avec deux fichiers :
    http://eurasia.cyclic.eu/maps/traces.html
    Mais au lieu d'avoir à spécifier chaque fichier .gpx dans le code source de la page, j'aimerais que chaque fichier (.gpx) soit affiché avec le script trace_gpx.

    Actuellement, le code est :
    1. <script> 
    2.     init_map('map') ; 
    3.     trace_gpx('20100719.gpx','19/07/2010','red') ; 
    4.     trace_gpx('20100721.gpx') ;    
    5. </script>


    Je pourrais imager l'idée par l'instruction suivante :
    1. <script> 
    2.     init_map('map') ; 
    3.     trace_gpx('*.gpx') ;    
    4. </script>


    Une idée?
    Merci d'avance!


    Merci pour lui.
       
    [JS]
    Publié le 04/07/2011 @ 11:46:58,
    Par Clandestino
    Je peux me tromper, mais par défaut JS ne sait pas accéder au filesystem hors IE (et là encore, il a besoin d'un activeX et de Scripting.FileSystemObject).

    Le plus simple est de mettre tous les fichiers .gpx dans un array et de passer un petit coup de jQuery :

    1. var _gpxs = ['20100719','20105487','32564878', ... ]; 
    2. $.each(_gpxs, function(i,item) { 
    3.     trace_gpx(item + '.gpx'); 
    4. });
       
    [JS]
    Publié le 04/07/2011 @ 14:32:09,
    Par Tang
    Apparemment soit ça fonctionne pas, soit mon pote modifie pas de la bonne façon.

    Donc :

    En fait, ça ne marche pas...
    Enfin, je ne sais pas exactement ce que je dois changer... "i" reste "i"? Si je mets un chiffre à la place de "i", la carte ne s'affiche même plus. Je comprends bien que je note les noms des fichiers entre les crochets mais ça s'arrête là...

    1. <script> 
    2.     init_map('map') ; 
    3.     var _gpxs = ['20100719','20100721']; 
    4.     $.each(_gpxs, function(i,item) { 
    5.         trace_gpx(item + '.gpx'); 
    6.     });    
    7. </script>


    Résultat : http://eurasia.cyclic.eu/maps/traces2.html


    Etant donne que ce n'est pas vraiment son truc le java, toute information détaillée est la bienvenue.

    ???

    Dernière édition: 04/07/2011 @ 14:33:30
       
    [JS]
    Publié le 04/07/2011 @ 14:50:25,
    Par Clandestino
    Question profondément débile (je sais), mais il a pensé à inclure jQuery dans sa page ?

    1. <script type="text/javascript" src:"http://code.jquery.com/jquery.min.js"></script>


    edit: j'ai regardé son source... Pas si débile que ça ma remarque :spamafote:
    Faut évidemment charger jQuery avant d'y faire appel :itm:

    Donc en fait, son code devrait être :

    1. <script type="text/javascript" src:"http://code.jquery.com/jquery.min.js"></script> 
    2. <script> 
    3. init_map('map') ; 
    4. var _gpxs = ['20100719','20100721'];  
    5. $.each(_gpxs, function(i,item) {  
    6. trace_gpx(item + '.gpx');  
    7. });  
    8. </script>

    Dernière édition: 04/07/2011 @ 14:52:05
       
    [JS]
    Publié le 04/07/2011 @ 15:07:26,
    Par Tang
    Ah ben un grand grand merci pour lui.

    Je lui communique...
       
    [JS]
    Publié le 04/07/2011 @ 15:09:38,
    Par Clandestino
    C'est src="http://code.jquery.com... et non src:"http://code.jquery.com... :aloy:
       
    [JS]
    Publié le 05/07/2011 @ 13:04:46,
    Par Tang
    Merci pour la précision (qu'il avait également corrigée).

    Ca fonctionne si ce n'est que c'est pas "automatique".

    En fait le but est qu'il dépose les fichiers dans un dossier sur le serveur et que la carte se mette à jour d'elle-même en vérifiant (genre 1 fois par jour) s'il y a de nouveaux fichiers présents.

    Si pas possible en JS, une idée en utilisant autre chose, et facilement ?
       
    [JS]
    Publié le 05/07/2011 @ 15:52:33,
    Par Clandestino
    Un petit bout de code PHP qui scanne le répertoire, balance le résultat dans un XML et l'envoie au JS qui le traite.

    En gros dans ce cas, ça donnerait ça :

    1. <?php 
    2. $path_to_gpxs = '../whatever_folder_it_is/gpxs/'
    3. $xml_string = <<<xml 
    4. <?xml version="1.0" encoding="UTF-8"?> 
    5. <item
    6. </item
    7. XML
    8.   
    9. $xml_generator = new SimpleXMLElement($xml_string); 
    10.   
    11. if ($handle = opendir($path_to_gpxs)) { 
    12. while (false !== ($file = readdir($handle))) { 
    13. if (is_file($path_to_gpxs.'/'.$file)) { 
    14. $image = $xml_generator->addChild('item'); 
    15. $image->addChild('path'$path_to_gpxs.'/'.$file); 
    16. closedir($handle); 
    17.   
    18. header("Content-Type: text/xml"); 
    19. echo $xml_generator->asXML(); 
    20. ?>


    Puis le JS :

    1. <script type="text/javascript" src="http://code.jquery.com/jquery.min.js"></script>  
    2. <script>  
    3. init_map('map') ; 
    4. $.ajax({ 
    5. type: "GET"
    6. url: "participations.xml"
    7. datatype: "xml"
    8. success: function(data) { 
    9. $(data).find("item").each(function() { 
    10. trace_gpx($(this).find('path').text()); 
    11. }); 
    12. }); 
    13. </script>
       
    [JS]
    Publié le 05/07/2011 @ 17:19:32,
    Par ovh
    Clan> PHP peut exporter un array en json, ce serait encore plus facile et naturel pour le js :cupra:

    http://fr.php.net/manual/en/function.json-encode.php
    Je n'ai rien à voir avec www.ovh.com
       
    [JS]
    Publié le 05/07/2011 @ 17:33:02,
    Par ovh
    Testé et approuvé :
    1. <?php 
    2. define("PATH"".");    // place ici le bon chemin sans / final 
    3. header("Content-type: application/json"); 
    4. $files = array(); 
    5. $iterator = new DirectoryIterator(PATH); 
    6. foreach ($iterator as $fileInfo) { 
    7.     if ($fileInfo->isFile()) { 
    8.         $files[] = PATH . '/' . $fileInfo->getFilename(); 
    9.     } 
    10. echo json_encode($files);


    1. <script type="text/javascript"
    2. init_map('map'); 
    3. $.ajax({ 
    4.     type: "get"
    5.     url: "test.php"
    6.     datatype: "json"
    7.     success: function(data){ 
    8.         $(data).each(function(idx, value){ 
    9.             trace_gpx(value); 
    10.         }); 
    11.     } 
    12. }); 
    13. </script>


    :dawa:

    Dernière édition: 05/07/2011 @ 21:07:14
    Je n'ai rien à voir avec www.ovh.com
       
    [JS]
    Publié le 06/07/2011 @ 08:29:25,
    Par Tang
    Ah ben je sens qu'il va être ravi...

    Un grand merci, j'étais sûr que par ici une solution serait trouvée.
       
    [JS]
    Publié le 06/07/2011 @ 10:23:44,
    Par Tang

    MA-GNI-FIQUE!!!!!!!!!!
    Deuxième solution (1ère pas testée).

    Merci merci merci!
    Tu transmettras!
       
    [JS]
    Publié le 06/07/2011 @ 11:34:32,
    Par ovh
    De rien :cupra: Mais ce ne serait pas plus simple qu'il s'inscrive sur le site ? :oh: C'est gratuit :petrus:
    Je n'ai rien à voir avec www.ovh.com
       
    [JS]
    Publié le 06/07/2011 @ 12:08:59,
    Par Tang
    De rien :cupra: Mais ce ne serait pas plus simple qu'il s'inscrive sur le site ? :oh: C'est gratuit :petrus:


    En fait ils sont sur le départ pour 14 mois et ont donc pas mal de chose à faire, donc je me suis occupé de "régler" ce point là.
       
    [JS]
    Publié le 12/07/2011 @ 09:12:48,
    Par Tang
    Finalement il a opté pour ceci (apparemment plus efficace*) :
    1. <script> 
    2.     init_map('map') ; 
    3.     <?php 
    4.     if ($handle = opendir($dir)) { 
    5.         $tab = array() ; 
    6.         while (false !== ($file = readdir($handle))) { 
    7.             if ( is_file("$dir/$file") ) 
    8.                 $tab[] = $file ; 
    9.         } 
    10.         closedir($handle); 
    11.     } 
    12.     sort($tab) ; 
    13.      
    14.     foreach ( $tab as $file ) { 
    15.         $fileName = str_replace('.gpx','',$file) ; 
    16.         echo "\t trace_gpx('$dir/$file','$fileName') ; \n" ; 
    17.     } 
    18.      
    19.     ?> 
    20. </script>


    *"[...]ça serait plus efficace d'écrire direct les appels trace_gpx dans
    le traces.html (à mettre en php du coup) que de faire un appel $.ajax"

    Encore merci à vous.
    Répondre - Catégorie:  
    Informaticien.be - © 2002-2024 AkretioSPRL  - Generated via Kelare
    The Akretio Network: Akretio - Freedelity - KelCommerce - Votre publicité sur informaticien.be ?