所以我尝试使用内置的 UITableViewCell 样式 - 特别是 UITableViewCellStyleSubtitle - 带有(单)行 textLabel 但多行 detailTextLabel。但是(自动)计算的单元格高度始终太短,并且似乎忽略了超过 1 行的详细信息。
我已经尝试使用 numberOfLines=0、estimatedRowHeight、UITableViewAutomaticDimension、preferredMaxWidthLayout 等,但在所有排列中,行为 - 实际上对于所有 UITableViewCell 样式 - 是否出现 UITableViewAutomaticDimension 单元格高度计算将正确说明多行 textLabel(耶!),但错误地假定 detailTextlabel 至多是单行(不!)。因此,具有多行 detailTextLabel 的单元格太短,因此单元格内容会溢出单元格的顶部和底部。
我在 GitHub 上发布了一个快速测试应用程序来展示这种行为 here .添加额外的文本行没问题——所有单元格样式都会适当增加高度以适应——但添加额外的细节行不会改变单元格高度,而且会很快导致内容溢出;文本+细节本身布局正确,并且一起正确居中在单元格的中间(所以在这个意义上 layoutSubviews 工作正常),但整体单元格高度本身没有变化。
似乎在 cell.contentView 和标签之间没有实际的顶部和底部约束,而是直接根据(可能是多行的)textLabel 和(仅单行)的高度计算单元格高度line) detailTextLabel,然后所有内容都集中在单元格的中间...同样,多行 textLabel 很好,我在 textLabel 和 detailTextLabel 之间没有做任何不同,但只有前者(正确)调整了单元格高度。
所以我的问题是,是否可以使用内置的 UITableViewCell 样式来可靠地显示多行 detailTextLabels,或者根本不可能,您需要而是创建一个自定义子类? [或者,几乎等同地,无需重写子类中的 layoutSubviews 并手动重新连接所有约束]。
[2016 年 5 月 4 日] 结论:从 iOS9 开始,多行 detailTextLabels 不能像预期的那样与 UITableViewAutomaticDimension 一起工作;单元格总是太短,文本/细节会溢出顶部和底部。您必须自己手动计算正确的单元格高度,或者创建和布局您自己的等效自定义 UITableViewCell 子类,或者(请参阅下面的答案)子类 UITableViewCell 并修复 systemLayoutSizeFittingSize:withHorizontalFittingPriority:verticalFittingPriority: 以返回正确的高度[推荐]
最佳答案
进一步的调查(参见 UITableViewCellTest)表明,当启用 UITableViewAutomaticDimension 时,系统调用 -systemLayoutSizeFittingSize:withHorizontalFittingPriority:verticalFittingPriority: 来计算单元格高度,并且这在其计算中几乎忽略了 detailTextLabel 的高度(错误!?)。因此,对于 UITableViewCellStyleSubtitle,单元格高度总是太短 [单行 detailTextLabel 可能不会完全溢出单元格,但这只是因为现有的顶部和底部边距],并且对于 UITableViewCellStyleValue1 或 UITableViewCellStyleValue2,只要 detailTextLabel 高于(例如更多行),高度就会太短文本标签。这对于没有 detailTextLabel 的 UITableViewCellStyleDefault 来说都是有争议的。
我的解决方案是继承并修复:
- (CGSize)systemLayoutSizeFittingSize:(CGSize)targetSize
withHorizontalFittingPriority:(UILayoutPriority)horizontalFittingPriority
verticalFittingPriority:(UILayoutPriority)verticalFittingPriority
{
// Bug finally fixed in iOS 11
if ([UIDevice.currentDevice.systemVersion compare:@"11" options:NSNumericSearch] != NSOrderedAscending) {
return [super systemLayoutSizeFittingSize:targetSize
withHorizontalFittingPriority:horizontalFittingPriority
verticalFittingPriority:verticalFittingPriority];
}
[self layoutIfNeeded];
CGSize size = [super systemLayoutSizeFittingSize:targetSize
withHorizontalFittingPriority:horizontalFittingPriority
verticalFittingPriority:verticalFittingPriority];
CGFloat detailHeight = CGRectGetHeight(self.detailTextLabel.frame);
if (detailHeight) { // if no detailTextLabel (eg style = Default) then no adjustment necessary
// Determine UITableViewCellStyle by looking at textLabel vs detailTextLabel layout
if (CGRectGetMinX(self.detailTextLabel.frame) > CGRectGetMinX(self.textLabel.frame)) { // style = Value1 or Value2
CGFloat textHeight = CGRectGetHeight(self.textLabel.frame);
// If detailTextLabel taller than textLabel then add difference to cell height
if (detailHeight > textHeight) size.height += detailHeight - textHeight;
} else { // style = Subtitle, so always add subtitle height
size.height += detailHeight;
}
}
return size;
}
在 View Controller 中:
- (void)viewDidLoad {
[super viewDidLoad];
self.tableView.estimatedRowHeight = 44.0;
self.tableView.rowHeight = UITableViewAutomaticDimension;
}
您可以从这里提取完整的子类:MultilineTableViewCell
到目前为止,此修复程序似乎运行良好,并让我成功地在具有动态类型支持的自调整单元格中使用带有多行 文本和详细信息的内置 UITableViewCellStyles。这避免了在 tableView:heightForRowAtIndexPath: 中手动计算所需单元格高度或必须创建自定义单元格布局的麻烦(和困惑)。
[(部分)在 iOS11 中修复]
Apple 终于 修复了 iOS11 中的这个错误(但显然只针对 UITableViewCellStyleSubtitle)。我已经更新了我的解决方案,只对 11 之前的设备应用必要的修正(否则你最终会在单元格的顶部和底部得到额外空间!)。
关于ios - 自动布局在计算 UITableViewCell 高度时忽略多行 detailTextLabel(所有样式),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36587126/
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
我试图获取一个长度在1到10之间的字符串,并输出将字符串分解为大小为1、2或3的连续子字符串的所有可能方式。例如:输入:123456将整数分割成单个字符,然后继续查找组合。该代码将返回以下所有数组。[1,2,3,4,5,6][12,3,4,5,6][1,23,4,5,6][1,2,34,5,6][1,2,3,45,6][1,2,3,4,56][12,34,5,6][12,3,45,6][12,3,4,56][1,23,45,6][1,2,34,56][1,23,4,56][12,34,56][123,4,5,6][1,234,5,6][1,2,345,6][1,2,3,456][123
我有一大串格式化数据(例如JSON),我想使用Psychinruby同时保留格式转储到YAML。基本上,我希望JSON使用literalstyle出现在YAML中:---json:|{"page":1,"results":["item","another"],"total_pages":0}但是,当我使用YAML.dump时,它不使用文字样式。我得到这样的东西:---json:!"{\n\"page\":1,\n\"results\":[\n\"item\",\"another\"\n],\n\"total_pages\":0\n}\n"我如何告诉Psych以想要的样式转储标量?解
我正在为一个项目制作一个简单的shell,我希望像在Bash中一样解析参数字符串。foobar"helloworld"fooz应该变成:["foo","bar","helloworld","fooz"]等等。到目前为止,我一直在使用CSV::parse_line,将列分隔符设置为""和.compact输出。问题是我现在必须选择是要支持单引号还是双引号。CSV不支持超过一个分隔符。Python有一个名为shlex的模块:>>>shlex.split("Test'helloworld'foo")['Test','helloworld','foo']>>>shlex.split('Test"
当我的预订模型通过rake任务在状态机上转换时,我试图找出如何跳过对ActiveRecord对象的特定实例的验证。我想在reservation.close时跳过所有验证!叫做。希望调用reservation.close!(:validate=>false)之类的东西。仅供引用,我们正在使用https://github.com/pluginaweek/state_machine用于状态机。这是我的预订模型的示例。classReservation["requested","negotiating","approved"])}state_machine:initial=>'requested
这可能是个愚蠢的问题。但是,我是一个新手......你怎么能在交互式rubyshell中有多行代码?好像你只能有一条长线。按回车键运行代码。无论如何我可以在不运行代码的情况下跳到下一行吗?再次抱歉,如果这是一个愚蠢的问题。谢谢。 最佳答案 这是一个例子:2.1.2:053>a=1=>12.1.2:054>b=2=>22.1.2:055>a+b=>32.1.2:056>ifa>b#Thecode‘if..."startsthedefinitionoftheconditionalstatement.2.1.2:057?>puts"f
我收到这个错误:RuntimeError(自动加载常量Apps时检测到循环依赖当我使用多线程时。下面是我的代码。为什么会这样?我尝试多线程的原因是因为我正在编写一个HTML抓取应用程序。对Nokogiri::HTML(open())的调用是一个同步阻塞调用,需要1秒才能返回,我有100,000多个页面要访问,所以我试图运行多个线程来解决这个问题。有更好的方法吗?classToolsController0)app.website=array.join(',')putsapp.websiteelseapp.website="NONE"endapp.saveapps=Apps.order("
我有这个html标记:我想得到这个:我如何使用Nokogiri做到这一点? 最佳答案 require'nokogiri'doc=Nokogiri::HTML('')您可以通过xpath删除所有属性:doc.xpath('//@*').remove或者,如果您需要做一些更复杂的事情,有时使用以下方法遍历所有元素会更容易:doc.traversedo|node|node.keys.eachdo|attribute|node.deleteattributeendend 关于ruby-Nokog
我知道我可以指定某些字段来使用pluck查询数据库。ids=Item.where('due_at但是我想知道,是否有一种方法可以指定我想避免从数据库查询的某些字段。某种反拔?posts=Post.where(published:true).do_not_lookup(:enormous_field) 最佳答案 Model#attribute_names应该返回列/属性数组。您可以排除其中一些并传递给pluck或select方法。像这样:posts=Post.where(published:true).select(Post.attr
这里有一个很好的答案解释了如何在Ruby中下载文件而不将其加载到内存中:https://stackoverflow.com/a/29743394/4852737require'open-uri'download=open('http://example.com/image.png')IO.copy_stream(download,'~/image.png')我如何验证下载文件的IO.copy_stream调用是否真的成功——这意味着下载的文件与我打算下载的文件完全相同,而不是下载一半的损坏文件?documentation说IO.copy_stream返回它复制的字节数,但是当我还没有下