本文整理汇总了C#中Columns.RemoveChild方法的典型用法代码示例。如果您正苦于以下问题:C# Columns.RemoveChild方法的具体用法?C# Columns.RemoveChild怎么用?C# Columns.RemoveChild使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Columns
的用法示例。
在下文中一共展示了Columns.RemoveChild方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: UpdateColumn
private static void UpdateColumn(Column column, Columns columns, Dictionary<uint, Column> sheetColumnsByMin)
{
var co = column.Min.Value;
Column newColumn;
if (!sheetColumnsByMin.ContainsKey(co))
{
newColumn = (Column)column.CloneNode(true);
columns.AppendChild(newColumn);
sheetColumnsByMin.Add(co, newColumn);
}
else
{
var existingColumn = sheetColumnsByMin[column.Min.Value];
newColumn = (Column)existingColumn.CloneNode(true);
newColumn.Min = column.Min;
newColumn.Max = column.Max;
newColumn.Style = column.Style;
newColumn.Width = column.Width;
newColumn.CustomWidth = column.CustomWidth;
if (column.Hidden != null)
newColumn.Hidden = true;
else
newColumn.Hidden = null;
if (column.Collapsed != null)
newColumn.Collapsed = true;
else
newColumn.Collapsed = null;
if (column.OutlineLevel != null && column.OutlineLevel > 0)
newColumn.OutlineLevel = (byte)column.OutlineLevel;
else
newColumn.OutlineLevel = null;
sheetColumnsByMin.Remove(column.Min.Value);
if (existingColumn.Min + 1 > existingColumn.Max)
{
//existingColumn.Min = existingColumn.Min + 1;
//columns.InsertBefore(existingColumn, newColumn);
//existingColumn.Remove();
columns.RemoveChild(existingColumn);
columns.AppendChild(newColumn);
sheetColumnsByMin.Add(newColumn.Min.Value, newColumn);
}
else
{
//columns.InsertBefore(existingColumn, newColumn);
columns.AppendChild(newColumn);
sheetColumnsByMin.Add(newColumn.Min.Value, newColumn);
existingColumn.Min = existingColumn.Min + 1;
sheetColumnsByMin.Add(existingColumn.Min.Value, existingColumn);
}
}
}
示例2: CollapseColumns
private static void CollapseColumns(Columns columns, Dictionary<uint, Column> sheetColumns)
{
UInt32 lastMin = 1;
var count = sheetColumns.Count;
var arr = sheetColumns.OrderBy(kp => kp.Key).ToArray();
// sheetColumns[kp.Key + 1]
//Int32 i = 0;
//foreach (KeyValuePair<uint, Column> kp in arr
// //.Where(kp => !(kp.Key < count && ColumnsAreEqual(kp.Value, )))
// )
for (var i = 0; i < count; i++)
{
var kp = arr[i];
if (i + 1 != count && ColumnsAreEqual(kp.Value, arr[i + 1].Value)) continue;
var newColumn = (Column)kp.Value.CloneNode(true);
newColumn.Min = lastMin;
var newColumnMax = newColumn.Max.Value;
var columnsToRemove =
columns.Elements<Column>().Where(co => co.Min >= lastMin && co.Max <= newColumnMax).
Select(co => co).ToList();
columnsToRemove.ForEach(c => columns.RemoveChild(c));
columns.AppendChild(newColumn);
lastMin = kp.Key + 1;
//i++;
}
}