我有一个UICollectionView我已经设置,一切正常(选择,标题等),但是,我想在某些情况下更改滚动方向。
简而言之,如果我进入故事板并更改scrollDirection它工作正常,但我想以编程方式进行!
我试图用
之类的东西直接改变集合视图的滚动方向 [myCollectionView setScrollDirection:....and so on.......
但这不起作用,我找不到scrollDirection或类似的东西。
我也尝试设置流程布局,但我确信我做错了(即尝试将ViewLayout设置为FlowLayout)。
UICollectionViewFlowLayout *flowLayout = [[UICollectionViewFlowLayout alloc]init];
[flowLayout setScrollDirection:UICollectionViewScrollDirectionVertical];
[myCollectionView setCollectionViewLayout:flowLayout];
这会导致很多Constraint问题崩溃,我怀疑我需要使用flowLayout做更多工作(从我发现它现在有点高于我)。
还应该注意的是,我使用的是自定义单元格,页眉和页脚。
简而言之,是否有一种简单的方法可以做到这一点?或者有没有人知道一个好的Flow Layout教程?
修改
我设置了集合视图;
[myCollectionView setDataSource:self];
[myCollectionView setDelegate:self];
我实现了这些委托方法,一切正常
viewForSupplementaryElementOfKind
numberOfSectionsInCollectionView
numberOfItemsInSection
cellForItemAtIndexPath
didSelectItemAtIndexPath
我已将DataSource和Delegate添加到.h以及FlowLayout委托但是我不确定后者应该具备什么。
大多数视觉布局都是在Story Board中完成的,有一些东西,如字体,大小和颜色,我以编程方式进行。
另一个编辑
当我尝试更改FlowLayout时,这是错误,当我尝试使布局无效时,我也会得到这个错误。
无法同时满足约束条件。 可能至少以下列表中的一个约束是您不想要的约束。试试这个:(1)看看每个约束,并试着找出你不期望的东西; (2)找到添加了不需要的约束或约束的代码并修复它。 (注意:如果您正在查看您不了解的NSAutoresizingMaskLayoutConstraints,请参阅UIView属性的文档translatesAutoresizingMaskIntoConstraints)
"<NSAutoresizingMaskLayoutConstraint:0x89967f0 h=--& v=--& V:[menuCell:0x8991700(50)]>",
"<NSLayoutConstraint:0x8991200 menuCell:0x8991700.bottom == UILabel:0x8992be0.bottom + 100>",
"<NSLayoutConstraint:0x898fd50 UILabel:0x8992be0.top == menuCell:0x8991700.top + 3>"
将尝试通过违反约束来恢复
中断objc_exception_throw以在调试器中捕获它。 UIView中列出的UIVonstraintBasedLayoutDebugging类别中的方法也可能有所帮助。
答案 0 :(得分:19)
这样做:
- (IBAction)changeDirection:(UIButton *)sender
{
UICollectionViewFlowLayout *layout = (UICollectionViewFlowLayout *)[self.collectionView collectionViewLayout];
if(layout.scrollDirection == UICollectionViewScrollDirectionHorizontal)
{
layout.scrollDirection = UICollectionViewScrollDirectionVertical;
}
else
{
layout.scrollDirection = UICollectionViewScrollDirectionHorizontal;
}
}
它对我有用。
答案 1 :(得分:5)
在swift中你可以这样做:
//From the collection view subclass
if let layout: UICollectionViewFlowLayout = self.collectionViewLayout as? UICollectionViewFlowLayout {
layout.scrollDirection = .Vertical
}
答案 2 :(得分:0)
好的,尝试在集合视图上调用invalidateLayout,如下所示:
[myCollectionView.collectionViewLayout invalidateLayout];
这会强制集合视图在此时更新其布局(See apple documentation here)。我不确定,但我不认为当你改变滚动方向时会调用它。
看看是否可以让你到达任何地方!
答案 3 :(得分:0)
您可以使用属性查看器didSet{}
和您的集合视图出口来完成此操作。
假定collectionView的出口是myCollectionView,则在代码中向出口添加一个didSet
属性观察器,并更改布局的方向。像-
@IBOutlet weak var myCollectionView:UICollectionView!{
didSet{
let layout = contentCollectionView.collectionViewLayout as!
UICollectionViewFlowLayout
layout.scrollDirection = .Vertical
}
}
通常,collectionView是从对象库中放到情节提要中的,它自动随FlowLayout一起提供。您可以通过告诉代码,当我获取集合视图时,希望其布局的滚动方向为水平或垂直,从而可以更改此布局的流动方向。