4.2. Lesson: Créer une mise en page dynamique

Maintenant que vous avez appris à créer une mise en page de base, nous allons un peu plus loin et créons une mise en page qui s’adapte dynamiquement à l’étendue de notre carte et aux propriétés de la page, par exemple lorsque vous changez la taille de la page. De même, la date de création s’adaptera de manière dynamique.

4.2.1. moderate Follow Along: Création du canevas de carte dynamique

  1. Chargez les jeux de données au format ESRI Shapefile protected_areas.shp, places.shp, rivers.shp et water.shp dans le canevas de carte et modifiez leurs propriétés à votre propre convenance.

  2. Une fois que tout est rendu et symbolisé à votre goût, cliquez sur l’icône newLayout Nouvelle mise en page dans la barre d’outils ou choisissez fichier ► nouvelle mise en page. Vous serez invité à choisir un titre pour la nouvelle mise en page.

  3. Nous voulons créer une mise en page cartographique composée d’un en-tête et d’une carte de la région près de Swellendam, en Afrique du Sud. La mise en page doit avoir une marge de 7,5 mm et l’en-tête doit avoir une hauteur de 36 mm.

  4. Créez un élément de carte appelé carte principale sur le canevas et allez dans le panneau mise en page. Descendez jusqu’à la section Variables et trouvez la partie mise en page. Ici, nous définissons quelques variables que vous pouvez utiliser dans toute la mise en page dynamique. Allez dans le panneau mise en page et descendez jusqu’à la section Variables. La première variable définira la marge. Appuyez sur le bouton signPlus et tapez le nom sw_layout_margin. Définissez la valeur à 7.5. Appuyez à nouveau sur le bouton signPlus et tapez le nom w_layout_height_header. Mettez la valeur à 36.

  5. Vous êtes maintenant prêt à créer automatiquement la position et la taille du canevas de la carte au moyen des variables. Assurez-vous que votre élément de carte est sélectionné, allez dans le panneau proprietes element, faites défiler vers le bas et ouvrez la section Position et taille. Cliquez sur l’expression dataDefineExpressionOn passer outre les donnees pour X et à partir de l’entrée Variables, choisissez @sw_layout_margin.

  6. Cliquez sur l’expression dataDefineExpressionOn passer outre les données définies pour Y, choisissez editer… et tapez la formule: :

    to_real(@sw_layout_margin) + to_real(@sw_layout_height_header)
    
  7. Vous pouvez créer la taille de l’élément de carte en utilisant les variables largeur et hauteur. Cliquez sur l’expression dataDefineExpressionOn passer outre les donnees definies pour largeur et choisissez Edit … à nouveau. Remplissez la formule: :

    @layout_pagewidth - @sw_layout_margin * 2
    

    Cliquez sur l’expression dataDefineExpressionOn passer outre les donnees definies pour hauteur et choisissez Edit …. Remplissez ici la formule: :

    @layout_pageheight -  @sw_layout_height_header -  @sw_layout_margin * 2
    
  8. Nous allons également créer une grille contenant les coordonnées de l’étendue du canevas de la carte principale. Allez à nouveau sur proprietes element et choisissez la section grille. Insérez une grille en cliquant sur le bouton signPlus. Cliquez sur modifier grille … et définissez l’intervalle Intervalle pour X, Y et Offset selon l’échelle de la carte que vous avez choisie dans le canevas principal du QGIS. Le Type de grille Cross est très bien adapté à nos besoins.

4.2.2. moderate Follow Along: Création de l’en-tête dynamique

  1. Insérez un rectangle qui contiendra l’en-tête avec le bouton addBasicShape Ajouter une forme. Dans le panneau: guilabel:Éléments, entrez le nom header.

  2. Encore une fois, allez dans la section proprietes element et ouvrez la section position et taille. En utilisant dataDefineExpressionOn passer outre les donnees definies, choisissez la variable sw_layout_margin pour X ainsi que pour Y. largeur sera définie par l’expression: :

    @layout_pagewidth - @sw_layout_margin * 2
    

    et hauteur par la variable sw_layout_height_header.

  3. Nous allons insérer une ligne horizontale et deux lignes verticales pour diviser l’en-tête en différentes sections à l’aide de la fonction addNodesShape ajouter element noeud. Créez une ligne horizontale et deux lignes verticales et nommez-les Ligne horizontale, Ligne verticale 1, Ligne verticale 2.

    1. Pour la ligne horizontale

      1. Mettez X à la variable sw_layout_margin.

      2. Définissez l’expression pour Y à: :

        @sw_layout_margin + 8
        
      3. Définissez l’expression pour largeur à: :

        @layout_pagewidth -  @sw_layout_margin * 3 - 53.5
        
    2. Pour la première ligne verticale :

      1. Définissez l’expression pour X à: :

        @layout_pagewidth - @sw_layout_margin * 2 - 53.5
        
      2. Mettez Y à la variable sw_layout_margin.

      3. La hauteur doit être la même que celle de l’en-tête que nous avons créé, donc mettez hauteur à la variable sw_layout_height_header.

    3. La deuxième ligne verticale est placée à gauche de la première

      1. Définissez l’expression pour X à: :

        @layout_pagewidth - @sw_layout_margin * 2 - 83.5
        
      2. Mettez Y à la variable sw_layout_margin.

      3. La hauteur doit être la même que celle de l’autre ligne verticale, donc mettez hauteur à la variable sw_layout_height_header.

    La figure ci-dessous montre la structure de notre mise en page dynamique. Nous allons remplir les zones créées par les lignes avec quelques éléments.

