Your Privacy Matters: We use our own and third-party cookies to improve your experience on our website. By continuing to use the website we understand that you accept their use. Cookie Policy
100
Xaml Grid - Horizontal Scrolling
posted

Hi,

i have a hierarchical grid (Xamgrid) with 2 header rows and many columns (> 200). I use grouped header columns and normal header columns mixed.

Now the problem:

When I scroll horizontally with the mouse, I don't get to the last column. Instead it ends somewhere in the middle.
With the keyboard I can scroll further.

To get around this, I scroll to the last column and back by code. But then columns are missing in the middle.

It looks like this could be related to virtualization.

Do you know this problem?
And do you have any idea how to make scrolling with the mouse stable?

greetings

Thomas


 <ig:XamGrid 	x:Name="view"                    
							AutoGenerateColumns="false"
							Background="{DynamicResource {x:Static UiCore:Brushes.WhiteColorBrush}}"
							BorderThickness="0"                    
							CellStyle="{DynamicResource HorizontalGaplessCellControlStyle}"
							ColumnWidth="Auto"
							ContextMenu="{DynamicResource ViewModelContextMenu}"
							DataContext="{Binding}"
							FixedRowSeparatorStyle="{DynamicResource FixedRowSeparatorStyle}"
							HeaderTextHorizontalAlignment="Center"
							Indentation="0"
							IsAlternateRowsEnabled="False"
							ItemsSource="{Binding SubElements}" 
							KeyboardNavigation="AllLayouts"
							MinimumRowHeight="{DynamicResource {x:Static UiCore:Constants.RasterHeight4Constant}}"
							RowHover="Row"                        
							CellControlGenerationMode="Virtualize"                                 
							ColumnResized="view_ColumnResized"
							ScrollBar.Scroll="view_Scroll">

                <ig:XamGrid.Style>
                    <Style BasedOn="{StaticResource {x:Type ig:XamGrid}}"
                       TargetType="{x:Type ig:XamGrid}">
                        <Style.Triggers>
                            <DataTrigger Binding="{Binding HasCustomizedGridColumns}"
                                     Value="False">
                                <Setter Property="IsEnabled"
                                        Value="False" />
                                <Setter Property="Opacity"
                                        Value="0.5" />
                            </DataTrigger>

                            <DataTrigger Binding="{Binding SubElements.Count}"
                                         Value="0">
                                <Setter Property="IsEnabled"
                                        Value="False" />
                                <Setter Property="Opacity"
                                        Value="0.5" />
                            </DataTrigger>

                        </Style.Triggers>
                    </Style>

                </ig:XamGrid.Style>

                <ig:XamGrid.ColumnLayouts>
                    <ig:ColumnLayout Key="SubElements" 
                                     TargetTypeName="RowViewModel"></ig:ColumnLayout> 
                </ig:XamGrid.ColumnLayouts>
           
                <ig:XamGrid.SortingSettings>
                    <ig:SortingSettings AllowSorting="False" />
                </ig:XamGrid.SortingSettings>

                <ig:XamGrid.ColumnResizingSettings>
                    <ig:ColumnResizingSettings AllowColumnResizing="Immediate"
                                               AllowDoubleClickToSize="False"
                                               AllowMultipleColumnResize="False" />
                </ig:XamGrid.ColumnResizingSettings>

                <ig:XamGrid.EditingSettings>
                    <ig:EditingSettings AllowEditing="None"
                                        IsEnterKeyEditingEnabled="False"
                                        IsF2EditingEnabled="False"
                                        IsMouseActionEditingEnabled="None"
                                        IsOnCellActiveEditingEnabled="False" />
                </ig:XamGrid.EditingSettings>
								
								<ig:XamGrid.SelectionSettings>
                    <ig:SelectionSettings CellSelection="Multiple" />
                </ig:XamGrid.SelectionSettings>
</ig:XamGrid>

Parents
  • 34850
    Offline posted

    Hello Thomas,

    My team and I have done an initial review of this thread, and it sounds like there is a lot going on here. As such, I have a few questions for you on this matter. Can you please provide some information regarding the following?

    1. Is there a concrete set of steps that you can provide that reproduces this issue you are seeing?

    2. You mentioned that you have a hierarchical XamGrid in this case – is this issue reproduced by scrolling the child columns or the parent columns (or both)?

    3. I see that you are handling the ScrollBar.Scroll event in your code – what is happening in this event?

    4. What is the specific version of Infragistics for WPF that you are using in this case? For example, if you are using version 2019.1, this number would look like: 19.1.20191.XXXX.

    5. Is migration to the XamDataGrid control an option or possibility for you in this case? I ask because as it states in every topic in our XamGrid online documentation, “We recommend that you use the XamDataGrid control instead of the XamGrid control. The XamGrid is being planned for retirement over the next few years and will not receive any new features. We will continue to provide support and critical bug fixes for the XamGrid during this time. For help or questions on migrating your codebase to the XamDataGrid, please contact support.” At the time of writing this, essentially the only thing that the XamGrid does that the XamDataGrid doesn’t is paging. The XamDataGrid does everything else that the XamGrid does, and it does it better and in a more performant way.

    Please let me know if you have any other questions or concerns on this matter.

Reply Children