まず、サンプルとして以下のビューを用意した。
struct ContentView: View {
var body: some View {
Text("Hello World")
.font(.title)
}
}
data:image/s3,"s3://crabby-images/074a0/074a0ecfb76f635b9a0c3197990f6a48bbb2dc13" alt=""
このTextビューに対し、以下のような装飾を付ける様々なモディファイアを今回は紹介していく。
data:image/s3,"s3://crabby-images/8aeb2/8aeb252c218e8888dd9a5d26ed72570f4054493a" alt=""
コンテンツ
フォントの太さを変更する
fontWeightモディファイアでは、引数の値に応じてフォントの太さを変更することができる。
struct ContentView: View {
var body: some View {
Text("Hello World")
.font(.title)
.fontWeight(.heavy)
}
}
data:image/s3,"s3://crabby-images/5b14c/5b14cb6fcc033f389943f5ef22cb9f347550e129" alt=""
ここではheavyを指定しているが、他にも以下の値を設定することができる。
- ultraLight
- thin
- light
- regular
- medium
- semibold
- bold
- heavy
- black
文字のカーニングを設定する
kerningモディファイアでは、カーニング(字間調整)を設定することができる。
引数に正の数を指定すると字間を広げ、負の数を指定すると狭くする。
struct ContentView: View {
var body: some View {
Text("Hello World")
.font(.title)
.kerning(10)
}
}
data:image/s3,"s3://crabby-images/827b8/827b89224ae368b620f595d0b4903a96341ef69b" alt=""
文字に下線をつける
underlineモディファイアでは、文字に下線を設定することができる。
struct ContentView: View {
var body: some View {
Text("Hello World")
.font(.title)
.underline()
}
}
data:image/s3,"s3://crabby-images/2d3bd/2d3bd55493042ce8457051282cea7170d909f8a4" alt=""
また、第一引数に下線をつけるかどうかのBool値、第二引数に下線の色を設定することもできる。
.underline(true, color: .red)
data:image/s3,"s3://crabby-images/c9a50/c9a50de8970f8d1c759f0e53501c0b79559538a0" alt=""
文字に取り消し線をつける
strikethroughモディファイアでは、文字に取り消し線をつけることができる。
struct ContentView: View {
var body: some View {
Text("Hello World")
.font(.title)
.strikethrough()
}
}
data:image/s3,"s3://crabby-images/34db9/34db9d42854ed0642d252844183054701627f9ed" alt=""
こちらもunderlineモディファイア同様、第一引数に取り消し線をつけるかどうかのBool値、第二引数に取り消し線の色を設定することもできる。
行間を設定する
lineSpacingモディファイアでは、テキストの行間を設定することができる。
※行間を確認するためframeで横幅サイズを制限している。
struct ContentView: View {
var body: some View {
Text("Hello World")
.font(.title)
.frame(width: 80)
.lineSpacing(30)
}
}
data:image/s3,"s3://crabby-images/2f858/2f858a048f7fe66c5875b2084c737837dbb21622" alt=""
モディファイアを組み合わせる
これらの装飾モディファイアを組み合わせると、以下のような見た目をしたテキストを作ることができる。
struct ContentView: View {
var body: some View {
Text("Hello World")
.font(.title)
.fontWeight(.heavy)
.kerning(10)
.underline()
.strikethrough()
.frame(width: 150)
.lineSpacing(30)
}
}
data:image/s3,"s3://crabby-images/8aeb2/8aeb252c218e8888dd9a5d26ed72570f4054493a" alt=""