適用于iPad縱向和橫向模式的尺寸等級我基本上希望根據iPad(縱向或橫向)的方向使用xcode 6中引入的大小調整類來定位不同的子視圖。我已經找到了許多教程,解釋了IB在縱向和橫向上如何為Iphone提供不同的大小調整類。但是,似乎沒有任何內容涵蓋IB上的iPad的個人風景或肖像模式。有人可以幫忙嗎?
3 回答

慕蓋茨4494581
TA貢獻1850條經驗 獲得超11個贊
作為RonDiamond的長篇答案的摘要。您需要做的就是在根視圖控制器中。
Objective-C的
- (UITraitCollection *)overrideTraitCollectionForChildViewController:(UIViewController *)childViewController{ if (CGRectGetWidth(self.view.bounds) < CGRectGetHeight(self.view.bounds)) { return [UITraitCollection traitCollectionWithHorizontalSizeClass:UIUserInterfaceSizeClassCompact]; } else { return [UITraitCollection traitCollectionWithHorizontalSizeClass:UIUserInterfaceSizeClassRegular]; }}
迅速:
override func overrideTraitCollectionForChildViewController(childViewController: UIViewController) -> UITraitCollection! { if view.bounds.width < view.bounds.height { return UITraitCollection(horizontalSizeClass: .Compact) } else { return UITraitCollection(horizontalSizeClass: .Regular) } }
然后在storyborad中使用緊湊寬度為縱向和常規寬度為橫向。

蝴蝶不菲
TA貢獻1810條經驗 獲得超4個贊
iPad具有水平和垂直尺寸的“常規”尺寸特性,不區分縱向和橫向。
可以UIViewController
通過方法在自定義子類代碼中覆蓋這些大小特征traitCollection
,例如:
- (UITraitCollection *)traitCollection { // Distinguish portrait and landscape size traits for iPad, similar to iPhone 7 Plus. // Be aware that `traitCollection` documentation advises against overriding it. UITraitCollection *superTraits = [super traitCollection]; if ([[UIDevice currentDevice] userInterfaceIdiom] == UIUserInterfaceIdiomPad) { UITraitCollection *horizontalRegular = [UITraitCollection traitCollectionWithHorizontalSizeClass:UIUserInterfaceSizeClassRegular]; UITraitCollection *verticalRegular = [UITraitCollection traitCollectionWithVerticalSizeClass:UIUserInterfaceSizeClassRegular]; UITraitCollection *regular = [UITraitCollection traitCollectionWithTraitsFromCollections:@[horizontalRegular, verticalRegular]]; if ([superTraits containsTraitsInCollection:regular]) { if (UIInterfaceOrientationIsPortrait([[UIApplication sharedApplication] statusBarOrientation])) { // iPad in portrait orientation UITraitCollection *horizontalCompact = [UITraitCollection traitCollectionWithHorizontalSizeClass:UIUserInterfaceSizeClassCompact]; return [UITraitCollection traitCollectionWithTraitsFromCollections:@[superTraits, horizontalCompact, verticalRegular]]; } else { // iPad in landscape orientation UITraitCollection *verticalCompact = [UITraitCollection traitCollectionWithVerticalSizeClass:UIUserInterfaceSizeClassCompact]; return [UITraitCollection traitCollectionWithTraitsFromCollections:@[superTraits, horizontalRegular, verticalCompact]]; } } } return superTraits;}- (BOOL)prefersStatusBarHidden { // Override to negate this documented special case, and avoid erratic hiding of status bar in conjunction with `traitCollection` override: // For apps linked against iOS 8 or later, this method returns true if the view controller is in a vertically compact environment. return NO;}
這使iPad具有與iPhone 7 Plus相同的尺寸特性。請注意,其他iPhone型號通常具有“緊湊寬度”特征(而不是常規寬度),無論方向如何。
以這種方式模仿iPhone 7 Plus允許該模型在Xcode的Interface Builder中用作iPad的替身,它不知道代碼中的自定義。
請注意,iPad上的分割視圖可能會使用與普通全屏操作不同的大小特征。
這個答案是基于這篇博客文章中采用的方法,并做了一些改進。
更新以修復iPad版本中的間歇性隱藏狀態欄,以及潛在的(更新)特征的踐踏UITraitCollection
。還注意到Apple文檔實際上建議不要覆蓋traitCollection
,因此將來可能會出現這種技術的問題。
- 3 回答
- 0 關注
- 893 瀏覽
添加回答
舉報
0/150
提交
取消