XAML Textblock Tapped事件未在ItemsControl DataTemplate中触发

时间:2014-03-28 15:14:15

标签: c# xaml windows-store-apps

        <DataTemplate x:Key="nodeTrafficQualifierTemplate">
        <Grid Width="400" Margin="8">
            <Grid.ColumnDefinitions>
                <ColumnDefinition Width="Auto"></ColumnDefinition>
                <ColumnDefinition Width="*"></ColumnDefinition>
                <ColumnDefinition Width="Auto"></ColumnDefinition>
            </Grid.ColumnDefinitions>
            <TextBlock Grid.Column="0" TextWrapping="WrapWholeWords" Text="{Binding Name}" />
            <StackPanel Grid.Column="2" Orientation="Horizontal" HorizontalAlignment="Right" >
                <TextBlock Name="GreenQualifier"  Text="{StaticResource CircleOpen}" 
                       IsTapEnabled="True"
                       Tapped="TrafficLightQualifier_OnTapped"
                       FontFamily="{StaticResource SymbolThemeFontFamily}" 
                       FontSize="20" Margin="0,0,60,0" Foreground="Green"/>
            </StackPanel>
        </Grid>
    </DataTemplate>

private void TrafficLightQualifier_OnTapped(object sender, TappedRoutedEventArgs e)
    {
        // Never get here...
        var qualifier = ((TextBlock)sender).Name;
        switch (qualifier)
        {
            case "GreenQualifier":

                break;
        }
    }

事件处理程序根本不会被调用。除了使用Image控件而不是Textblock之外,我有与此相同的东西,并且Tapped事件处理程序工作正常。

Textblock的Loaded事件触发并且处理没有问题。

这与焦点有关吗?有没有办法让这个工作?

谢谢!

3 个答案:

答案 0 :(得分:2)

这绝对是一个边缘案例。我在Textbloxk中用作文本的符号是“零宽度”字形,旨在相互叠加以制作单选按钮等。大多数符号字形不是零宽度,它们工作正常。解决方案是在Textblock中添加Width =“40”,然后事件处理程序正常工作。

答案 1 :(得分:2)

尝试在后面的代码中的构造函数中添加处理程序:

GreenQualifier.AddHandler(TappedEvent, new TappedEventHandler(TrafficLightQualifier_OnTapped), true);

答案 2 :(得分:1)

对我来说,它运作正常。

但是,一个假设是ListView或消耗DataTemplate的地方在事件处理程序之前处理Tapped事件。检查您的ListView属性和我的。

我的ListView如下。您可以找到<!-- THIS IS WHERE I TESTED -->代码。

<ListView Grid.Row="0" x:Name="ListViewPages" HorizontalAlignment="Stretch" Background="{StaticResource LbLightShadowBrush}"
        VerticalAlignment="Stretch" BorderThickness="0" Margin="0,45,0,0"
        CanReorderItems="True" CanDragItems="True" AllowDrop="True" ItemContainerStyle="{StaticResource ListViewItemStyle1}" SelectionChanged="ListViewPages_OnSelectionChanged">
                        <ListView.ItemTemplate>
                            <DataTemplate>
                                <Border BorderBrush="White" BorderThickness="0,0,0,0" Height="60">
                                    <Grid Background="White">
                                        <StackPanel Orientation="Vertical" Margin="5">
                                            <TextBlock x:Name="TestBlock" Foreground="{StaticResource LbBackgroundBrush}" Text="{Binding Path=Title}" FontFamily="Global User Interface" Margin="0,3" Tapped="TestBlock_OnTapped" /> <!-- THIS IS WHERE I TESTED -->
                                            <TextBlock Foreground="{StaticResource LbLightTextBrush}" Text="{Binding Path=Data, Converter={StaticResource PropertyDataSummary}}"/>
                                        </StackPanel>

                                    </Grid>
                                </Border>
                            </DataTemplate>
                        </ListView.ItemTemplate>
                        <ItemsPanelTemplate>
                            <VirtualizingStackPanel Orientation="Vertical" />
                        </ItemsPanelTemplate>
                    </ListView>

并且,只需通过断点检查eventhandler。

        private void TestBlock_OnTapped(object sender, TappedRoutedEventArgs e)
    {
        Debug.WriteLine("tapped");
    }