像这样开始,我喜欢:
但后来我添加了一个段,这发生了:
宽度是在 IB 中设置的,而不是在代码中。
我所需要的只是一种动态计算宽度的方法。最后,它会做这样的事情:
control.width = (labelWidths + marginWidths);
// where marginWidths = (marginWidth * control.numberOfSegments)
像这样开始,我喜欢:
但后来我添加了一个段,这发生了:
宽度是在 IB 中设置的,而不是在代码中。
我所需要的只是一种动态计算宽度的方法。最后,它会做这样的事情:
control.width = (labelWidths + marginWidths);
// where marginWidths = (marginWidth * control.numberOfSegments)
您可以使用该属性apportionsSegmentWidthsByContent
并将其设置为YES
.
prgrmr 的答案中的方法在这里可以正常工作,但事实并非如此。
我没有使用自定义 UILabel 子视图添加不必要的开销,而是
修改了上面链接中的示例代码以提出以下建议:
- (void)resizeSegmentsToFitTitles:(UISegmentedControl *)control {
CGFloat textWidth = 0; // total width of all text labels
CGFloat marginWidth = 0; // total width of all margins
NSUInteger nSegments = control.subviews.count;
UIView *aSegment = [control.subviews objectAtIndex:0];
UIFont *theFont = nil;
// get font for segment title label
for (UILabel *label in aSegment.subviews) {
if ([label isKindOfClass:[UILabel class]]) {
theFont = label.font;
break;
}
}
// calculate width of text in each segment
for (NSUInteger i = 0; i < nSegments; i++) {
NSString *title = [control titleForSegmentAtIndex:i];
CGFloat width = [title sizeWithFont:theFont].width;
CGFloat margin = 15;
if (width > 200) {
NSString *ellipsis = @"…";
CGFloat width2 = [ellipsis sizeWithFont:theFont].width;
while (width > 200-width2) {
title = [title substringToIndex:title.length-1];
width = [title sizeWithFont:theFont].width;
}
title = [title stringByAppendingString:ellipsis];
}
[control setTitle:title forSegmentAtIndex:i];
textWidth += width;
marginWidth += margin;
}
// resize segments to accomodate text size, evenly split total margin width
for (NSUInteger i = 0; i < nSegments; i++) {
// size for label width plus an equal share of the space
CGFloat textWidth = [[control titleForSegmentAtIndex:i]
sizeWithFont:theFont].width;
// the control leaves a 1 pixel gap between segments if width
// is not an integer value; roundf() fixes this
CGFloat segWidth = roundf(textWidth + (marginWidth / nSegments));
[control setWidth:segWidth forSegmentAtIndex:i];
}
// set control width
[control setFrame:CGRectMake(0, 0, (textWidth + marginWidth), 30)];
}
第一个选项如下所示:
segmentedControl.setWidth(100, forSegmentAt: 0)
segmentedControl.setWidth(50, forSegmentAt: 1)
这为您提供了单独大小的细分,同时坚持您定义的值,这意味着您可以根据需要调整美学。第二个选项如下所示:
segmentedControl.apportionsSegmentWidthsByContent = true
这将完全控制权交给了 iOS,这可能是大多数时候做的最好的事情。
适用于 iOS 5.0
它将调整分段控件的大小以适应每个分段的文本标签中的文本。
override func viewDidLoad() {
super.viewDidLoad()
UILabel.appearance(whenContainedInInstancesOf: [UISegmentedControl.self]).numberOfLines = 0
}