1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

LiveViewNative × Swift で ネイティブアプリ作成

Last updated at Posted at 2025-03-31

概要

Elixirでスマートフォンアプリを開発する際に、LiveViewNativeというライブラリを利用することができます。

似たような選択肢としてElixirDesktopがありますが、両者には次のような大きな違いがあります。

  • アプリケーションの実装形式の違い
    • LiveViewNative:ネイティブアプリ
    • ElixirDesktop:WebViewベースのアプリ
  • ページの表示方法の違い
    • LiveViewNative:外部公開されたPhoenixサーバーのページにアクセスして表示
    • ElixirDesktop:ローカルで起動したサーバーのページにアクセスして表示

LiveViewNativeでは、ネイティブクライアントごとに異なるライブラリを使用することで、1つのPhoenixプロジェクトから複数のOS向けモバイルアプリを作成することが可能です。

今回はネイティブクライアントとしてSwiftUIを選択し、iOSアプリを作成していきます。

また記事中の内容は下記のリポジトリで公開しています

環境

本記事の内容はMac環境で検証しています。
使用しているElixirやErlangのバージョンは以下の通りです。

% asdf current
Name            Version         Source                       Installed
elixir          1.18.2-otp-27   /Users/linsei/.tool-versions true
erlang          27.2.2          /Users/linsei/.tool-versions true
nodejs          22.7.0          /Users/linsei/.tool-versions true

手順

LiveViewNativeでは、サーバー側とクライアント側で実装が分かれます。
以下はネイティブクライアントに、SwiftUIを選択した場合になります。

  • サーバー側:Phoenixプロジェクト
  • クライアント側:Xcode(SwiftUI)プロジェクト

それぞれのプロジェクト作成手順については後述しますが、基本的なディレクトリ構成は以下のようになります。

tutorial_lvn % tree -L 1
. ← これがサーバー側
├── ()
└── native
    └── swiftui
        ├── TutorialLvn
        └── TutorialLvn.xcodeproj ← これがクライアント側

このあと、サーバー側・クライアント側に分けて手順を紹介していきます。

サーバー側

サーバー側の実装は、以下の手順で進めていきます。

  1. Phoenixプロジェクトの作成
  2. LiveViewNativeの依存関係の追加
  3. LiveViewNativeのセットアップ

Phoenixプロジェクトの作成

まずはPhoenixプロジェクトを作成します。
今回は将来的にデータベースを使った内容も扱う可能性があるため、Ectoありで生成します。

% mix phx.new tutorial_lvn

LiveViewNativeの依存関係の追加

LiveViewNativeを使用するために、公式リポジトリの手順に従って依存関係を追加します。

mix.exs の deps セクションに以下を追記してください。

mix.exs
  defp deps do
    [
      # LiveViewNative(+Swift)の依存を追加
+      {:live_view_native, "~> 0.4.0-rc.1"},
+      {:live_view_native_stylesheet, "~> 0.4.0-rc.1"},
+      {:live_view_native_swiftui, "~> 0.4.0-rc.1"},
+      {:live_view_native_live_form, "~> 0.4.0-rc.1"}
    ]
  end

LiveViewNativeのセットアップ

依存関係の追加・取得が完了したら、以下のコマンドを順に実行してLiveViewNativeのセットアップを行います。

% mix lvn.setup
To setup your application with LiveView Native run:

> mix lvn.setup.config
> mix lvn.setup.gen

% mix lvn.setup.config
()
Don't forget to run mix lvn.setup.gen

% mix lvn.setup.gen
(略)

これらのコマンドを実行すると、Xcodeプロジェクトが自動生成されます。
ネイティブクライアントにSwiftUIを選択した場合は、この生成されたプロジェクトを編集して開発を進めていきます。

クライアント側

今回はSwiftUIを使用するため、公式リポジトリのSwiftUI向けリポジトリを参考に進めていきます。

クライアント側の実装は、以下の手順で進めます。

  1. クライアントの追加
  2. SwiftUIモジュールの作成
  3. neexファイルへの内容記述
  4. routerexの修正
  5. Xcodeプロジェクトを開く
  6. 接続先サーバーのURLを設定
  7. アプリの起動

クライアントの追加

XcodeプロジェクトにSwiftUIのクライアントを追加するには、以下のコマンドを実行します。

mix lvn.swiftui.gen

ただし、SwiftUIクライアントはサーバー側のセットアップ時に自動生成されているため、通常はこの手順をスキップして問題ありません。

SwiftUIモジュールを作成する

今回は、HomeLive.SwiftUIというSwiftUIモジュールを作成します。
以下のコマンドを実行してください。

