- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在构建一个具有可变高度自定义表格单元格的 UITableView,它们的高度由包含的多行 UILabel 的大小决定。我已经连接了 tableView:heightForRowAtIndexPath:
委托(delegate)方法,并使用 sizeWithFont:constrainedToSize:
正确计算了最终高度。
我遇到了一个奇怪的问题:当调用数据源方法 tableView:cellForRowAtIndexPath:
时,正确的每行高度已经如上所述确定,但是单元格与该高度不匹配。相反,单元格的 frame.size.height
属性是表格 View 的默认单元格高度(86 像素,正如我在 Interface Builder 中设置的那样,当包含的 UILabel 具有只是一行文本),而不是 tableView:heightForRowAtIndexPath:
为该索引路径确定的正确高度。
我正在使用出列生成 cellForRowAtIndexPath:
中的单元格,也就是说,
// Using storyboards, this never returns nil, no need to check for it
CustomCell *cell = (CustomCell *)[tableView dequeueReusableCellWithIdentifier:@"SomeIdentifier"];
NSLog(@"%f", cell.frame.size.height); // 86, not correct if the cell contains a multi-line UILabel
看来,无论 iOS 在幕后做什么,出列都不会设置单元格的 frame 属性来匹配计算出的高度。这本身并不奇怪,出列本身与单元格实例有关,而不是它们的几何形状。不过,单元格呈现正确,因此高度属性被设置在某处,但它发生在 cellForRowAtIndexPath:
之后。
所以:当我最初填充表格 View 时,所有单元格的 cell.frame.size.height
都是 86,因为当我向下滚动列表时它们第一次出现。由于在第一个 cellForRowAtIndexPath:
之后的某个时间为每一行设置了正确的几何图形,因此当我向上滚动时,高度属性对于在重新使用后返回 View 中的每个单元格都是正确的。
在此之后我可以随意来回滚动表格 View ,从那时起每个单元格的高度属性保持正确。
在任何基于出列的重用发生之前,第一次获得正确单元格高度的正确方法是什么?我需要它来重新定位表格单元格的 subview 。我是否需要在 cellForRowAtIndexPath:
中手动调用 heightForRowAtIndexPath:
,然后手动设置新创建的 CustomCell 实例的框架以匹配该高度?这似乎是多余的,我需要创建一种机制来检测何时使用错误的帧高度首次创建单元格,以及何时使用正确的帧高度将其出队以避免这种冗余。
因此,如果有人能阐明这背后的逻辑,我将不胜感激。
最佳答案
正如 Flexo 所建议的那样,自己回答这个问题显然比对问题进行编辑要好。所以,这是以前的编辑作为答案:
没关系,我应该更好地阅读文档。我可以在 UITableViewDelegate
的 tableView:willDisplayCell:forRowAtIndexPath:
方法中获得正确的框架,因此这是根据设置的正确框架进行 subview 自定义的正确位置,而不是 cellForRowAtIndexPath:
。
不过,有趣的是文档是这样说的:
After the
delegate
returns, the table view sets only thealpha
andframe
properties, and then only when animating rows as they slide in or out.
...因为调用此委托(delegate)方法时正确的框架已经存在。但无论如何,问题解决了。
关于ios - UITableViewCell 框架高度与 tableView 不匹配 :heightForRowAtIndexPath:,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11898596/
我是 Swift 开发新手,正在学习许多在线教程。这些教程中的大多数都引用了 Xcode 上的旧版本,并且代码会导致错误。谁能解释为什么下面的代码会产生“UITableViewCell”?无法转换为
我在我的单元格中使用 AutoLayout,但是,当单元格内有大文本并且单元格展开时,单元格似乎与下面的单元格重叠。图像显示了这是如何重叠单元格的: UITableViewCell:
我的函数接受类型为 (cell: UITableViewCell, item: AnyObject) -> () 的函数作为参数。 我的问题是,当我尝试将具有 UITableViewCell 的子类
我正在尝试做一些相当简单的事情,但我看不到最好的方法。我有一个带有两个单元格的 uitableview,第一个在 contextview 中有一个 uitextfield,输入 View 设置为 ui
我在使用 Swift 时遇到了一些挑战。 我有一个带有原型(prototype)单元的 UITableView。有3个单元格前两个包含用户填写的文本字段。第三个包含一个提交按钮。 非常简单! 我的问题
我是 Objective C 的新手。我有一个问题。 我使用自定义的tableviewcell。我正确地使用 JSON 列出了数据。 我想将点击的数据传递到新 View 的自定义表格 View 。 所
我有两个单元格,比方说我的应用程序中的单元格 A 和单元格 B。它们都有自己的类,class CellA : UITableViewCell 和 class CellB : UITableViewCe
我有一个 UIViewController,它根据屏幕上的所需选项实例化一些 UITableViewCell。这些选项之一是“说明”,我创建了一个 .XIB 文件来在屏幕上显示说明。但是,在此屏幕上,
我正在尝试创建一个 tableview,其中有一个 uitableviewcell(cell1) 的子类,其中包含一个按钮等。当在 cell1 中单击该按钮时,该按钮应该在其正下方添加和删除 uita
在使用 UITableView 编码时,我遇到了这个我无法理解的错误。我的表格有 3 行,每行设置 50 像素,但第二行除外,我将其设置为 500 像素,它填满整个屏幕。当我向下滚动到底部时,问题出现
UITableViewCell 反射(reflect)两种不同的状态:突出显示和选定。 对我来说,它们听起来相同,那么到底有什么区别? 最佳答案 突出显示发生在触地时。 选定发生在触摸时,然后调用di
我刚刚添加了屏幕截图。它是定制单元吗?正如我所见,“ map ”是右对齐的,“1800”是左对齐的。我该如何创建它? 最佳答案 它确实看起来像一个自定义单元格。因为 UITableViewCell 继
我不太了解 tableview 的整体行为: 我有一个带有我在 Storyboard中定义的动态单元格(reuseIdentifier:单元格)的表格 View 。除此之外,我还有两个使用两个 nib
我有一个带有以下代码的 UITableViewCell,其中用户单击 UITableViewCell 上的“保存”按钮。单元格中的图像已保存,“保存”按钮动画消失,但单元格仍然存在。 -(UIT
我有一个UITableView,每个单元格都包含一个UIImageView 和一个UIButton。点击按钮后我启动相机,我正在尝试更新该单元格索引路径中的 UIImageView 。到目前为止,这是
有谁知道如何在进入编辑模式时从分组的 UITableView 中隐藏多个单元格?当退出编辑模式时,我希望这些行以动画效果隐藏,就像在“联系人”应用程序中看到的那样。 如您所知,在联系人编辑模式下,行数
我在 UITableViewCell 中有一个 subview ,其中包含一个 UILabel 和一个 UIButton。当我按下按钮时,它出于某种原因取消选择 UITableViewCell。 有没
我一直在经历在 UItableViewCell 中设置 UIDatePicker 的过程,当选择其上方的 UITableViewCell 时会显示该 UIDatePicker,然后在选择 UITabl
我必须集成从代码中以编程方式生成的 UITableViewCell,如下所示: UITableViewCell *newCell = [[UITableViewCell alloc] initWith
我现在正在学习 iOS 开发中的 UITableView 类,我想在导航到多个 UITableViewCells 的部分中实现点击一个 UITableViewCell,该附件类型用于复选标记,我应该怎
我是一名优秀的程序员,十分优秀!