8月
7
7
UISegmentedControlのタイトルの位置を変更する方法
data:image/s3,"s3://crabby-images/c4a6a/c4a6ae0f3de7a026cbb354eabb99e245a1005dac" alt="how-to-change-the-position-of-the-title-of-uisegmentedcontrol-01.jpg How to change the position of the title of uisegmentedcontrol 01"
どうも、@takashingsです。
仕事でUISegmentedControlを使うことがあって、
タイトルを設定しようとしたら、タイトルの位置が微妙に中心に来ていないんですよね。
むむむ…ということで、調べたら、調整する方法を見つけたので、紹介したいと思います。
ちなみに何も設定しないままのUISegmentedControlはこちら。
data:image/s3,"s3://crabby-images/5ed09/5ed0922140751510c5217b0a927d3d1b7e288549" alt="how-to-change-the-position-of-the-title-of-uisegmentedcontrol-02.jpg How to change the position of the title of uisegmentedcontrol 02"
AppStoreのランキングの文字、そのまま持ってきました。
すごく細かいですが、若干上に寄っているんですよね。
調整するために使用するのは”setContentOffset:forSegmentAtIndex“というメソッド。
UISegmentedControl *segmentedControl = [[UISegmentedControl alloc] initWithItems:[NSArray arrayWithObjects:@"トップ有料",@"トップ無料",@"トップセールス", nil]]; segmentedControl.selectedSegmentIndex = 0; // ここで調整する [segmentedControl setContentOffset:CGSizeMake(0, 2) forSegmentAtIndex:0];
位置はCGSizeで設定します。
これでUISegmentedControl内のタイトル位置を調整することができます。
上で調整したものがこちら。
data:image/s3,"s3://crabby-images/88c86/88c86c19111152d37a8f589f9e2a7fc6752a14d8" alt="how-to-change-the-position-of-the-title-of-uisegmentedcontrol-03.jpg How to change the position of the title of uisegmentedcontrol 03"
ちゃんと真ん中にタイトルの位置が来ていますね。
data:image/s3,"s3://crabby-images/45e86/45e862f42e30899b16428e08bf6529f2ffcce487" alt="how-to-change-the-position-of-the-title-of-uisegmentedcontrol-04.jpg How to change the position of the title of uisegmentedcontrol 04"
ちなみに、セグメントごとに位置を調整できるようです。
設定次第ではこんなこともできます。
data:image/s3,"s3://crabby-images/5e2ce/5e2ce39548203f8addf6f8da820050b829e16d6b" alt="how-to-change-the-position-of-the-title-of-uisegmentedcontrol-05.jpg How to change the position of the title of uisegmentedcontrol 05"
セグメントごとに位置を変えるということはあまりなさそうですが、こんなこともできるよ、ということで。