これ簡単に作る方法ありませんかね。
角の丸い背景に色を付けた TextField。
data:image/s3,"s3://crabby-images/cd420/cd4205b46ccb360fd9330ef01691a708d706b36f" alt=""
なんか簡単にできないんですが、
いい方法ありませんか。
🧑💻 やってみる
「角を丸く」
と
「背景色を黄色に」
が同時にできません。
TextField("Search", text: $text)
.frame(width: 200)
.background(.yellow)
TextField("Search", text: $text)
.frame(width: 200)
.textFieldStyle(.roundedBorder)
.background(.yellow) // NG
.backgroundStyle(.yellow) // NG
.tint(.yellow) // NG
data:image/s3,"s3://crabby-images/93848/9384878bee912b632124b6112a6b30d8afe1fbd8" alt=""
👉 roundedBorder | Apple Developer Documentation data:image/s3,"s3://crabby-images/7badd/7badd26063eaa7238c7498c7bacc6c42e9118a0d" alt="hatena-bookmark"
🧑💻 Chain Modifiers
一度、スタイルを plain にして、
padding を付けて、
背景に黄色い角丸四角を置きます。
// chain view modifiers
TextField("Search", text: $text)
.textFieldStyle(.plain)
.padding(6)
.background(.yellow, in: .rect(cornerRadius: 6))
.frame(width: 200)
data:image/s3,"s3://crabby-images/cd420/cd4205b46ccb360fd9330ef01691a708d706b36f" alt=""
しかし、数行続くと View 全体の見通しが悪くなるのがいやだ。
🧑💻 Create TextFieldStyle
TextField 専用のスタイルを作ってそれを適用します。
struct RoundedBordertFieldStyle: TextFieldStyle {
var cornerRadius: CGFloat
var color: Color
func _body(configuration: TextField<Self._Label>) -> some View {
configuration
.textFieldStyle(.plain) // macOS
.padding(cornerRadius)
.background(color, in: .rect(cornerRadius: cornerRadius))
}
}
extension TextFieldStyle where Self == RoundedBordertFieldStyle {
static var roundedBorderYellow: Self {
Self(cornerRadius: 6, color: .yellow)
}
}
TextField("Search", text: $text)
.textFieldStyle(RoundedBordertFieldStyle(cornerRadius: 6, color: .yellow)) // OK
//.textFieldStyle(.roundedBorderYellow) // OK
.frame(width: 200)
data:image/s3,"s3://crabby-images/cd420/cd4205b46ccb360fd9330ef01691a708d706b36f" alt=""
しかし、いちいちここまで書くのがいやだ。
_ (アンダースコア) もなんかいや。
👉 TextFieldStyle Protocol "makeBody" method hidden | Apple Developer Forums data:image/s3,"s3://crabby-images/25518/2551819f98c60e222a13a03db0a21458f3aa3321" alt="hatena-bookmark"
🧑💻 Create View extension
ViewModifier を作ろうかと思ったが、
View の extension まででいいですよね。
extension View {
func roundedBorder(cornerRadius: CGFloat, color: Color) -> some View {
self
.textFieldStyle(.plain)
.padding(cornerRadius)
.background(color, in: .rect(cornerRadius: cornerRadius))
}
}
// create view extension (or view modifier)
TextField("Search", text: $text)
.roundedBorder(cornerRadius: 6, color: .yellow)
.frame(width: 200)
data:image/s3,"s3://crabby-images/cd420/cd4205b46ccb360fd9330ef01691a708d706b36f" alt=""
これぐらいがいいのかな。
🧑💻 Create Child View
新しく View を作って、それに押し込んじゃいます。
struct RoundedBorderTextField: View {
var label: String
@Binding var text: String
var cornerRadius: CGFloat
var color: Color
var body: some View {
TextField(label, text: $text)
.textFieldStyle(.plain)
.padding(cornerRadius)
.background(color, in: .rect(cornerRadius: cornerRadius))
}
}
// create child view
RoundedBorderTextField(label: "Search", text: $text, cornerRadius: 6, color: .yellow)
.frame(width: 200)
data:image/s3,"s3://crabby-images/cd420/cd4205b46ccb360fd9330ef01691a708d706b36f" alt=""
最初からこれで良かったのでは。
🧑💻 まとめ
どれが一番いいんすかね。
macOS に切り替えなが思ったのは、
実際、TextField って、
「フォーカス」とかも
取り扱ってますよね。
それを考えると、
「@State を考慮してるやつ」
のがいいのかもしれません。
👉 【SwiftUI】市松模様を背景にする - Checkered Pattern Background 🏁 data:image/s3,"s3://crabby-images/ab11f/ab11f47e786dbbd9de77594da88fdf71af8ce67b" alt="hatena-bookmark"
👉 【SwiftUI】枠線付き角丸ボタンを簡単に作りたい data:image/s3,"s3://crabby-images/aedb3/aedb30ed5540b54c6a4628c6d2b4f0a857878b9a" alt="hatena-bookmark"