2

リストビューを含むエキスパンダーがあります。エキスパンダーは最初は無効になっており、アプリケーションの起動後に有効になります。

InitializeComponent() の前に、ListView の ItemsSource (もちろん InitializeComponent の前に作成された監視可能なコレクション) に少なくとも 1 つのアイテムを設定すると、すべてがうまく機能します。エキスパンダーが正しく展開され、アイテムが正しく表示されます。唯一の問題は、レンダリングするためにより多くのスペースを必要とする新しいアイテムがトリミングされて表示されることです-これは、ListView が適切に更新されていないことを意味すると思いますか?

ただし、InitializeComponent() の後でいつでもアイテムをコレクションに追加すると、エキスパンダーは少しだけ (ほんの数ピクセル) 拡張します。ListView の Width を強制的に大きな値にすると、エキスパンダーは拡張されますが、リストに挿入されたアイテムは背景色だけでレンダリングされ、コンテンツはありません...

これは、ListViewの初期化、更新、またはあなたが持っているものと関係があると思います。コードは次のとおりです。

XAML:

<DockPanel Name="mainPanel">
    <Expander DockPanel.Dock="Right" ExpandDirection="Right" IsExpanded="False" IsEnabled="{Binding ExpanderEnabled}">
        <Expander.Style>
            <Style TargetType="Expander">
                <Setter Property="Background" Value="#FFFF3333" />
                <Style.Triggers>
                    <DataTrigger Binding="{Binding ExpanderEnabled}" Value="True">
                        <Setter Property="Background" Value="LightGreen" />
                    </DataTrigger>
                </Style.Triggers>
             </Style>
         </Expander.Style>
         <Expander.Header>
             <Grid Width="30" VerticalAlignment="Top" HorizontalAlignment="Left">
                 <Grid Width="300" Height="300" VerticalAlignment="Top" HorizontalAlignment="Left">
                      <TextBlock Text="Expander Name" FontSize="12" FontWeight="Bold" Margin="22,170,0,0" VerticalAlignment="Center" HorizontalAlignment="Left" RenderTransformOrigin="0,1">
            <TextBlock.RenderTransform>
                <TransformGroup>
                    <ScaleTransform/>
                    <SkewTransform/>
                    <RotateTransform Angle="-90"/>
                    <TranslateTransform/>
                </TransformGroup>
            </TextBlock.RenderTransform>
                            </TextBlock>
                        </Grid>
                    </Grid>
         </Expander.Header>
         <ListView ItemsSource="{Binding Items}" BorderBrush="LightGreen" BorderThickness="3">
             <ListView.Style>
                 <Style TargetType="ListView">
                     <Style.Resources>
                         <SolidColorBrush x:Key="{x:Static SystemColors.HighlightBrushKey}" Color="Black"/>
                     </Style.Resources>
                 </Style>
              </ListView.Style>
              <ListView.View>
                  <GridView>
                      <GridView.ColumnHeaderContainerStyle>
                          <Style TargetType="{x:Type GridViewColumnHeader}">
                              <Setter Property="Visibility" Value="Collapsed"/>
                          </Style>
                      </GridView.ColumnHeaderContainerStyle>
                      <GridViewColumn DisplayMemberBinding="{Binding Path=A, Converter={StaticResource aConverter}}" Width="Auto" />
                      <GridViewColumn DisplayMemberBinding="{Binding Path=B, Converter={StaticResource bConverter}}" Width="Auto" />
                      <GridViewColumn DisplayMemberBinding="{Binding Path=C, Converter={StaticResource cConverter}}" Width="Auto" />
                      <GridViewColumn DisplayMemberBinding="{Binding Path=D, StringFormat='\{0\} ds'}" Width="Auto" />
                  </GridView>
              </ListView.View>
           </ListView>
      </Expander>
      ...
4

0 に答える 0