2013-07-08 2 views
0

У меня есть объекты, которые выглядят так:Отобразить иерархические данные с помощью UltraWinGrid с некоторыми настройками конфигурации сетки?

public class ComponentProperty 
{   
    public string Property { get; set; } 
    public object Value { get; set; } 
    public string DataType { get; set; } 
    public string PropertyKey { get; set; } 
    public string Unit { get; set; } 
    public string DependencyType { get; set; } 
    public object ListType { get; set; } 

    public List<ComponentProperty> Properties { get; set; } 
} 

У меня есть информация построить более в следующем виде BindingList, где результат:

public class ComponentPropertyList: BindingList<ComponentProperty> 
{ 

} 

Сценарий:

Список Компоненты Свойства связываются с Infragistics Ultra WinGrid, чтобы генерировать Master-Detail View, и я сделал следующую настройку в Grid настройки:

void ultraGrid1_InitializeLayout(object sender, Infragistics.Win.UltraWinGrid.InitializeLayoutEventArgs e) 
{ 
    ultraGrid1.DisplayLayout.Override.AllowColSizing = AllowColSizing.Synchronized; 
    e.Layout.Bands[0].Override.HeaderAppearance.FontData.Bold = Infragistics.Win.DefaultableBoolean.True; 
    ultraGrid1.DisplayLayout.Appearance.BackColor = Color.White; 
    ultraGrid1.DisplayLayout.Appearance.BackColor2 = Color.White; 
    ultraGrid1.DisplayLayout.Override.ActiveRowAppearance = null; 
    ultraGrid1.DisplayLayout.BorderStyle = UIElementBorderStyle.None; 
    ultraGrid1.DisplayLayout.Override.BorderStyleCell = UIElementBorderStyle.None; 
    ultraGrid1.DisplayLayout.Override.BorderStyleRow = UIElementBorderStyle.None; 
    ultraGrid1.DisplayLayout.Override.ColumnAutoSizeMode = ColumnAutoSizeMode.Default; 
    ultraGrid1.DisplayLayout.Bands[0].ColHeadersVisible = true; 
    ultraGrid1.DisplayLayout.Bands[0].Override.RowSelectors = DefaultableBoolean.False; 
    ultraGrid1.DisplayLayout.Bands[0].Columns[0].CellActivation = Activation.NoEdit; 
    ultraGrid1.DisplayLayout.Bands[0].Columns[1].CellActivation = Activation.AllowEdit; 
    //Infosys: Nikita - Added for #1143 - START 
    ultraGrid1.DisplayLayout.Bands[0].Columns["Unit"].CellActivation = Activation.NoEdit; 
    //Infosys: Nikita - Added for #1143 - END 
    ultraGrid1.DisplayLayout.Bands[0].Columns[1].CellAppearance.BorderColor = Color.Black; 
    ultraGrid1.DisplayLayout.Override.RowAppearance.TextVAlign = VAlign.Middle; 
    // e.Layout.Bands[0].Columns[1].Width = 90; 
    ultraGrid1.DisplayLayout.Scrollbars = Scrollbars.Automatic; 
    ultraGrid1.DisplayLayout.ScrollBounds = ScrollBounds.ScrollToFill; 
    ultraGrid1.DisplayLayout.AutoFitStyle = AutoFitStyle.ResizeAllColumns; 
    ultraGrid1.DisplayLayout.Bands[0].Columns[2].AutoSizeMode = ColumnAutoSizeMode.None; 
    ultraGrid1.DisplayLayout.Bands[0].Columns[3].AutoSizeMode = ColumnAutoSizeMode.None; 
    ultraGrid1.DisplayLayout.Bands[0].Columns[2].Hidden = true; 
    ultraGrid1.DisplayLayout.Bands[0].Columns[3].Hidden = true; 
    //ultraGrid1.DisplayLayout.Bands[0].Columns[Constants.Collevel].Hidden = true; 
    //ultraGrid1.DisplayLayout.Bands[0].Columns[Constants.ColID].Hidden = true; 
    //ultraGrid1.DisplayLayout.Bands[0].Columns[Constants.Colparentid].Hidden = true; 
    ultraGrid1.DisplayLayout.Bands[0].Columns["DependencyType"].Hidden = true; 
    ultraGrid1.DisplayLayout.Bands[0].Columns["ListType"].Hidden = true; 
    //ultraGrid1.DisplayLayout.Bands[0].Override.AllowColSizing = AllowColSizing.Synchronized; 
    ultraGrid1.DisplayLayout.BorderStyle = UIElementBorderStyle.Default; 


    //ultraGrid1.DisplayLayout.Bands[0].Columns[1].TabStop = false; 
    ultraGrid1.DisplayLayout.Bands[0].Columns[1].CellAppearance.BackColor = Color.White; 

    ultraGrid1.DisplayLayout.Bands[0].Columns["Value"].Style = Infragistics.Win.UltraWinGrid.ColumnStyle.DropDownList; 
    ultraGrid1.DisplayLayout.Bands[0].Columns["Value"].ButtonDisplayStyle = Infragistics.Win.UltraWinGrid.ButtonDisplayStyle.Always; 

    ultraGrid1.DisplayLayout.Bands[0].Columns["Value"].CellAppearance.BackColor = Color.White; 

    ultraGrid1.DisplayLayout.Override.SupportDataErrorInfo = SupportDataErrorInfo.CellsOnly; 
    ultraGrid1.DisplayLayout.Bands[0].Columns[1].SupportDataErrorInfo = DefaultableBoolean.True; 

    ultraGrid1.DisplayLayout.Bands[0].Columns[0].Width = 200; 
    ultraGrid1.DisplayLayout.Bands[0].Columns["Value"].Width = 120; 
    ultraGrid1.DisplayLayout.Bands[0].Columns["Value"].TabIndex = 0; 
    ultraGrid1.DisplayLayout.Bands[0].Columns["Unit"].Width = 60; 

    for (int rowCount = 0; rowCount < ultraGrid1.Rows.Count; rowCount++) 
    { 
     UltraGridRow row = ultraGrid1.Rows[rowCount]; 
     if (string.IsNullOrEmpty(Convert.ToString(row.Cells[1].Value))) 
     { 
      row.Cells[1].Appearance.BackColor = Color.White; 
     } 
    } 

    ultraGrid1.DisplayLayout.BorderStyle = Infragistics.Win.UIElementBorderStyle.Solid; 
    ultraGrid1.DisplayLayout.Override.BorderStyleCell = Infragistics.Win.UIElementBorderStyle.Solid; 


    ultraGrid1.DisplayLayout.Override.GroupByRowSpacingAfter = 0; 
    ultraGrid1.DisplayLayout.Override.GroupByRowSpacingBefore = 0; 
    ultraGrid1.DisplayLayout.Override.HeaderPlacement = HeaderPlacement.OncePerGroupedRowIsland; 

    if (ultraGrid1.DisplayLayout.Bands.Count > 1) 
    { 
     ultraGrid1.DisplayLayout.Bands[1].ColHeadersVisible = false; 
     ultraGrid1.DisplayLayout.Bands[1].Columns[2].AutoSizeMode = ColumnAutoSizeMode.None; 
     ultraGrid1.DisplayLayout.Bands[1].Columns[3].AutoSizeMode = ColumnAutoSizeMode.None; 
     ultraGrid1.DisplayLayout.Bands[1].Columns[0].CellActivation = Activation.NoEdit; 
     ultraGrid1.DisplayLayout.Bands[1].Columns[4].CellActivation = Activation.NoEdit; 
     ultraGrid1.DisplayLayout.Bands[1].Columns[2].Hidden = true; 
     ultraGrid1.DisplayLayout.Bands[1].Columns[3].Hidden = true; 
     ultraGrid1.DisplayLayout.Bands[1].Columns["DependencyType"].Hidden = true; 
     ultraGrid1.DisplayLayout.Bands[1].Columns["ListType"].Hidden = true; 
     ultraGrid1.DisplayLayout.Bands[1].Columns[0].Width = 120; 
     //ultraGrid1.DisplayLayout.Bands[1].Columns[0].TabStop = false; 
     ultraGrid1.DisplayLayout.Bands[1].Columns["Value"].Width = 180; 
     ultraGrid1.DisplayLayout.Bands[1].Columns["Value"].TabIndex = 0; 
     ultraGrid1.DisplayLayout.Bands[1].Columns["Unit"].Width = 60; 
     //ultraGrid1.DisplayLayout.Bands[1].Columns[Constants.ColUnit].TabStop = false; 
     ultraGrid1.DisplayLayout.Override.RowSelectors = DefaultableBoolean.False; 
     if (e.Layout.Bands[1].Columns.Exists(" ") == true) 
     { 
      ultraGrid1.DisplayLayout.Bands[1].Columns[" "].Width = 0; 
     } 
     if (e.Layout.Bands[1].Columns.Exists(" ") == false) 
     { 
      ultraGrid1.DisplayLayout.Bands[1].Columns.Add(" "); 
      ultraGrid1.DisplayLayout.Bands[1].Columns[" "].Header.VisiblePosition = 0; 
      ultraGrid1.DisplayLayout.Bands[1].Columns[" "].Width = 0; 
     } 
     if (ultraGrid1.DisplayLayout.Bands.Count > 2) 
     { 

      ultraGrid1.DisplayLayout.Bands[2].ColHeadersVisible = false; 
      ultraGrid1.DisplayLayout.Bands[2].Columns[2].AutoSizeMode = ColumnAutoSizeMode.None; 
      ultraGrid1.DisplayLayout.Bands[2].Columns[3].AutoSizeMode = ColumnAutoSizeMode.None; 
      ultraGrid1.DisplayLayout.Bands[2].Columns[0].CellActivation = Activation.NoEdit; 
      ultraGrid1.DisplayLayout.Bands[2].Columns[4].CellActivation = Activation.NoEdit; 
      //ultraGrid1.DisplayLayout.Bands[2].Override.AllowColSizing = AllowColSizing.None; 
      ultraGrid1.DisplayLayout.Bands[2].Columns[2].Hidden = true; 
      ultraGrid1.DisplayLayout.Bands[2].Columns[3].Hidden = true; 

      ultraGrid1.DisplayLayout.Bands[2].Columns["DependencyType"].Hidden = true; 
      ultraGrid1.DisplayLayout.Bands[2].Columns["ListType"].Hidden = true; 
      ultraGrid1.DisplayLayout.Bands[2].Columns[0].Width = 200; 
      ultraGrid1.DisplayLayout.Bands[2].Columns["Value"].Width = 120; 
      ultraGrid1.DisplayLayout.Bands[2].Columns["Unit"].Width = 60; 
      ultraGrid1.DisplayLayout.Override.RowSelectors = DefaultableBoolean.False; 
      //ultraGrid1.DisplayLayout.Bands[2].Columns[0].TabStop = false; 
      ultraGrid1.DisplayLayout.Bands[2].Columns["Value"].TabIndex = 0; 
      //ultraGrid1.DisplayLayout.Bands[2].Columns[Constants.ColUnit].TabStop = false; 
      ultraGrid1.DisplayLayout.Bands[2].Columns["Value"].Style = Infragistics.Win.UltraWinGrid.ColumnStyle.DropDownList; 
      ultraGrid1.DisplayLayout.Bands[2].Columns["Value"].ButtonDisplayStyle = Infragistics.Win.UltraWinGrid.ButtonDisplayStyle. 
      if (e.Layout.Bands[2].Columns.Exists(" ") == true) 
      { 
       ultraGrid1.DisplayLayout.Bands[2].Columns[" "].Width = 0; 
      } 
      if (e.Layout.Bands[2].Columns.Exists(" ") == false) 
      { 
       ultraGrid1.DisplayLayout.Bands[2].Columns.Add(" "); 
       ultraGrid1.DisplayLayout.Bands[2].Columns[" "].Header.VisiblePosition = 0; 
       ultraGrid1.DisplayLayout.Bands[2].Columns[" "].Width = 0; 
      } 
     } 
    } 
    e.Layout.Bands[0].Override.CellAppearance.BorderAlpha = Alpha.Transparent; 
    e.Layout.Bands[0].Override.SelectedCellAppearance.ForeColor = Color.Black; 
    e.Layout.Bands[0].Override.RowAppearance.BorderAlpha = Alpha.Transparent; 
    e.Layout.Bands[0].Override.CellAppearance.BackColorAlpha = Alpha.Transparent; 
    e.Layout.Bands[0].Columns[0].CellActivation = Activation.NoEdit; 
    e.Layout.Bands[0].Columns[1].CellActivation = Activation.NoEdit; 
    e.Layout.Bands[0].Columns[2].CellActivation = Activation.NoEdit; 
    ultraGrid1.DisplayLayout.AutoFitStyle = AutoFitStyle.ResizeAllColumns; 
    ultraGrid1.DisplayLayout.Bands[0].Override.RowSelectors = DefaultableBoolean.False; 
    ultraGrid1.DisplayLayout.Appearance.BackColor = Color.White; 
    //ultraGrid1.DisplayLayout.Override.AllowColSizing = AllowColSizing.None; 
    //ultraGrid1.DisplayLayout.Override.AllowRowLayoutColMoving = GridBagLayoutAllowMoving.None; 
    ultraGrid1.DisplayLayout.BorderStyle = UIElementBorderStyle.Solid; 
    ultraGrid1.DisplayLayout.Bands[0].Columns[1].ButtonDisplayStyle = Infragistics.Win.UltraWinGrid.ButtonDisplayStyle.Always; 
    ultraGrid1.DisplayLayout.TabNavigation = TabNavigation.NextCell; 


    if (e.Layout.Bands[0].Columns.Exists(" ") == true) 
    { 
     ultraGrid1.DisplayLayout.Bands[0].Columns[" "].Width = 0; 
     //ultraGrid1.DisplayLayout.Bands[0].Columns[" "].ColSpan = 3; 
    } 
    if (e.Layout.Bands[0].Columns.Exists(" ") == false) 
    { 
     ultraGrid1.DisplayLayout.Bands[0].Columns.Add(" ").DataType = typeof(bool); 
     ultraGrid1.DisplayLayout.Bands[0].Columns[" "].Header.VisiblePosition = 0; 
     ultraGrid1.DisplayLayout.Bands[0].Columns[" "].Width = 0; 
     // ultraGrid1.DisplayLayout.Bands[0].Columns[" "].ColSpan = 3; 
     ultraGrid1.DisplayLayout.Bands[0].Columns[" "].Style = Infragistics.Win.UltraWinGrid.ColumnStyle.CheckBox; 
     UltraGridColumn checkBox = ultraGrid1.DisplayLayout.Bands[0].Columns[" "]; 
    } 

    foreach (UltraGridBand band in ultraGrid1.DisplayLayout.Bands) 
    { 
     band.HeaderVisible = false; 
    } 
} 