% mix lvn.gen.live swiftui Home

このコマンドを実行すると、/liveディレクトリ内に次のファイルが生成されます

  • home_live.swiftui.ex
  • swiftui/home_live.swiftui.neex

続いて、同じディレクトリにhome_live.exを作成し、以下のように記述します。

lib/tutorial_lvn_web/live/home_live.ex
defmodule TutorialLvnWeb.HomeLive do
  use TutorialLvnWeb, :live_view
  use TutorialLvnNative, :live_view
end

最終的な/liveディレクトリの構成は次のようになります。

lib/tutorial_lvn_web/live
├── home_live.ex
├── home_live.swiftui.ex
└── swiftui
    └── home_live.swiftui.neex

neexに内容を記述

画面を表示した際にテキストが表示されるよう、neex ファイルに以下のように記述します。

lib/tutorial_lvn_web/live/swiftui/home_live.swiftui.neex
<Text>Hello, SwiftUI!</Text>

router.exを変更する

/にアクセスした際、SwiftUIクライアントでneexが読み込まれるよう、ルーティングを変更します。

lib/tutorial_lvn_web/router.ex
  scope "/", TutorialLvnWeb do
    pipe_through :browser

-   get "/", PageController, :home
+   live "/", HomeLive
  end

Xcodeでプロジェクトを開く

ここまでの準備が完了したら、Xcodeを起動し、生成されたプロジェクトを開きます。
今回のプロジェクトはnative/swiftui/TutorialLvn.xcodeprojに作成されています。

初回の読み込み時には、Xcode側でビルド設定などの内部処理が走るため、少し時間がかかる場合があります。

この処理には少し時間がかかりますが、以降の手順を進めているうちにちょうど完了することが多いので、焦らず進めていきましょう。

接続先サーバーのURLを指定する

SwiftUIクライアントがPhoenixサーバーへアクセスできるように、接続先URLを設定します。
この作業は以下の2ステップに分かれます

  • Phoenixサーバーを外部からアクセスできるように公開する
  • 公開されたURLをSwiftUIクライアントに設定する

Phoenixサーバーを外部からアクセスできるように公開する

まずは、SwiftUIクライアントがアクセスできるように、Phoenixサーバーを外部公開する準備を行います。
今回は ngrok を使って、ローカルで起動したサーバーを外部に公開します。

# サーバーを起動する
% mix phx.server

# 別ターミナルで ngrok を起動する
% ngrok http 4000
Forwarding   https://bea9-125-13-7-104.ngrok-free.app -> http://localhost:4000

この例ではhttps://bea9-125-13-7-104.ngrok-free.appが外部からアクセス可能なURLになります。
このURLを、後ほどSwiftUIクライアントの接続先として設定します。

公開されたURLをSwiftUIクライアントに設定する

次に、Xcodeプロジェクト内で、外部公開したPhoenixサーバーのURLを指定します。

TutorialLvn/ContentViewファイルを開き、#LiveViewの設定部分を以下のように変更してください

native/swiftui/TutorialLvn/ContentView
        #LiveView(
            .automatic(
-               development: .localhost(path: "/"),
+               development: URL(string: "https://bea9-125-13-7-104.ngrok-free.app")!,
-               production: URL(string: "https://example.com")!
+               production: URL(string: "https://bea9-125-13-7-104.ngrok-free.app")!
            ),
            addons: [
               .liveForm
            ]
        )

この変更により、アプリはngrok経由でPhoenixサーバーに接続し、neexファイルを読み込んで画面を描画できるようになります。

アプリを起動する

ここまでの設定が完了したら、Xcodeでアプリをビルドして実行してみましょう。

実行時にSigning for "TutorialLvn" ...のようなエラーが表示された場合は、 Xcode上部のプロジェクト設定 → Signing & Capabilities タブで、Apple ID に紐づく開発チームを選択してください。

動作確認

iPhone SE(実機)および Apple Watch(エミュレーター)で動作確認を行いました。

iPhone SE(実機)

Apple Watch

まとめ

今回はLiveViewNativeを使ってiOSアプリを作成しました。

ElixirDesktop以外でのスマホアプリ開発手法を試すことで、新たな選択肢を知る良い機会になりました。

また、Apple Watchのエミュレーターでも動作確認を行えたことで、Watchアプリを開発する手法についても触れることができました。

LiveViewNativeの学習を深めていけば、将来的にWatchアプリの開発が決まった時に、さまざまな機能を開発者目線で提案できるようになるかもしれません。

次回は、neex上の要素の操作や、ElixirとSwiftの処理連携について掘り下げ、より実用的な内容を紹介する予定です。

関連

1
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?