图1 点击导航栏上一个item(漏洞状左边)可以切换排列方式
图2 变成图2这种排列,这种怎么做。而且点击了切换item之后没有等待,直接更新的。不像是重新发送了请求。
图1 点击导航栏上一个item(漏洞状左边)可以切换排列方式
图2 变成图2这种排列,这种怎么做。而且点击了切换item之后没有等待,直接更新的。不像是重新发送了请求。
两个页面都用 UICollectionView来做,第一个看似表格,其实用UIColectionView也能做出来,
UICollectionViewDelegate, UICollectionViewDataSource, UICollectionViewDelegateFlowLayout
UICollectionView 是通过这3个协议中的方法来实现的,
定义个Bool变量,来切换效果1与效果2, 在上面的3个协议的方法中,用
if Bool {...} else {...}
来给UICollectionView 赋予不同的形态
点击导航栏的item后,Bool变量发生变化,reload
PS: UI变化,要放在主线程中
和楼上的答案差不多,俩个样式都用UICollectionView,准备两个样式的cell,在UICollectionViewDelegateFlowLayout的代理方法
(CGSize)collectionView:(UICollectionView )collectionView layout:(UICollectionViewLayout)collectionViewLayout sizeForItemAtIndexPath:(NSIndexPath *)indexPath
{
//self.isStyle1,用于判断是那种样式,
if (self.isStyle1)
{
//高度自己设置,这里设置为40
return CGSizeMake(collectionView.frame.size.width, 40);
}
else
{
//样式2
return CGSizeMake(collectionView.frame.size.width/2, 40);
}
}
//在创建 cell 的代理中逻辑一样就不写了
//点击导航上的 item,self.isStyle1取反,reloadData
2 回答1k 阅读
1 回答1.1k 阅读✓ 已解决
1 回答2.7k 阅读
1 回答1.5k 阅读
1 回答1.4k 阅读
1.7k 阅读
1 回答1.1k 阅读
这里有个Demo
涉及到:UICollectionView的这个方法
(UICollectionViewTransitionLayout )startInteractiveTransitionToCollectionViewLayout:(UICollectionViewLayout )layout
还有:UICollectionViewTransitionLayout这个类.