はじめに
前回は、アプリ「やるのかやらないのかコイントス」アプリを作りました。コイントスで即決できるようになったでしょうか? 私は決断に迷ったらいつも助けてもらっています。
アプリ作成の第3弾は「愚っ痴る - ここが私の愚痴を吐き出す場所」を作ります。人間生きていれば、愚痴りたい時だってあります。人目を気にせず、思い切って愚痴ることができる場所があればいいなと思ったことはありませんか?今回はそんなあなただけの愚痴る場所を作っていきましょう!
開発環境
この連載では、次の環境を使用しています。
- macOS Sequoia 15.1
- Xcode 16.1
プロジェクトの立ち上げる
今回も前回と同じように、作ったプロジェクトの中に新規ファイルを作成して進めていきます。それでは、Xcodeからプロジェクトを開いて、アプリ作りを進めていきましょう。

アプリ 「愚っ痴る - ここが私の愚痴を吐き出す場所」を作る
ファイルを新規作成
愚っ痴る用のコードを記述するためにファイルを新規作成します。
-
Xcode上部メニューバーから
File
>New
>File from Template…
を選択します。 -
テンプレートを選択する画面が表示されます。①プラットフォームは
iOS
を選択し、User Interface下の②SwiftUI View
を選択、③Next
を押します。 -
保存先を選択する画面では、④のファイル名に
ComplaintView
を入力し、⑤の項目が同様の値になっていることを確認し、⑥Create
を押します。 -
作成が完了すると、Xcodeのナビゲーターエリアに作成した
ComplaintView.swift
ファイルが表示されます。 -
変数
body
のコードを以下のコード[1]に書き換えて下さい。 -
次のようなプレビューが表示されます。
import SwiftUI struct ComplaintView: View { var body: some View { VStack { Text("Good Chill") .font(.system(size: 56)) .fontWeight(.black) .foregroundStyle(.red) Button(action: { // ボタン押下時の処理 }, label: { Text("愚痴る") .font(.largeTitle) }) } } }
Viewを横に並べる
Viewを横に並べるには、HStack
を使用します。すでに学んでいるVStack
と使い方は同じです。Text(“Good Chill”)
を二つのText
に分解して、HStack
を使用して配置してみます。
struct ComplaintView: View { var body: some View { VStack { // ここを変更↓ HStack(spacing: 16) { Text("Good") .font(.system(size: 56)) .fontWeight(.black) .foregroundStyle(.red) Text("Chill") .font(.system(size: 56)) .fontWeight(.black) .foregroundStyle(.red) }
Text
を横並びに配置できました。HStack
でもspacing
に値を設定することで、配置している各要素のスペースを設定することができます。

View内の全ての要素にモディファイアを適用する
HStack(spacing: 16) {
内のモディファイアをみると、.font(.system(size: 56))
や.fontWeight(.black)
など同じモディファイアがそれぞれに記述されているため、コードの整理をしていきます。
次のようにモディファイアをHStack
の}
後ろに移動させます。
struct ComplaintView: View { var body: some View { VStack { // ここを変更↓ HStack(spacing: 16) { Text("Good") Text("Chill") } .font(.system(size: 56)) .fontWeight(.black) .foregroundStyle(.red)
重複したモディファイアは無くなりましたが、プレビューの見た目は変わりません。これはHStack
側にモディファイアを付けることでその中の全要素にもモディファイアの効果が適用されるためです。
ただし、中の要素にすでに別のモディファイアが付いている場合は、外側のモディファイアの効果がその要素に反映されることはありません。実際に、Text("Chill")
に色をつけて確認してみましょう。
struct ComplaintView: View { var body: some View { VStack { HStack(spacing: 16) { Text("Good") Text("Chill") // ここを変更↓ .foregroundStyle(.yellow) } .font(.system(size: 56)) .fontWeight(.black) .foregroundStyle(.red)
プレビューを確認すると、HStack
側のforegroundStyle
は.red
にしていますが、Text("Chill")
につけた.foregroundStyle(.yellow)
の変更も正しく反映されているのが確認できます。

ボタンにスタイルを適用する
愚痴るボタンにスタイルを適用して、よりボタンのような見た目に変更していきます。Button
には.buttonStyle
というモディファイが用意されており、任意のスタイルを設定することで、ボタンの見た目を変更することができます。
次のように.buttonStyle
を設定すると、ボタンにスタイルが適用されます。
Button(action: { // ボタン押下時の処理 }, label: { Text("愚痴る") .font(.largeTitle) }) // ここを追加↓ .buttonStyle(.borderedProminent)
