我正在使用此方法创建自定义信息窗口 - (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
(绿色)对其没有影响。它仍然具有全屏尺寸
不幸的是,我发现的唯一方法是使用显式框架,这需要手动计算并且根本不要将 Autolayout 与 Google Maps InfoWindow 一起使用。
我做了几个测试来验证相同的 View 如何显示为 UIWindow
的 subview ,并发现行为是不同的。
关于ios - Google map 信息窗口根据内部内容调整大小,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30643740/
欢迎光临 OStack程序员社区-中国程序员成长平台 (https://ostack.cn/) | Powered by Discuz! X3.4 |