0

リストボックスに表示されるコレクションがあります。これは、主要なlistBoxのlistBoxItemです。各リストボックスのアイテム(メジャーではない)には、テキストボックスとボタンがあります。したがって、リストボックスのいずれかのボタンをタップすると、すべてのコレクションを取得する必要があります。これはWindowsのpnone7アプリケーションです。listbBoxにあるアイテムのリストを取得したい。コレクションではない場合に1つのアイテムを取得する方法を知っています(メジャーリストボックスのアイテムのみ)

        private void Audio_Button_Click(object sender, RoutedEventArgs e)
    {
        string uri = null;
        TextBox tb = null;
        var grid = (Grid)((Button)sender).Parent;
        foreach (var child in grid.Children)
        {
            if (child is TextBox && (string)((TextBox)child).Tag == "URL")
            {
                tb = (TextBox)child;
            }
        }
        uri = tb.Text;

しかし、私はすべてのアイテムを入手する方法を知りません。問題は、「送信者」にlistBoxItemではなくtypeボタンがあることです。とにかく、タイプがlistBoxItemの場合、アイテムのリストを作成する方法がわかりません(

または、スクロールせずに別のコントロールを使用できますか?コレクションはそれほど大きくありません。しかし、私は同じ問題を抱えていると思います(

アップデート:

                                <local:NewsTemplateSelector.Audio>
                                <DataTemplate>
                                    <Grid Name="AudioGrid" MaxHeight="2000">
                                        <Grid.ColumnDefinitions>
                                            <ColumnDefinition Width="75"/>
                                            <ColumnDefinition/>
                                        </Grid.ColumnDefinitions>
                                        <Grid.RowDefinitions>
                                            <RowDefinition Height="75"/>
                                            <RowDefinition Height="Auto"/>
                                            <RowDefinition Height="Auto"/>
                                            <RowDefinition Height="Auto"/>
                                            <RowDefinition Height="28"/>
                                        </Grid.RowDefinitions>
                                        <Image Source="{Binding SourceImage}" Width="75"/>
                                        <TextBlock Text="{Binding SourceName}" Foreground="Black" FontSize="25" Grid.Column="1" TextWrapping="Wrap" />
                                        <TextBlock Text="{Binding Texts}"  Foreground="Black" FontSize="25" Grid.Column="1" Grid.Row="1" TextWrapping="Wrap"  VerticalAlignment="Top" Height="auto" />
                                        <Image Source="{Binding Photo[0].Big}" Margin="10" Grid.Column="1" Grid.Row="2"/>
                                        <TextBlock Text="{Binding Audio[0].Title}"  Foreground="Black" FontSize="25" Margin="96,10,10,10" Grid.Column="1" Grid.Row="3" />
                                        <Button Background="Black"  Content="Play" Grid.Column="1" HorizontalAlignment="Left" Margin="10,7,0,10" Grid.Row="3" d:LayoutOverrides="Height" Width="74" Tap="Audio_Button_Click" />
                                        <Image Source="images\like.jpg" Grid.Column="1" HorizontalAlignment="Right" Grid.Row="4" Width="30" Margin="0,1.5,34,-1.5" d:LayoutOverrides="VerticalMargin"/>
                                        <TextBlock Text="{Binding Likes}" Grid.Column="1" HorizontalAlignment="Right" Grid.Row="4" Foreground="Black" TextWrapping="Wrap" Width="30" Margin="0,0.5,0,-0.5"/>
                                        <Line X1="0" Y1="27" X2="420" Y2="27" Margin="0,-28,0,0" Stroke="Gray" StrokeThickness="1" Grid.Column="1"  />
                                        <Line X1="0" Y1="27" X2="80" Y2="27" Margin="0,-28,0,0" Stroke="Gray" StrokeThickness="1" />
                                        <TextBox Text="{Binding Audio[0].Url}" Tag="URL" Visibility="Collapsed" />
                                    </Grid>
                                </DataTemplate>
                            </local:NewsTemplateSelector.Audio>

  <local:NewsTemplateSelector.Audios>
                                <DataTemplate>
                                    <Grid Name="AudiosGrid" MaxHeight="2000">
                                        <Grid.ColumnDefinitions>
                                            <ColumnDefinition Width="75"/>
                                            <ColumnDefinition/>
                                        </Grid.ColumnDefinitions>
                                        <Grid.RowDefinitions>
                                            <RowDefinition Height="75"/>
                                            <RowDefinition Height="Auto"/>
                                            <RowDefinition Height="Auto"/>
                                            <RowDefinition Height="Auto"/>
                                            <RowDefinition Height="28"/>
                                        </Grid.RowDefinitions>
                                        <Image Source="{Binding SourceImage}" Width="75"/>
                                        <TextBlock Text="{Binding SourceName}" Foreground="Black" FontSize="25" Grid.Column="1" TextWrapping="Wrap" />
                                        <TextBlock Text="{Binding Texts}"  Foreground="Black" FontSize="25" Grid.Column="1" Grid.Row="1" TextWrapping="Wrap"  VerticalAlignment="Top" Height="auto" />
                                        <Image Source="{Binding Photo[0].Big}" Margin="10" Grid.Column="1" Grid.Row="2"/>
                                        <ListBox Name="audiosListbox" ItemsSource="{Binding Audio}"  MaxHeight="500" Margin="10" Grid.Column="1" Grid.Row="3" >
                                            <ListBox.ItemTemplate>
                                                <DataTemplate>
                                                    <Grid>
                                                        <Grid.ColumnDefinitions>
                                                            <ColumnDefinition Width="100"/>
                                                            <ColumnDefinition/>
                                                        </Grid.ColumnDefinitions>
                                                        <TextBlock Text="{Binding Title}" Grid.Column="1" Foreground="Black" FontSize="25"  />
                                                        <Button Content="Play" Background="Black" Tap="Audios_Button_Click" />
                                                        <TextBox Text="{Binding Audio.Url}" Tag="URL" Visibility="Collapsed" />
                                                    </Grid>
                                                </DataTemplate>
                                            </ListBox.ItemTemplate>
                                        </ListBox>

                                        <Image Source="images\like.jpg" Grid.Column="1" HorizontalAlignment="Right" Grid.Row="4" Width="30" Margin="0,1.5,34,-1.5" d:LayoutOverrides="VerticalMargin"/>
                                        <TextBlock Text="{Binding Likes}" Grid.Column="1" HorizontalAlignment="Right" Grid.Row="4" Foreground="Black" TextWrapping="Wrap" Width="30" Margin="0,0.5,0,-0.5"/>
                                        <Line X1="0" Y1="27" X2="420" Y2="27" Margin="0,-28,0,0" Stroke="Gray" StrokeThickness="1" Grid.Column="1"  />
                                        <Line X1="0" Y1="27" X2="80" Y2="27" Margin="0,-28,0,0" Stroke="Gray" StrokeThickness="1" />
                                    </Grid>
                                </DataTemplate>
                            </local:NewsTemplateSelector.Audios>

私は持っていますコレクション

単純

4

1 に答える 1

0

Linq To Visual Tree (ダウンロード コード、1 つのファイルのみ) を使用して、すべての項目を保持する Listbox を取得できます。クリックハンドラーのこのコードは、それに対して機能するはずです。

var parentLb = ((Button)sender).Ancestors().FirstOrDefault(x => x is Listbox) as Listbox;
if(parentLb != null)
{
    // Cast the ItemsSource property to the list type you're using...
    var list = parentLb.ItemsSource
    // And do whatever you want with that list.
}

listもちろん、元の型にキャストする必要があります。

于 2012-12-10T21:30:05.540 に答える