Splitview контент свойства окна универсальный
Я включил splitview в мое приложение. Но я не знаю, как заполнить содержание моего splitview. Я прочитал, я должен вложить рамку там. Итак, у меня есть мой Mainpage.xaml, и если пользователь нажимает одну кнопку меню, содержимое разделенного просмотра должно быть, например, helpandabout.xaml. Или что я должен вкладывать в свойство содержимого? И как мне заменить контент на разных страницах. В настоящее время я просто пытался изменить видимость сетки, если пользователь нажимает одну кнопку, но это не философия этого элемента управления. Как это:
<Grid x:Name="Grid1" Visibility="Visible"> </Grid>
<Grid Visibility="Collapsed" x:Name="Grid2"> </Grid>
И затем пользователь нажимает кнопку на панели splitview, и код делает это:
Grid1.Visibility = Visibility.Collapsed;
Grid2.Visibility = Visibility.Visible;
И я знаю, что это глупый кусок кода.
1 ответ
На самом деле вы можете заменить полный стандарт приложения на SplitView, Create Navigation и т. Д.
Я сделал следующее:
1- Изучите пример навигации здесь: пример навигации uwp
2.- После того, как вы узнаете, как это работает, у него есть некоторые хитрости, такие как панель команд находится за пределами панели приложения и т. Д., Вы можете извлечь весь код из библиотеки.
AppShell.xaml, NavMenuItem, NavMenuListView.cs, PageHeader.xaml
3.- Создайте следующие расширения:
public class NavigationExtensions
{
public static void Initialize<T>(List<NavMenuItem> list, NavigationFailedEventHandler OnNavigationFailed, LaunchActivatedEventArgs e)
{
AppShell shell = Window.Current.Content as AppShell;
// Do not repeat app initialization when the Window already has content,
// just ensure that the window is active
if (shell == null)
{
// Create a AppShell to act as the navigation context and navigate to the first page
shell = new AppShell();
shell.NavigationList = list;
try
{
shell.CurrentItem = list.First(i => i.DestPage == typeof(T));
}
catch
{
}
// Set the default language
shell.Language = Windows.Globalization.ApplicationLanguages.Languages[0];
shell.AppFrame.NavigationFailed += OnNavigationFailed;
if (e.PreviousExecutionState == ApplicationExecutionState.Terminated)
{
//TODO: Load state from previously suspended application
}
}
// Place our app shell in the current Window
Window.Current.Content = shell;
if (shell.AppFrame.Content == null)
{
// When the navigation stack isn't restored, navigate to the first page
// suppressing the initial entrance animation.
shell.AppFrame.Navigate(typeof(T), e.Arguments, new Windows.UI.Xaml.Media.Animation.SuppressNavigationTransitionInfo());
}
// Ensure the current window is active
Window.Current.Activate();
}
}
4.- Ссылка на все это в вашем проекте и в добавлении App.xaml.cs
protected override void OnLaunched(LaunchActivatedEventArgs e)
{
NavigationExtensions.Initialize<PersonalView>(Navigation.GetNavigationMenuItems(),OnNavigationFailed,e);
}
где метод, например:
public class Navigation
{
public static List<NavMenuItem> GetNavigationMenuItems()
{
var list = new List<NavMenuItem>(
new[]
{
new NavMenuItem()
{
Symbol = Symbol.Contact,
Label = "Personal",
DestPage = typeof(PersonalView)
},
new NavMenuItem()
{
Symbol = Symbol.World,
Label = "Countries",
DestPage = typeof(CountriesView)
},
new NavMenuItem()
{
Symbol = Symbol.Setting,
Label = "Settings",
DestPage = typeof(SettingsView)
},
});
return list;
}
}