Mas*_*olo 1 c# xaml user-controls listener microsoft-metro
这是问题所在:
我有一个带有听众的"主页按钮"
private void Item_Tap(object sender, TappedRoutedEventArgs e)
{
if (this.Frame != null)
{
this.Frame.Navigate(typeof(Home));
}
}
Run Code Online (Sandbox Code Playgroud)
如果我使用其中的"主页按钮"构建了用户控件,我该如何完成相同的导航?
**我接近解决方案**.这是用户控件:
public sealed partial class TopBarControl : UserControl
{
public Frame Frame { get; set; }
public object Parameter { get; set; }
public TopBarControl(Frame frame)
{
this.InitializeComponent();
this.Frame = frame;
var localSettings = Windows.Storage.ApplicationData.Current.LocalSettings;
var dateAndTime = DateTime.Now;
Date.Text = dateAndTime.Date.ToString("MM/dd/yyyy");
User.Text = localSettings.Values["userName"].ToString();
//SectionTitle.Text = Parameter.ToString();
}
private void GoHome_Tap(object sender, TappedRoutedEventArgs e)
{
if (this.Frame != null)
{
this.Frame.Navigate(typeof(Main_Menu));
}
}
}
Run Code Online (Sandbox Code Playgroud)
在xaml用户控件上我有:
<Button Grid.Column="0" HorizontalAlignment="Right" BorderThickness="0">
<Image Source="/Assets/home_icon.png" Tapped="GoHome_Tap"/>
</Button>
Run Code Online (Sandbox Code Playgroud)
与用户控件关联的页面
public WantedVehicles()
{
this.InitializeComponent();
}
private TopBarControl topBarControl;
protected override void OnNavigatedTo(NavigationEventArgs e)
{
Tit.Text = e.Parameter.ToString();
topBarControl.Frame = this.Frame;
topBarControl.Parameter = e.Parameter;
}
protected override void LoadState(Object navigationParameter, Dictionary<String, Object> pageState)
{
}
protected override void SaveState(Dictionary<String, Object> pageState)
{
}
Run Code Online (Sandbox Code Playgroud)
但按钮不起作用.
我理解你的问题.这是一种创建主页按钮的简单方法,您可以在应用程序的任何位置添加该按钮,它将导航回家.无需级联事件或类似的事情.只需创建一个自定义控件.这与用户控件不同.这只是按钮控件的子类.方法更加清洁.
三个简单的步骤.
注意:我的自定义控件将被称为HomeButton,我的主页类将被称为HomePage.除此之外,这应该是开箱即用的.
首先,定义按钮的外观:
<!-- custom home button -->
<Style TargetType="local:HomeButton" BasedOn="{StaticResource BackButtonStyle}">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="Button">
<Grid Height="48" Width="48">
<Ellipse Stroke="White" StrokeThickness="2" />
<TextBlock Text="" FontSize="20"
VerticalAlignment="Center" HorizontalAlignment="Center" />
</Grid>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
Run Code Online (Sandbox Code Playgroud)
其次,定义您的自定义控件,如下所示:
public sealed class HomeButton : Button
{
public HomeButton()
{
this.DefaultStyleKey = this.GetType();
this.Click += HomeButton_Click;
}
void HomeButton_Click(object sender, RoutedEventArgs e)
{
var _Frame = Window.Current.Content as Frame;
var _Type = typeof(HomePage);
_Frame.Navigate(_Type);
}
}
Run Code Online (Sandbox Code Playgroud)
第三,最后,将您的主页按钮添加到您的应用程序!
<local:HomeButton HorizontalAlignment="Left" VerticalAlignment="Top" Margin="40" />
Run Code Online (Sandbox Code Playgroud)
以下是它的外观:

它甚至有效!:)如果你想更多地设置按钮的样式,很容易在/Common/StandardStyles.xaml文件中窃取BackButtonStyle的样式.然后你可以拥有相同的View States和all.无论如何,这将让你到达你想要的地方.
所以,这是主页按钮,可以解决您在问题中描述的问题.它甚至以一种比你想象的方式更少问题的方式解决它 - 因为在上下文中手动冒泡事件会导致噩梦.
我希望这有帮助.
| 归档时间: |
|
| 查看次数: |
2963 次 |
| 最近记录: |