我有一个集合视图,我正在尝试获取我正在窥视和弹出的单元格的索引。
目前我正在使用indexPathForItemAtPoint:
然而这总是返回0
无处在我点击屏幕。
- (void)viewDidLoad {
[super viewDidLoad];
[self registerForPreviewingWithDelegate:self sourceView:self.collectionView];
}
- (UIViewController *) previewingContext:(id <UIViewControllerPreviewing>)previewingContext viewControllerForLocation:(CGPoint)location {
CellEditViewController *CEVC = [self.storyboard instantiateViewControllerWithIdentifier:@"detail"]; //The view I want peek/pop to
NSLog(@"Location: %f,%f", location.x, location.y);
NSLog(@"Index of: %lu", [[self.collectionView indexPathForItemAtPoint:location] row]);
[CEVC setPreferredContentSize:CGSizeMake(0.0, 320.0)];
return CEVC;
}
- (void)previewingContext:(id <UIViewControllerPreviewing>)previewingContext commitViewController:(UIViewController *)viewControllerToCommit {
[self showViewController:viewControllerToCommit sender:self];
}
registerForPreviewingWithDelegate:sourceView:
移动到我创建每个单元格的位置。previewingContext:viewControllerForLocation:
和previewingContext:commitViewController:
移动到单元格视图方法,由于其他原因,这不起作用。我不认为这是预览的问题,因为当我使用UITapGestureRecognizer
实现相同的东西时,我得到了类似的输出:
- (void) processDoubleTap:(UITapGestureRecognizer *)sender {
NSLog(@"Got tapped twice");
if (sender.state == UIGestureRecognizerStateEnded) {
CGPoint point = [sender locationInView:self.collectionView];
NSIndexPath *indexPath = [self.collectionView indexPathForItemAtPoint:point];
NSLog(@"Index was: %lu", [indexPath row]);
if (indexPath) {
NSLog(@"Index was double tapped");
}
}
}
2017-12-25 10:48:13.990523-0800 quickthings[3052:356150] Got tapped twice
2017-12-25 10:48:13.990843-0800 quickthings[3052:356150] Index was: 0
这是发生了什么,这正是我想要的。我唯一想做的事情就是当细胞被轻敲时也能够得到敲击细胞的索引。
(蓝色)UIView
“链接”到集合视图控制器(下面第二个屏幕截图中的顶视图控制器)。
原因:问题的主要原因是如何在故事板中设置CollectionViewController。总之,这些是它的主要问题:
那么为什么这会导致你看到的问题。在您引用self.collectionView时,在CollectionViewController中,您指的是顶级的,而不是显示单元格的那个。那不是显示单元格的那个,实际上没有显示单元格,所以当你在特定点请求单元格时,它总是返回nil,因此你得到的行值为零。如果您能够访问实际显示单元格的UICollectionView,则可以获得正确的值。
除此之外,还有其他问题,你还没有遇到过。
解决方案:这个问题基本上有两个主要解决方案......
我已经尝试过方法2,这是我必须要做的才能让它正常工作:
将CollectionViewController从子类化UICollectionViewController更改为子类化UIViewController,因为它将成为UICollectionView的持有者。您还需要使其直接支持UICollectionViewDataSource和UICollectionViewDelegate,因为UICollectionViewController已经执行此操作,但UIViewController没有。所以在CollectionViewController.m中改变这一行:
@interface CollectionViewController : UICollectionViewController
对此:
@interface CollectionViewController : UIViewController <UICollectionViewDelegate, UICollectionViewDataSource>
在故事板中接下来将CollectionViewController的顶级视图更改回UIView(即删除类属性中的UICollectionView)。它现在只是真正的UICollectionView的持有者。
接下来将故事板中设置的剩余UICollectionView链接到CollectionViewController.h中名为'collectionView'的IBOutlet,以便对self.collectionView的所有引用现在引用正确的东西。
我不得不做的另一件事但我不知道为什么更改UITableViewController和UICollectionViewController的单元格标识符,以便它们不是'Cell'。我刚刚使用了'TableCell'和'CollectionCell'。如果你不这样做,他们都会因为某些原因而感到困惑。
(我认为这就是我所做的一切,但如果不是,我相信你能够处理任何其他问题)
完成所有操作后,self.collectionView将引用正确的内容,您将在- (UIViewController *) previewingContext:(id <UIViewControllerPreviewing>)previewingContext viewControllerForLocation:(CGPoint)location
方法中获得正确的索引路径。
奖金回合:现在一些额外的奖励评论。您似乎也遇到与TableViewController相同的问题,尽管它目前似乎没有引起任何问题。你可能想要解决它。
当我第一次运行项目时,无论如何都无法看到向表中添加任何内容,因为缺少文本字段和“添加”按钮。原来是因为我使用的是iPhone 8模拟器而不是iPhone X模拟器,一旦我切换一切都没问题,我可以看到文本字段和“添加”按钮。这意味着你的界面不能正确地适应不同的设备尺寸(实际上),你应该真正解决这个问题。
Phew的结果比我想象的要长,但希望能解决问题。此外,当我访问git存储库时,我可以克隆它并进行更改。我显然没有提交它们,因为它是你的存储库但是如果你在理解我做了什么以使它工作时有任何麻烦我可以将它们提交到你的主分支或作为一个新的分支。