如何为stackpanel实现click事件

时间:2013-07-17 11:34:31

标签: c# windows-phone-8 visibility stackpanel

我在这里查看了stackpanel类http://msdn.microsoft.com/en-us/library/system.windows.controls.stackpanel.aspx,它没有点击事件。

我正在使用Windows Phone 8应用程序,我在堆栈面板上有一个文本框和一些按钮。我想要包含一个可以单击stackpanel的功能,然后将其上的控件的可见性设置为折叠,然后再次单击时它们将变为可见。

我该怎么做?

5 个答案:

答案 0 :(得分:8)

尝试使用MouseLeftButtonUp事件。

答案 1 :(得分:5)

您可以将整个堆叠面板包裹在一个按钮中:

<button>
    <stackpanel>
    </stackpanel>
</button>

然后根据需要将单击事件或命令附加到按钮。

答案 2 :(得分:0)

您可以使用TouchUpTouchDown事件。 但我认为您必须检查TouchDown是否与StackPanel位于同一TouchUp。所以你可以检查它是否是“点击”。

答案 3 :(得分:0)

你可以用一点点狡猾的方式解决这个问题,如果它很好就可以,否则我会发布另一个。

 <StackPanel Background="Red" MinHeight="80"  VerticalAlignment="Top" Tap="StackPanel_Tap_1" Orientation="Horizontal">
            <Button x:Name="btn1" Content="Button"/>
            <Button x:Name="btn2" Content="Button"/>
            <TextBox Height="72" x:Name="textbox1" TextWrapping="Wrap" Text="TextBox" Width="456"/>
        </StackPanel> 




 private void StackPanel_Tap_1(object sender, GestureEventArgs e)
    {


        if (btn1.IsEnabled==false)
        {
            btn1.IsEnabled = true;
            btn1.Visibility = Visibility.Visible;
            btn2.Visibility = Visibility.Visible;
            textbox1.Visibility = Visibility.Visible;
        }
        else
        {

            btn1.IsEnabled = false;
            btn1.Visibility = Visibility.Collapsed;
            btn2.Visibility = Visibility.Collapsed;
            textbox1.Visibility = Visibility.Collapsed;
        }

    }

答案 4 :(得分:-1)

StackPanel置于Border控件内,使用MouseLeftButtonUp的{​​{1}}处理事件,并将Border的背景设置为Border }