本文整理匯總了C#中Columns.AppendChild方法的典型用法代碼示例。如果您正苦於以下問題:C# Columns.AppendChild方法的具體用法?C# Columns.AppendChild怎麽用?C# Columns.AppendChild使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Columns
的用法示例。
在下文中一共展示了Columns.AppendChild方法的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++;
}
}