在Xamarin IOS中,你可以试试UIScrollView。设置PagingEnabled,可以实现你的愿望。(在StoryBoard中关注ScrollView也是全屏的)
ScrollView.ContentSize = new CGSize(UIScreen.MainScreen.Bounds.Size.Width, 2*ScrollView.Bounds.Size.Height);
ScrollView.PagingEnabled = true;
表格视图代码:
UITableView uITableView = new UITableView(new CGRect(0, ScrollView.Bounds.Size.Height, UIScreen.MainScreen.Bounds.Size.Width, ScrollView.Bounds.Size.Height));
string[] tableItems = new string[] { "Vegetables", "Fruits", "Flower Buds", "Legumes", "Bulbs", "Tubers", "Vegetables", "Fruits", "Flower Buds", "Legumes", "Bulbs", "Tubers"};
uITableView.BackgroundColor = UIColor.Cyan;
uITableView.Source = new TableSource(tableItems);
public class TableSource : UITableViewSource
{
string[] TableItems;
string CellIdentifier = "TableCell";
public TableSource(string[] items)
{
TableItems = items;
}
public override UITableViewCell GetCell(UITableView tableView, NSIndexPath indexPath)
{
UITableViewCell cell = tableView.DequeueReusableCell(CellIdentifier);
string item = TableItems[indexPath.Row];
//---- if there are no cells to reuse, create a new one
if (cell == null)
{ cell = new UITableViewCell(UITableViewCellStyle.Default, CellIdentifier); }
cell.TextLabel.Text = item;
return cell;
}
public override nint RowsInSection(UITableView tableview, nint section)
{
return TableItems.Length;
}
}
自定义向上视图:
UIView upView = new UIView(new CGRect(0, 0, UIScreen.MainScreen.Bounds.Size.Width, ScrollView.Bounds.Size.Height));
upView.BackgroundColor = UIColor.DarkGray;
最后在 ScrollView 中添加它们:
ScrollView.Add(upView);
ScrollView.Add(uITableView);
图片展示如下:(为了更好的在ScrollView中展示不同的页面,设置upView和uITableView的背景色)
进入这个控制器时,设置ContentOffSet为第二页,然后会先显示tableview,向下滚动时会显示upView。
ScrollView.SetContentOffset(new CGPoint(0, ScrollView.Bounds.Size.Height), true);
如果想在滚动的时候添加Animation,加一个Delegate来监听DraggingStarted
ScrollView.Delegate = new ScrollViewDelegate();
public class ScrollViewDelegate :UIScrollViewDelegate
{
public override void DraggingStarted(UIScrollView scrollView)
{
//base.DraggingStarted(scrollView);
if(scrollView.ContentOffset.Y == scrollView.Bounds.Size.Height)
{
//Add Animation herer
}
}
}