../../../_images/dynamic_layout_structure.png

4.2.3. moderate Follow Along: Création d’étiquettes pour l’en-tête dynamique

  1. Le titre de votre projet QGIS peut être inclus automatiquement. Le titre est défini dans les proprietes projet. Insérez un label avec le bouton addLabel ajouter etiquette et entrez le nom project title (variable). Dans le panneau Main Properties du panneau proprietes element, entrez l’expression: :

    [%@project_title%]
    

    Définissez la position de l’étiquette.

    1. Pour X, utilisez l’expression: :

      @sw_layout_margin + 3
      
    2. Pour Y, utilisez l’expression: :

      @sw_layout_margin + 0.25
      
    3. Pour largeur, utilisez l’expression: :

      @layout_pagewidth - @sw_layout_margin *2 - 90
      
    4. Entrez 11,25 pour hauteur.

    Sous Apparence, définissez la taille de la police à 16 pt.

  2. La deuxième étiquette comprendra une description de la carte que vous avez créée. Là encore, insérez une étiquette et nommez-la description de la carte. Dans le champ Propriétés principales, entrez le texte description de la carte. Nous inclurons également

    printed on: [%format_date(now(),'dd.MM.yyyy')%]
    

    Nous avons utilisé ici deux fonctions Date et Heure (now et format_date).

    Définissez la position de l’étiquette.

    1. Pour X, utilisez l’expression: :

      @sw_layout_margin + 3
      
    2. Pour Y, utilisez l’expression: :

      @sw_layout_margin + 11.5
      
  3. La troisième étiquette comprendra des informations sur votre organisation. Nous allons d’abord créer quelques variables dans le menu Variables des Propriétés de l’élément. Allez dans le menu Mise en page, cliquez sur le bouton signPlus à chaque fois et entrez les noms o_department, o_name, o_adress et o_postcode. Dans la deuxième ligne, entrez les informations concernant votre organisation. Nous utiliserons ces variables dans la section Propriétés principales.

    Dans Propriétés principales, entrez

    [% @o_name %]
    [% @o_department %]
    [% @o_adress %]
    [% @o_postcode %]
    

    Définissez la position de l’étiquette.

    1. Pour X, utilisez l’expression: :

      @layout_pagewidth - @sw_layout_margin - 49.5
      
    2. Pour Y, utilisez l’expression: :

      @sw_layout_margin + 15.5
      
    3. Pour largeur, utilisez 49.00.

    4. Pour hauteur, utilisez l’expression: :

      @sw_layout_height_header - 15.5
      
../../../_images/dynamic_layout_organisation.png

4.2.4. moderate Follow Along: Ajout d’images dans l’en-tête dynamique

  1. Utilisez le bouton addNewImage ajouter image pour placer une image au-dessus de votre étiquette information d'organisation. Après avoir saisi le nom logo de l'organisation, définissez la position et la taille du logo :

    1. Pour X, utilisez l’expression: :

      @layout_pagewidth - @sw_layout_margin - 49.5
      
    2. Pour Y, utilisez l’expression: :

      @sw_layout_margin + 3.5
      
    3. Pour largeur, utilisez 39.292

    4. Pour hauteur, utilisez 9.583

    Pour inclure un logo de votre organisation, vous devez enregistrer votre logo sous votre répertoire d’origine et entrer le chemin sous Propriétés principales ► Source de l’image.

  2. Notre tracé a encore besoin d’une flèche nord. Celle-ci sera également insérée en utilisant northArrow Ajouter flèche du nord. Nous utiliserons la flèche nord par défaut. Définissez la position :

    1. Pour X, utilisez l’expression: :

      @layout_pagewidth - @sw_layout_margin * 2 - 78
      
    2. Pour Y, utilisez l’expression: :

      @sw_layout_margin + 9
      
    3. Pour Largeur, utilisez 21.027

    4. Pour Hauteur, utilisez 21.157.

4.2.5. moderate Follow Along: Création de la barre d’échelle de l’en-tête dynamique

  1. Pour insérer une barre d’échelle dans l’en-tête, cliquez sur addScalebar Ajouter barre d’échelle et placez-la dans le rectangle au-dessus de la flèche nord. Dans Carte sous Propriétés principales choisissez votre carte principale (Carte 1). Cela signifie que l’échelle change automatiquement selon l’étendue que vous choisissez dans le canevas principal de QGIS. Choisissez le Style Numérique. Cela signifie que nous insérons une échelle simple sans barre d’échelle. L’échelle a encore besoin d’une position et d’une taille.

    1. Pour X, utilisez l’expression: :

      @layout_pagewidth - @sw_layout_margin * 2 - 78
      
    2. Pour Y, utilisez l’expression: :

      @sw_layout_margin + 1
      
    3. Pour Largeur, utilisez 25.

    4. Pour Hauteur, utilisez 8.

    5. Placez le Point de référence au centre.

Félicitations ! Vous avez créé votre première mise en page de carte dynamique. Jetez un coup d’œil à la mise en page et vérifiez si tout est comme vous le souhaitez ! La mise en page de la carte dynamique réagit automatiquement lorsque vous modifiez les propriétés de la Page. Par exemple, si vous changez la taille de la page de DIN A4 à DIN A3, cliquez sur le bouton refresh Rafraîchir la vue et la conception de la page est adaptée.

../../../_images/dynamic_layout.png

4.2.6. What’s Next?

Sur la page suivante, vous aurez un devoir à compléter. Cela vous permettra de pratiquer les techniques que vous avez apprises jusqu’à présent.