gpt4 book ai didi

ios - 以编程方式更改不同 iPad 屏幕分辨率上的 .xib 大小

转载 作者:行者123 更新时间:2023-11-28 21:28:10 27 4
gpt4 key购买 nike

我在 iPad mini/iPad 4 和 iPad Pro 的 View 中显示 HUD 时遇到问题。它不会像它应该的那样居中。我认为,这是我的 .xib 大小的问题。这取决于模拟指标设置。

我尝试使用模拟指标设置 .xib,

<强>1。 iPad 全屏

我将 .xib 设置为 iPad 全屏,

iPad

如果我以源代码形式打开,它会提供 1024 x 704 分辨率。

<rect key="frame" x="0.0" y="64" width="1024" height="704"/>

然后我在 iPad 上运行它,我的 HUD 就应该居中了。但如果我在 iPad Pro 上运行,我的 HUD 也不会居中。看起来我的 HUD 仍然位于 1024 x 704 的中心。

<强>2。 iPad Pro 全屏

我尝试使用 iPad Pro 全屏设置 .xib

iPad Pro

它给了我 1366 x 960 的分辨率

<rect key="frame" x="0.0" y="64" width="1366" height="960"/>

然后我在 iPad Pro 上运行它,我的 HUD 就应该居中了。但如果我在 iPad 上运行,我的 HUD 也不会居中。看起来我的 HUD 仍然位于 1366 x 960 的中心。

我不认为模拟指标的设置会影响我的 HUD 问题,因为它说 here .我正在使用 JGProgressHUD顺便说一句,这是我如何显示我的 HUD。

HUD = [JGProgressHUD progressHUDWithStyle:JGProgressHUDStyleDark];
HUD.textLabel.text = NSLocalizedString(@"MISC_LOADING_DATA", nil);
[HUD showInView:self.view];

此 HUD 将自动以 self.view 为中心,我认为重要的是我的 .xib 大小。我的问题是,我应该如何设置 .xib 大小以使我的 HUD 在 iPad 和 iPad Pro 上居中?

如有任何帮助,我们将不胜感激。谢谢。

更新

我的问题是 viewDidLoad 上的 self.view.bounds.size 值与某些方法上的 self.view.bounds.size 不同完成处理程序。

- (void)viewDidLoad {
[super viewDidLoad];

// first print
NSLog(@"Height: %f", self.view.bounds.size.height);
NSLog(@"Width: %f", self.view.bounds.size.width);

[self generateData:^(BOOL result) {
if (HUD.superview) {
[HUD dismiss];

// 2nd print on completion handler
NSLog(@"Height: %f", self.view.bounds.size.height);
NSLog(@"Width: %f", self.view.bounds.size.width);
}
}];
}

我在 iPad Pro 上运行。在第一次打印时,它给了我

2016-05-19 16:39:31.529 hr-akses[34013:1535416] Height: 704.000000
2016-05-19 16:39:31.529 hr-akses[34013:1535416] Width: 1024.000000

但是在第二次打印时,它给了我

2016-05-19 16:39:31.607 hr-akses[34013:1535416] Height: 960.000000
2016-05-19 16:39:31.607 hr-akses[34013:1535416] Width: 1366.000000

..

已解决

作为Luke Smith据说,autolayout 很可能没有在 viewDidLoad 完成它的工作。我在 viewWillAppear 上初始化了我的 HUD,它解决了我的问题。

最佳答案

您在这里使用的这个大小设置纯粹是为了 Interface Builder 中编辑屏幕的大小。您的问题不在于此设置,而在于您没有提到的自动布局规则。

例如,尝试这些规则:将它固定在距顶部 4 个像素的位置,并给它一个固定的宽度和高度,您需要这样:

Fix 4 px from top, and fix width and height

然后要修复它,使其始终水平居中,您需要:

Centre item horizontally in container

(请仔细注意方框中的勾号和位置约束上的红色标记 - 那些是在那里创建的)

现在有了这 4 条规则,您的项目始终水平居中,从顶部开始 4,并设置宽度和高度,绝对适用于从 watch 到 iPad Pro 的任何设备。

如果您现在更改模拟指标中的大小设置,是的,IB 屏幕可能会出现一些错误,但相同的规则仍然存在,并且在运行时仍然有效。错误仅与 Interface Builder 中显示的布局有关 - 即,规则规定该项目应该死点,但现在不是。

如果 IB 屏幕仍然显示错误,您可以做的是选择有定位错误的屏幕项目,然后执行以下两项操作之一:Update frames / contraints

更新框架:如果您选择此选项,它会采用规则并应用它们,就好像应用程序正在运行一样。因此,如果规则规定它应该居中,而它当前未在 Interface Builder 中居中,则选择此项将进行居中。

更新约束:如果您选择此项,IB 假定项目的位置是实际正确的(如果它不是居中的)而不是更改项目的位置,而是更改规则本身以适应该位置该项目目前在。

和那些玩一玩,让它深入人心——这些东西真的很方便,而且一直在使用。

关于ios - 以编程方式更改不同 iPad 屏幕分辨率上的 .xib 大小,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37316057/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com