ios – 在运行时为popover view锚点创建按钮

ios – 在运行时为popover view锚点创建按钮,第1张

概述这可能是不可能的,但我希望有人会有一个想法如何做到这一点。 我有一个应用程序,我从iPhone移植到环球。在iPhone上,我使用Tabbed应用程序。我使用三个选项卡来显示正常数据。我有一个第四个选项卡只有在满足某些条件时才会显示。要添加选项卡,我做: if ([[UIDevice currentDevice] userInterfaceIdiom] == UIUserInterfaceIdio 这可能是不可能的,但我希望有人会有一个想法如何做到这一点。

我有一个应用程序,我从iPhone移植到环球。在iPhone上,我使用Tabbed应用程序。我使用三个选项卡来显示正常数据。我有一个第四个选项卡只有在满足某些条件时才会显示。要添加选项卡,我做:

if ([[UIDevice currentDevice] userInterfaceIdiom] == UIUserInterfaceIdiomPhone) {    UITabbarController *tabController = (UITabbarController *) self.rootVIEwController;    NSMutableArray* newArray = [NSMutableArray arrayWithArray: tabController.vIEwControllers];    [newArray addobject: [theStoryboard instantiateVIEwControllerWithIDentifIEr: @"AdditionalVIEw-Phone"]];    [tabController setVIEwControllers:newArray animated:YES];}

对于iPad,我在初始视图中有足够的空间可以显示iPhone UI中主要三个选项卡中的所有内容。所以我需要的只是“附加”数据的另一个(小)视图。我想使用popOver视图来执行,所以我使用一个导航栏和popover按钮设置初始视图,就像在Utility App模板中一样。但现在我被困了我无法弄清楚如何在运行时创建该popover按钮,并使其正确执行popOver视图。我可以这样添加按钮:

UIbarbuttonItem *flipbutton = [[UIbarbuttonItem alloc] initWithTitle: @"Modem" style: UIbarbuttonItemStylePlain target: self action: @selector(togglePopover:)];self.navbar.topItem.rightbarbuttonItem = flipbutton;

但是我得到一个例外:’NSInternalinconsistencyException’,原因:’UIStoryboardPopoverSegue必须从条形按钮项或视图呈现。我很确定这是因为我没有为popOver segue设置一个锚点。该故事板中不存在该按钮,因此我无法将其设置在该位置。我似乎找不到一个API在运行时设置它。

我还尝试在IB中创建按钮,但不在视图层次结构中,然后将rightbarbuttonItem属性设置为我现有的按钮。这也是有效的,但我仍然无法将该按钮设置为popover视图的锚点。我可以将导航栏设置为锚点,但这会使其锚定到导航栏中的标题,这看起来很愚蠢。

有任何想法吗?

解决方法 我有同样的问题,并通过在视图控制器的故事板中创建一个UIbarbuttonItem而不是视图层次结构的一部分来解决它。

在IB中,将条形按钮项目拖动到视图控制器视图下方的暗条,将其放在“第一响应器”和“视图控制器”图标旁边。为它创建一个(强)IBOutlet。然后通过从栏按钮项目拖到目的地,从中创建一个popover segue到目的地视图控制器。看来这是将其设为锚的唯一方法。选择它作为现有segue的锚点不起作用(看起来像IB错误)。

在vIEwDIDLoad中,您可以将此条按钮项目分配给navigationItem(或任何您喜欢的位置),并且segue按预期工作。

总结

以上是内存溢出为你收集整理的ios – 在运行时为popover view锚点创建按钮全部内容,希望文章能够帮你解决ios – 在运行时为popover view锚点创建按钮所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1086931.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-27
下一篇 2022-05-27

发表评论

登录后才能评论

评论列表(0条)

保存