Text
Text – SwiftUI | Apple Developer Documentation
font
SwiftUIでは基本的に可変のTextStyleフォントを使うのが一般的のようです。
TextStyleで指定されると端末のフォントサイズによって自動でサイズが調整されます。
SwiftUIで用意されているフォントサイズ
data:image/s3,"s3://crabby-images/63627/6362775010013f444e4ad7b8096496954809b496" alt=""
struct ContentView: View {
var body: some View {
VStack {
Text("largeTitle").font(.largeTitle)
HStack {
Text("title").font(.title)
Text("title2").font(.title2)
Text("title3").font(.title3)
}
Text("headline").font(.headline)
Text("subheadline").font(.subheadline)
Text("body").font(.body)
Text("callout").font(.callout)
Text("footnote").font(.footnote)
HStack {
Text("caption").font(.caption)
Text("caption2").font(.caption2)
}
}
}
}
フォントサイズの固定
data:image/s3,"s3://crabby-images/b1660/b16608f30bd0b6b401859d3b9d8ed100476010f5" alt=""
struct ContentView: View {
var body: some View {
Text("fixed size 16pt").font(.system(size: 16))
}
}
テキストの省略・行数
LineLimit
Textの表示される行数を指定する修飾子です。UIKitとは違いデフォルトは1行ではなく制限無しのようです。
lineLimitに指定された整数以上の行数になる場合は省略されます。
Text("1行省略させる場合").lineLimit(1)
TruncationMode
TruncationModeで省略位置を任意にすることができます,デフォルトはtail
head
data:image/s3,"s3://crabby-images/d7694/d76945107dcea6cfa7e438b06a6865353f8e37ee" alt=""
Text("🐙🐙🐙🐙🐙🐱🐱🐱🐱🐱🐧🐧🐧🐧🐧")
.lineLimit(1)
.truncationMode(.head)
middle
data:image/s3,"s3://crabby-images/e7804/e7804e5343b2cc7a859bc20324de36aad16f7bfc" alt=""
Text("🐙🐙🐙🐙🐙🐱🐱🐱🐱🐱🐧🐧🐧🐧🐧")
.lineLimit(1)
.truncationMode(.middle)
taiil
data:image/s3,"s3://crabby-images/94398/94398e88daf8f190c797d19ec55f7c39df5930d3" alt=""
Text("🐙🐙🐙🐙🐙🐱🐱🐱🐱🐱🐧🐧🐧🐧🐧")
.lineLimit(1)
.truncationMode(.tail)
fixedSize
垂直または水平方向にViewのサイズを固定化させる修飾子です、文字がはみ出すとTextの領域からはみ出します
data:image/s3,"s3://crabby-images/24bcd/24bcdc0209be454544ed2de0fd59423a24aa5296" alt=""
Text("🐙🐙🐙🐙🐙🐱🐱🐱🐱🐱🐧🐧🐧🐧🐧")
.lineLimit(1)
.truncationMode(.head)
.fixedSize()
.frame(width: 200, height: 50, alignment: .center)
Color
foregroundColor
data:image/s3,"s3://crabby-images/5c34e/5c34e6bf83b344e32197349e024b850861f6f859" alt=""
struct ContentView: View {
var body: some View {
HStack {
VStack {
Text("black").foregroundColor(.black)
Text("clear").foregroundColor(.clear)
Text("white").foregroundColor(.white)
Text("gray").foregroundColor(.gray)
Text("red").foregroundColor(.red)
Text("green").foregroundColor(.green)
Text("blue").foregroundColor(.blue)
}
VStack {
Text("orange").foregroundColor(.orange)
Text("yellow").foregroundColor(.yellow)
Text("pink").foregroundColor(.pink)
Text("purple").foregroundColor(.purple)
Text("primary").foregroundColor(.primary)
Text("secondary").foregroundColor(.secondary)
}
}
}
}
background
data:image/s3,"s3://crabby-images/1f943/1f943d6e6d9bfb48120ee211f60d7b6a04b5df06" alt=""
Text("Background Color").background(Color.green)