用户控件上的按钮侦听器

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)

但按钮不起作用.

Jer*_*xon 9

我理解你的问题.这是一种创建主页按钮的简单方法,您可以在应用程序的任何位置添加该按钮,它将导航回家.无需级联事件或类似的事情.只需创建一个自定义控件.这与用户控件不同.这只是按钮控件的子类.方法更加清洁.

三个简单的步骤.

注意:我的自定义控件将被称为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="&#xE10F;" 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.无论如何,这将让你到达你想要的地方.

所以,这是主页按钮,可以解决您在问题中描述的问题.它甚至以一种比你想象的方式更少问题的方式解决它 - 因为在上下文中手动冒泡事件会导致噩梦.

我希望这有帮助.