【发布时间】:2013-07-04 17:08:32
【问题描述】:
我想沿一条线绘制点。
线条长度取决于设备和方向,并且始终延伸到整个屏幕。因此,对我来说,使用相对百分比值定位点是最有意义的。
到目前为止,我只发现在某种点值中定义了约束 (Doc)
是否也可以使用百分比值作为约束?关于如何以可扩展的方式定位这些点的任何想法......还是我需要“手动”进行这种转换/定位?
【问题讨论】:
标签: ios objective-c uiview autolayout
我想沿一条线绘制点。
线条长度取决于设备和方向,并且始终延伸到整个屏幕。因此,对我来说,使用相对百分比值定位点是最有意义的。
到目前为止,我只发现在某种点值中定义了约束 (Doc)
是否也可以使用百分比值作为约束?关于如何以可扩展的方式定位这些点的任何想法......还是我需要“手动”进行这种转换/定位?
【问题讨论】:
标签: ios objective-c uiview autolayout
是的,您可以将点定位为视图宽度的一小部分。 NSLayoutConstraint 方法,constraintWithItem:attribute:relatedBy:toItem:attribute:multiplier:constant:,有一个 multiplier 参数,可以让你在父视图和它的子视图之间使用分数关系。超级视图的右边缘将是该视图的宽度(如果它是全宽视图,则为屏幕),因此如果您创建如下所示的约束,点将定位在沿线的一小部分距离处:
-(void)viewDidLoad {
[super viewDidLoad];
[self.view removeConstraint:self.leftConDark];
[self.view removeConstraint:self.leftConLight];
NSLayoutConstraint *lcd = [NSLayoutConstraint constraintWithItem:self.darkButton
attribute:NSLayoutAttributeCenterX
relatedBy:NSLayoutRelationEqual
toItem:self.view
attribute:NSLayoutAttributeRight
multiplier:.5
constant:0];
NSLayoutConstraint *lcl = [NSLayoutConstraint constraintWithItem:self.lightButton
attribute:NSLayoutAttributeCenterX
relatedBy:NSLayoutRelationEqual
toItem:self.view
attribute:NSLayoutAttributeRight
multiplier:.9
constant:0];
[self.view addConstraints:@[lcd,lcl]];
}
在此示例中,我定位了两个 UIButton(信息类型为深色和浅色)。我在 IB 中添加了它们,并将 IBOutlets 设置为它们在视图左侧的约束(这就是系统给我的,它可能在右侧 - 没关系,因为你只是删除它们.如果您在代码中制作点,则不需要这样做)。在代码中,我删除了这些约束,然后添加新的约束,使按钮的中心位于屏幕上 50% 和 90% 的位置。
【讨论】:
multiplier 和NSLayoutAttributeRight 的使用(虽然我可能会使用NSLayoutAttributeCenterX 到NSLayoutAttributeRight,但Bernd 无疑明白这一点)。太棒了。
我还不是自动布局专家(甚至还不是有能力的人!)但从 XCode 6 开始,您似乎可以在 IB 中做到这一点。
显示尺寸检查器(单击标尺)
双击约束矩形(不明显!“编辑”会将您带到其他地方)
【讨论】: