为左栏按钮项,右栏按钮项,titleView解释此边距逻辑

|| 谁能告诉我您在以下屏幕快照中看到的边距来自何处?我希望红色,绿色和蓝色矩形在屏幕布局(横向和纵向)中都彼此相邻。相反,我看到了视图之间的莫名其妙的空白。
// Setup Left Bar Button item
UIBlankToolbar* tools = [[[UIBlankToolbar alloc] initWithFrame:CGRectMake(0, 0, 115, 44)] autorelease];
tools.autoresizingMask = UIViewAutoresizingFlexibleWidth;
[tools setBackgroundColor:[UIColor greenColor]];
self.navigationItem.leftBarButtonItem = [[[UIBarButtonItem alloc] initWithCustomView:tools] autorelease];

...

// Setup Right Bar Button Item
UIBlankToolbar* tools = [[[UIBlankToolbar alloc] initWithFrame:CGRectMake(0, 0, 100, 44)] autorelease];
[tools setAutoresizingMask:UIViewAutoresizingFlexibleWidth];
[tools setBackgroundColor:[UIColor redColor]];
self.navigationItem.rightBarButtonItem = [[[UIBarButtonItem alloc] initWithCustomView:tools] autorelease];

...

// Setup Title View
self.navigationItem.titleView = [[[UIView alloc] initWithFrame:CGRectMake(0, 0, 50, 44)] autorelease];
self.navigationItem.titleView.autoresizingMask = UIViewAutoresizingFlexibleWidth;
[self.navigationItem.titleView setBackgroundColor:[UIColor blueColor]];
我用这段代码看到的是: 真正困扰我的是,随着可用空间变小,视图之间的边距变得更大了?我不明白他们为什么在那里,也为什么他们的行为与我对利润的期望背道而驰。 谢谢!     
已邀请:
        导航栏在其强制执行的项目之间具有最小的边距,这就是为什么您不能摆脱边距的原因。 解释您的特定代码也不是很困难:
115+100+50 = 265
,屏幕的宽度为320,因此导航栏有55个像素用作边距。左侧项目左对齐,右侧项目右对齐,中间项目居中。 因此,肖像中的边距非常有意义。 您在景观中看到的是由于您的宽度灵活。您不应在导航栏中的项目上设置灵活的宽度,因此执行此操作时的行为是不确定的,即,错误在于您使用导航栏的方式,而不是导航栏本身。 发生的情况是,首先计算了正确商品的新尺寸。它从100增加到
100+(480-320) = 260
。然后计算出中间项目的大小,看起来它只是占用了所有可用的大小。在计算左项时,实际上会缩小,因为右项和中间项已占用所有空间,因此,在导航栏强制使用边距时,像素将从左项获取。 实际算法可能有所不同。毕竟它是封闭的,我正在尝试解释未定义的行为,但是查看所产生的边距似乎正在发生。 无论如何,您的应用永远都不要依赖未定义的行为,因为未定义的行为可能会在版本之间发生变化并破坏它。您应该做的是创建自己的自定义视图,并将其添加为导航栏的子视图。然后,您将以所需的方式处理视图中的边距。
yourView = [[YourView alloc] initWithFrame:(UIInterfaceOrientationIsPortrait(interfaceOrientation)) ? CGRectMake(0, 0, 320, 44) : CGRectMake(0, 0, 480, 44)];
yourView.autoresizingMask = UIViewAutoresizingFlexibleWidth;
[self.navigationController.navigationBar addSubview:yourView];
    

要回复问题请先登录注册