SPIP-Contrib

SPIP-Contrib

عربي | Deutsch | English | Español | français | italiano

273 Plugins, 191 contribs sur SPIP-Zone, 37 visiteurs en ce moment

Accueil du site > Navigation > Nuage de mots (tagcloud) > Un affichage fonction de l’importance relative dans le site

Un affichage fonction de l’importance relative dans le site

31 mars 2005 – par mortimer – <blink style='color:red;'>public|spip|ecrire:commentaires</blink>

Voici une contrib qui étend le principe de « Afficher les mots-clés en faisant varier la taille de la police » pour faire des affichages avec taille de police (ou une autre propriété) variant en fonction de l’importance relative d’un objet (article, mot clef, etc.) dans le site.

Concepts

La contrib « Afficher les mots-clés en faisant varier la taille de la police » permet d’afficher une liste de mots clefs en variant la taille de la police en fonction du nombre d’articles associés à chaque mots.

Ici, nous proposons une version générique de cette méthode qui permet, avec de simples filtres, de calculer les variations de taille de police [1]. De plus, les filtres proposés permettent d’appliquer le principe à quasiment tout élément dont on peut avoir une représentation numérique de l’importance dans le site.

On pourra ainsi :
-  mettre en valeur une rubrique en fonction du nombre d’articles qu’elle contient,
-  mettre en valeur une rubrique en fonction de la popularité des articles qu’elle contient,
-  mettre en valeur des articles en fonction du nombre de document associés,
-  etc...

Une démo qui vous sera plus parlante est disponible ici.

Les filtres

Commençons par la définition des filtres qui devront être copiés dans le fichier mes_fonctions.php3 :

-  noop mange tout ce qui lui est passé, il nous servira à faire des calculs sans rien afficher.
-  filtre_max trouve le maximum parmi les valeurs qui lui sont passées (on peut lui passer un paramètre optionnel pour pouvoir l’utiliser indépendamment plusieurs fois sur la même page),
-  coef calcule un coefficient représentant l’importance pour l’affichage. On doit l’appliquer après filtre_max et spécifier la valeur dont on veut calculer le coefficient. il prend aussi un paramètre optionnel qui spécifie la valeur maximum qui pourra être retournée,
-  repeat répète une chaîne un certain nombre de fois. On peut l’utiliser pour transformer le coefficient en une répétition de balises (voir plus bas). Il prend un paramètre optionnel spécifiant en dessous de quelle valeur il ne faut rien retourner (on peut ainsi filtrer les résultats ayant un coefficient trop petit).

Des boucles

Voici quelques exemple d’utilisation de ces filtres.

-  Le premier exemple permet d’afficher le titre des rubriques avec des tailles de police différentes en fonction du nombre d’articles qu’elles contiennent.

On défini déjà un style pour fixer les tailles de police. Plus la rubrique sera importante, plus il y aura de balises <em> autour :

