Comment modifier un changement de page ?#

1.  Avec les commandes de base#

Plusieurs commandes existent :

  • \newpage impose un changement brutal de page mais ce n’est généralement pas ce que vous voulez.

  • \clearpage termine la page en cours, tout comme \newpage, mais fait en sorte de placer tous les flottants qui seraient encore en attente, avant de commencer une nouvelle page. Cette commande est utilisée, par exemple, en fin de chapitre.

  • \cleardoublepage fait la même chose mais force en plus un redémarrage sur une page impaire, en laissant éventuellement une page blanche. Cela permet de reprendre le texte sur une page de droite, ce qui est encore plus utilisé en fin de chapitre dans les belles éditions.

  • \pagebreak[⟨n⟩], commande qui respecte la justification, où n représente l’autorité avec laquelle on veut changer de page. Ce paramètre est compris entre 1 et 4 :

    • 1 impose une contrainte faible si tu le souhaites, tu peux insérer un saut de page ici. ») ;

    • 4 impose une contrainte sévère je t’ordonne d’insérer un saut de page ici ! »).

  • \nopagebreak[⟨n⟩], similaire à \pagebreak[⟨n⟩] mais pour empêcher une coupure de page.

  • \enlargethispage{⟨longueur⟩} impose à de comprimer (⟨longueur⟩ négative) ou d’étirer (⟨longueur⟩ positive) la hauteur du contenu de la page. Ceci peut être utile pour éviter que la page suivante ne contienne trop peu de texte. Par exemple :

    % ajoute un cm
    \enlargethispage{1cm}
    % supprime deux lignes dans la page
    \enlargethispage{-2\baselineskip}
    

Note

\enlargethispage*{⟨lgr⟩} donne une autorité plus grande à la commande \enlargethispage en l’obligeant à agir sur les espacements élastiques verticaux contenus dans la page courante.

1.1.  Cas particulier des sauts de page au sein de listes#

Dans le cas particulier où un utilisateur souhaiterait éviter les coupures de page (ou les coupures de colonnes avec le package multicol) à l’intérieur des \item dans un environnement description (ou dans toute liste), voici une solution simple issue du  :

\begin{description}\interlinepenalty 10000

L’environnement samepage peut éviter qu’une liste à puces ou un paragraphe ne soit coupé par un changement de page.

2.  Avec l’extension needspace#

L’extension needspace permet de réserver de l’espace en bas de page. S’il n’y a pas assez de place dans le restant de la page, une nouvelle est commencée. Par exemple :

... paragraphe précédent.\par
\needspace{5\baselineskip}
% les 5 lignes suivantes seront sur une
% même page / colonne
Les cinq lignes suivantes vont parler de...

3.  Avec l’extension block#

Avertissement

L’extension block.sty est vraisemblablement obsolète. Ce qui suit est informatif.

Le fichier block.sty, de Jean-Pierre F. Drucbert, obtenu partir de commandes de diverses origines (dont Donald Arseneau), permet certains contrôles.

Vous pouvez protéger une zone contre la rupture de page. Il suffit pour cela de la placer dans un environnement Block ou dans un environnement IBlock. Dans le premier cas (Block), le premier paragraphe se trouvant dans la zone n’aura pas de retrait d’alinéa en première ligne, mais dans le second cas (IBlock), tous les paragraphes (même le premier) auront un retrait d’alinéa. Ceci est utile en particulier pour éviter de séparer un texte et un exemple qui l’accompagne. Les blocs ainsi protégés doivent, bien entendu, rester assez petits. La syntaxe est (vous pouvez remplacer Block par IBlock) :

\begin{Block}
...
zone protégée
...
\end{Block}

Cette méthode, très simple, a l’inconvénient de ne pas pouvoir s’appliquer lorsque la zone à protéger doit contenir une commande de sectionnement (c’est-à-dire du même type que section), une note en bas de page, une note marginale ou un corps mobile (figure ou table). Dans ce cas, il faudra utiliser une des commandes du paragraphe suivant.

Vous pouvez aussi demander de changer de page (ou de colonne, si votre document est sur deux colonnes) s’il ne reste pas verticalement assez de place sur la page. Deux commandes de réservation verticale sont disponibles : \need{⟨dimension⟩}, dont le paramètre est une longueur, et \lneed{⟨nombre⟩}, dont le paramètre est le nombre de lignes équivalent à l’espace vertical demandé (avec cette forme le paramètre est plus facile à estimer).