在UICollectionView中更改滚动方向

时间:2014-01-13 16:04:01

标签: ios xcode cocoa-touch uicollectionview flowlayout

我有一个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类别中的方法也可能有所帮助。

4 个答案:

答案 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一起提供。您可以通过告诉代码,当我获取集合视图时,希望其布局的滚动方向为水平或垂直,从而可以更改此布局的流动方向。