Xamarin.Forms 中的 RowSpan 和 ColumnSpan
RowSpan and ColumnSpan in Xamarin.Forms
有没有人可以向我解释 RowSpan
和 ColumnSpan
在 Xamarin.Forms
中是如何工作的?
right, left, top, bottom 参数有点乱
让我们将此代码片段用于 RowSpan
:
grid.Children.Add(new Label
{
Text = "Span two rows (or more if you want)",
TextColor = Color.Yellow,
BackgroundColor = Color.Navy,
XAlign = TextAlignment.Center,
YAlign = TextAlignment.Center
}, 2, 3, 1, 3);
数字 2、3、1、3 在此处的列和行中表示什么?
这适用于四行三列的网格。
此答案由 Till Balandat 从 this answer at Xamarin's forums (archived) 复制粘贴,但在这里很有用,因为 Xamarin 的文档似乎没有解释 Add 方法的附加参数。
带有 4 个参数的 Add 的重载有点令人困惑,但最终可以让您定义 Row、RowSpan、Column 和 Columnspan:
所以上面的例子
var label = new Label { Text = "Row 1" };
myGrid.Children.Add(label,0,0);
Grid.SetColumnSpan(label,2);
转换为:
var label = new Label { Text = "Row 1" };
myGrid.Children.Add(label, 0, 2, 0, 1);
这是 Xamarin 内部所做的:
public void Add(View view, int left, int right, int top, int bottom)
{
//..exceptionhandling removed
Grid.SetRow((BindableObject) view, top);
Grid.SetRowSpan((BindableObject) view, bottom - top);
Grid.SetColumn((BindableObject) view, left);
Grid.SetColumnSpan((BindableObject) view, right - left);
this.Add(view);
}
所以你可能更喜欢这样的东西:
public static class GridExtension
{
public static void AddChild(this Grid grid, View view, int row, int column, int rowspan = 1, int columnspan = 1)
{
if (row < 0)
throw new ArgumentOutOfRangeException("row");
if (column < 0)
throw new ArgumentOutOfRangeException("column");
if (rowspan <= 0)
throw new ArgumentOutOfRangeException("rowspan");
if (columnspan <= 0)
throw new ArgumentOutOfRangeException("columnspan");
if (view == null)
throw new ArgumentNullException("view");
Grid.SetRow((BindableObject)view, row);
Grid.SetRowSpan((BindableObject) view, rowspan);
Grid.SetColumn((BindableObject) view, column);
Grid.SetColumnSpan((BindableObject) view, columnspan);
grid.Children.Add(view);
}
}
有没有人可以向我解释 RowSpan
和 ColumnSpan
在 Xamarin.Forms
中是如何工作的?
right, left, top, bottom 参数有点乱
让我们将此代码片段用于 RowSpan
:
grid.Children.Add(new Label
{
Text = "Span two rows (or more if you want)",
TextColor = Color.Yellow,
BackgroundColor = Color.Navy,
XAlign = TextAlignment.Center,
YAlign = TextAlignment.Center
}, 2, 3, 1, 3);
数字 2、3、1、3 在此处的列和行中表示什么?
这适用于四行三列的网格。
此答案由 Till Balandat 从 this answer at Xamarin's forums (archived) 复制粘贴,但在这里很有用,因为 Xamarin 的文档似乎没有解释 Add 方法的附加参数。
带有 4 个参数的 Add 的重载有点令人困惑,但最终可以让您定义 Row、RowSpan、Column 和 Columnspan: 所以上面的例子
var label = new Label { Text = "Row 1" };
myGrid.Children.Add(label,0,0);
Grid.SetColumnSpan(label,2);
转换为:
var label = new Label { Text = "Row 1" };
myGrid.Children.Add(label, 0, 2, 0, 1);
这是 Xamarin 内部所做的:
public void Add(View view, int left, int right, int top, int bottom)
{
//..exceptionhandling removed
Grid.SetRow((BindableObject) view, top);
Grid.SetRowSpan((BindableObject) view, bottom - top);
Grid.SetColumn((BindableObject) view, left);
Grid.SetColumnSpan((BindableObject) view, right - left);
this.Add(view);
}
所以你可能更喜欢这样的东西:
public static class GridExtension
{
public static void AddChild(this Grid grid, View view, int row, int column, int rowspan = 1, int columnspan = 1)
{
if (row < 0)
throw new ArgumentOutOfRangeException("row");
if (column < 0)
throw new ArgumentOutOfRangeException("column");
if (rowspan <= 0)
throw new ArgumentOutOfRangeException("rowspan");
if (columnspan <= 0)
throw new ArgumentOutOfRangeException("columnspan");
if (view == null)
throw new ArgumentNullException("view");
Grid.SetRow((BindableObject)view, row);
Grid.SetRowSpan((BindableObject) view, rowspan);
Grid.SetColumn((BindableObject) view, column);
Grid.SetColumnSpan((BindableObject) view, columnspan);
grid.Children.Add(view);
}
}