私が好きなこのように始まります:
しかし、セグメントを追加すると、これが発生します
。幅は、コードではなく 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)];
}
各セグメントのテキスト ラベルにテキストが収まるように、セグメント化されたコントロールのサイズが調整されます。
override func viewDidLoad() {
super.viewDidLoad()
UILabel.appearance(whenContainedInInstancesOf: [UISegmentedControl.self]).numberOfLines = 0
}