On doit ensuite, dans le squelette, faire deux boucles :

  • _max et _max_art servent à calculer le nombre maximum d’articles qui sont contenus dans les rubriques du site. En appliquant |filtre_max{total} sur le nombre d’articles dans chaque rubrique, on va garder le plus grand nombre d’articles trouvé. |noop sert à ne pas afficher la valeur retournée par le filtre qui cherche le maximum.
  • _aff et _aff_art parcoure toutes les rubriques et calcul le coefficient d’affichage. |filtre_max{total} retourne le nombre d’articles maximal trouvé dans la première boucle. |coef{#TOTAL_BOUCLE} calcul l’importance du nombre d’articles dans cette rubrique par rapport au nombre d’articles maximum. |repeat{#_aff:TITRE,<em>,</em>} entoure le titre de la rubrique du nombre de balises <em> défini par le filtre coef

-  Le deuxième exemple utilise le même principe pour afficher les articles d’une rubrique « galerie » en fonction du nombre d’images qu’ils contiennent :

La différence ici est que l’on utilise directement le filtre coef pour fixer la taille de la police. On passe donc un deuxième paramètre à ce filtre pour spécifier que le coefficient doit être calculé entre 0 et 250.

-  La dernière boucle d’exemple est un peu différente. Elle affiche les rubriques en fonction de la popularité de leur article le plus populaire :

Les boucles max_art et aff_art ne sont plus là pour calculer un total, mais pour trouver la popularité maximum. On fait donc une boucle triée par popularité croissante et l’on ne prend que le premier résultat (i.e. l’article avec la plus forte popularité).

P.-S.

Le filtre coefficient ne retourne pas des valeurs très homogènes et certain affichages risquent d’être très gros par rapport à d’autre (c.f. le site de test).

Mais comme coef est un filtre, il est simple d’ajouter un filtre de lissage (sqrt ou log) après :

<strong [(#TOTAL_BOUCLE|filtre_max{doc}|coef{#TOTAL_BOUCLE,250}|sqrt|ceil)]

Notes

[1En fait, n’importe quelle propriété peut être contrôlée avec ces filtres. L’exemple de la taille de la police est seulement le plus direct, mais on pourrait calculer un nom de class etc.

Retour en haut de la page

Vos commentaires

  • Le 19 juillet 2008 à 23:44, par Sylvano En réponse à : Méthode plus simple : balise #TOTAL_BOUCLE et filtre de comparaison

    Bonjour,

    Je ne suis pas familier avec le PHP, et je voulais créer un nuage de tags qui conviendrait à un site comportant peu d’articles, sans utiliser de PHP.

    Je vous propose donc la méthode que j’ai utilisée sur Fol d’ire (mes tags sont regroupés le groupe de mots-clés n°4) :

    Dans le squelette :

    <BOUCLE_nuage (MOTS) {id_groupe=4} >

      <BOUCLE_total (ARTICLES) {id_mot}>
      </BOUCLE_total>
         <span class="[(#TOTAL_BOUCLE|>{2}|?{'font120',''})]">
            <span class="[(#TOTAL_BOUCLE|>{5}|?{'font120',''})]">
               <span class="[(#TOTAL_BOUCLE|>{10}|?{'font120',''})]">
                  <a href="#URL_MOT">
                     [(#_nuage:TITRE) - ]
                  </a>
               </span>
            </span>
         </span>
      </B_total>
    </BOUCLE_nuage>

    Et dans le CSS :

    .font120 {
    font-size:115%;
    }

    .font120 span span a:link {
    color:#880000;
    }

    .font120 span span a:hover {
    color:#000000;
    }

    .font120 .font120 span a:link {
    color:#660000;
    }

    .font120 .font120 span a:hover {
    color:#000000;
    }

    .font120 .font120 .font120 a:link {
    color:#440000;
    }

    .font120 .font120 .font120 a:hover {
    color:#000000;
    }

    Cela servira peut-être à quelqu’un...

    Sylvano

    Répondre à ce message

  • Le 25 février 2007 à 22:34, par Aurélie En réponse à : Un affichage fonction de l’importance relative dans le site

    Salut,

    Merci pour ta contrib. En Spip 1.9.1, j’ai utilisé les balises #SET et #GET pour obtenir quelque chose de similaire.

    Mon idée est, dans un squelette rubrique.html, de mettre en valeur les sous-rubriques en fonction de la popularité des articles qu’elles contiennent. Cet exemple correspond donc au dernier exemple de l’article ci-dessus. Avec un peu d’imagination, on doit pouvoir l’adapter à d’autres besoins...

    La BOUCLE_popularite_max sélectionne l’article le plus populaire de la branche, c’est-à-dire de la rubrique en cours et de ses sous-rubriques. Avec #SET{pop_max,#POPULARITE}, on donne à la variable pop_max, la valeur de sa #POPULARITE. pop_max a donc une valeur comprise entre 0 et 100.

    On sélectionne ensuite les sous-rubriques de la rubrique en cours avec la BOUCLE_sous_rubriques. Puis l’article le plus populaire de cette branche-là.

    On fixe une taille relative de police (<span style="font-size: ...em;">) en fonction d’un obscur calcul :
    [(#POPULARITE|div{#GET{pop_max}}|round{2}|plus{1})]

    La popularité de cet article est divisée par la popularité maximum obtenue auparavant (#GET{pop_max}), on arrondi deux chiffres après la virgule (voir fonction round() de php) et on ajoute 1.

    Avec ce calcul, un article dont la popularité serait de 0/100 aurait une taille de 1em, un article ayant une popularité de 100/100 aurait une taille de 2em.

    Notez que cette boucle n’affichera que les rubriques contenant au moins un article. Pour s’assurer que les rubriques qui ne contiennent que des documents ou des liens par exemple, s’afficheront, on ajoute un code alternatif à la BOUCLE_articles (<//B_articles>).

    Répondre à ce message

  • Le 25 avril 2006 à 10:40, par Laurent Haberkorn En réponse à : Un affichage fonction de l’importance relative dans le site

    Cette contribution ne semble pas marcher sous Internet Explorer, alors que sous Firefox oui. Y a-t-il un moyen de « forcer » cette présentation le navigateur n°1 ?

    Répondre à ce message

  • Le 10 août 2005 à 22:07, par @lexandre En réponse à : > Un affichage fonction de l’importance relative dans le site

    Merci pour ta contribution.

    Testée sur www.instits.fr

    Répondre à ce message

Répondre à cet article

Qui êtes-vous ?

Pour afficher votre trombine avec votre message, enregistrez-la d'abord sur gravatar.com (gratuit et indolore) et n'oubliez pas d'indiquer votre adresse e-mail ici.

Ajoutez votre commentaire ici Les choses à faire avant de poser une question (Prolégomènes aux rapports de bugs. )
Ajouter un document

Retour en haut de la page

Ça discute par ici

  • Une licence pour un article

    18 avril 2007 – 25 <blink style='color:red;'>public|spip|ecrire:commentaires</blink>

    Sur une idée originale de erational, voici un plugin permettant de lier une licence à un article.

  • Plugin Parrainage

    6 novembre 2011 – <blink style='color:red;'>public|spip|ecrire:commentaire</blink>

    Permettre aux utilisateurs d’inviter leurs contacts à s’inscrire sur le site. Description Vous connaissez le web moderne et son cortège d’applis toujours en version « beta » et de buzz sur le dernier réseau à la mode ? Vous voulez vous aussi vous y (...)

  • Formulaire de contact libre

    27 avril 2011 – 36 <blink style='color:red;'>public|spip|ecrire:commentaires</blink>

    Dans SPIP il n’y a pas un formulaire de contact, mais autant de formulaires de contact que d’auteurs. Cette phrase de Romy, dans son article Une page de contact dans mon SPIP, pointe un petit manque de SPIP. La possibilité d’insérer rapidement un (...)

  • Plugin Mot de Passe Compliqué

    2 novembre 2007 – 16 <blink style='color:red;'>public|spip|ecrire:commentaires</blink>

    Ce plugin ajoute un testeur de complexité de mot de passes dans les formulaires de choix de mot de passe de SPIP.

  • Navigation AJAX

    31 janvier – 18 <blink style='color:red;'>public|spip|ecrire:commentaires</blink>

    Ce plugin permet de modifier automatiquement une parties des liens internes de manière à ce qu’ils ne déclenchent pas un chargement complet de la page cible, mais un chargement en AJAX de certains éléments spécifiés à l’avance. Il permet aussi de (...)