В состав коллекции компонентов может быть N уровень в зависимости от значений.

CompoentProperty 1
--------> SubProperty1
----------------> SubSubProperty1
---------- ------> SubSubProperty1
CompoentProperty 2
--------> SubProperty2
----------------> SubSubProperty2
---- ------------> SubSubProperty2
----------------------> SubSubProperty3
-------- --------------> SubSubProperty3
--------------------------->SubSubProperty NN

Проблема:

Layout не является правильным , есть много Banding после присвоения DataSource сетке, так как ComponentProperties Класс и указанный Column Size не оказывает на это никакого влияния. Раньше я использовал datatable как источник данных, который необходимо заменить источником данных объекта. Существуют ли какие-либо настройки для работы с объектными источниками данных.

Lost of band showing rather than just 3 bands if i have 3 level hierarchy

+0

Это не ясно, что вы после этого. Вы хотите, чтобы ComponentProperty была первой полосой («мастер») и сплющенной иерархией в качестве 2-й группы, или вы хотите сохранить уровни? – kristianp

ответ

3

я получил какое-то решение от Infragistics фото- галерей, что некоторые, что решить проблему компоновки. Как я проверял, когда я использую IList, эти настройки работают правильно после установки MaxBandDepth Property при событии загрузки формы.

// Load only upto two descendant bands. So even if the data source has more than 3 level 
// deep hierarchy, the UltraGrid will only make use of first two levels and ignore the 
// levels deeper than that. 
    this.ultraGrid1.DisplayLayout.MaxBandDepth = 3; 

Проблема, которая произошла было похоже, как спросили ниже темы:
First Column of Wingrid Extending too large when datasource is IList

По умолчанию сетки синхронизирует ширину столбцов каждой группы. Итак, в таком случае, когда у вас есть рекурсивный источник данных, - это по существу бесконечное количество полос и для каждой полосы сетка немного отступы. Это означает, что первый столбец становится очень большим , чтобы разместить отступы вплоть до иерархии . Сетка ограничивает до 100 диапазонов глубины по умолчанию, , но это все равно означает 100 уровень отступов.

Таким образом, существует несколько способов, которыми вы можете справиться.

Установите MaxBandDepth на сетку на меньшее значение. Я рекомендую значение между 5 и 8. Это даст вам неплохую производительность на достойной машине , и большинство пользователей, вероятно, не разберут более 5 уровней. Вы можете установить AllowColSizing в Free. Это остановит сетку от синхронизации ширины столбцов и позволит независимо распределять столбцы каждой полосы.

Ссылки:
MaxBandDepth Changing After Datasource Set
MaxBandDepth is not being used when the datasource is set
Ultragrid Hierarchical DataSource with Multiple Level Paths
UltraGrid hierarchy

 Смежные вопросы

  • Нет связанных вопросов^_^