我正在使用此方法创建自定义信息窗口 - (UIView *)mapViewGMSMapView *)mapView markerInfoWindowGMSMarker *)marker 基于 UIStoryboard 使用自动布局。我预计一些内部 View 会因为接收到实际的文本信息而调整大小,并且信息窗口的最终大小将与 IB 的 View 不同。
实际上,结果是我的 InfoWindow View 尝试全屏显示,没有任何方法可以解决这个问题。使用 autoresizingMask 不会改变任何东西,与设置 Hugging Priority 的结果相同。唯一的方法是设置一个固定的大小约束,我已经为宽度做了这个。但是对于高度,我需要根据内部内容的实际大小动态计算大小。
更新:添加了 Storyboard 的屏幕截图
更新 2:具有 2 个 ScrollView 的示例测试,具有覆盖的方法 intrinsicContentSize :
- (CGSize)intrinsicContentSize {
[self layoutIfNeeded];
return self.contentSize;
}
内部 UIScrollView 通过所有 4 个边附加到基本 ScrollView
内部 UIScrollView 仅附加到顶部和左侧
示例测试 View 层次结构
如您所见,全屏根 UIScrollView (蓝色边框)仍然存在。而内部的UIScrollView (绿色)对其没有影响。它仍然具有全屏尺寸
Best Answer-推荐答案 strong>
不幸的是,我发现的唯一方法是使用显式框架,这需要手动计算并且根本不要将 Autolayout 与 Google Maps InfoWindow 一起使用。
我做了几个测试来验证相同的 View 如何显示为 UIWindow 的 subview ,并发现行为是不同的。
关于ios - Google map 信息窗口根据内部内容调整大小,我们在Stack Overflow上找到一个类似的问题:
https://stackoverflow.com/questions/30643740/
|