Grands titres de page sur iOS
Cette interface utilisateur de l’application multiplateforme .NET (.NET MAUI) spécifique à la plateforme iOS est utilisée pour afficher le titre de la page sous forme de titre volumineux dans la barre de navigation d’un NavigationPageappareil qui utilise iOS 11 ou version ultérieure. Un titre volumineux est aligné à gauche et utilise une police plus grande, et passe à un titre standard lorsque l’utilisateur commence à faire défiler le contenu, afin que l’immobilier de l’écran soit utilisé efficacement. Toutefois, en orientation paysage, le titre revient au centre de la barre de navigation pour optimiser la disposition du contenu. Elle est consommée en XAML en définissant la NavigationPage.PrefersLargeTitles
propriété jointe sur une boolean
valeur :
<NavigationPage xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
xmlns:ios="clr-namespace:Microsoft.Maui.Controls.PlatformConfiguration.iOSSpecific;assembly=Microsoft.Maui.Controls"
...
ios:NavigationPage.PrefersLargeTitles="true">
...
</NavigationPage>
Il peut également être consommé à partir de C# à l’aide de l’API Fluent :
using Microsoft.Maui.Controls.PlatformConfiguration;
using Microsoft.Maui.Controls.PlatformConfiguration.iOSSpecific;
...
var navigationPage = new Microsoft.Maui.Controls.NavigationPage(new iOSLargeTitlePageCode());
navigationPage.On<iOS>().SetPrefersLargeTitles(true);
La NavigationPage.On<iOS>
méthode spécifie que cette plateforme spécifique ne s’exécutera que sur iOS. La NavigationPage.SetPrefersLargeTitle
méthode, dans l’espace Microsoft.Maui.Controls.PlatformConfiguration.iOSSpecific
de noms, contrôle si les titres volumineux sont activés.
À condition que les grands titres soient activés sur la NavigationPagepile de navigation, toutes les pages de la pile de navigation affichent des titres volumineux. Ce comportement peut être substitué sur les pages en définissant la Page.LargeTitleDisplay
propriété jointe sur une valeur de l’énumération LargeTitleDisplayMode
:
<ContentPage ...
xmlns:ios="clr-namespace:Microsoft.Maui.Controls.PlatformConfiguration.iOSSpecific;assembly=Microsoft.Maui.Controls"
Title="Large Title"
ios:Page.LargeTitleDisplay="Never">
...
</ContentPage>
Vous pouvez également remplacer le comportement de la page à partir de C# à l’aide de l’API Fluent :
using Microsoft.Maui.Controls.PlatformConfiguration;
using Microsoft.Maui.Controls.PlatformConfiguration.iOSSpecific;
...
public class iOSLargeTitlePageCode : ContentPage
{
public iOSLargeTitlePageCode
{
On<iOS>().SetLargeTitleDisplay(LargeTitleDisplayMode.Never);
}
...
}
La Page.On<iOS>
méthode spécifie que cette plateforme spécifique ne s’exécutera que sur iOS. La Page.SetLargeTitleDisplay
méthode, dans l’espace Microsoft.Maui.Controls.PlatformConfiguration.iOSSpecific
de noms, contrôle le comportement de titre volumineux sur le Page, avec l’énumération LargeTitleDisplayMode
fournissant trois valeurs possibles :
Always
: forcez la barre de navigation et la taille de police à utiliser le grand format.Automatic
: utilisez le même style (grand ou petit) que l’élément précédent dans la pile de navigation.Never
: forcez l’utilisation de la barre de navigation régulière et de petite mise en forme.
En outre, la SetLargeTitleDisplay
méthode peut être utilisée pour activer/désactiver les valeurs d’énumération en appelant la LargeTitleDisplay
méthode, qui retourne le résultat actuel LargeTitleDisplayMode
:
switch (On<iOS>().LargeTitleDisplay())
{
case LargeTitleDisplayMode.Always:
On<iOS>().SetLargeTitleDisplay(LargeTitleDisplayMode.Automatic);
break;
case LargeTitleDisplayMode.Automatic:
On<iOS>().SetLargeTitleDisplay(LargeTitleDisplayMode.Never);
break;
case LargeTitleDisplayMode.Never:
On<iOS>().SetLargeTitleDisplay(LargeTitleDisplayMode.Always);
break;
}
Le résultat est qu’un spécifié LargeTitleDisplayMode
est appliqué au Page, qui contrôle le comportement du grand titre :