「TAURI」の基礎知識を押さえ、簡単なTAURIアプリ開発を体験してみよう

2023年10月3日(火)
大西 武 (オオニシ タケシ)
第2回の今回は、本連載のテーマであるデスクトップアプリを作れる「TAURI」の概要とインストール方法やビルド、実行方法を解説します。

リリースアプリのビルドとインストーラの作成

デバッグビルドができたので、今度は公開用のリリースビルド方法を解説します。さらに、TAURIでリリースビルドすると「MSI」ファイルのインストーラまで一緒に作成されます。

リリースビルドの際は、必ず「src-tauri」→「tauri.conf.json」ファイルの「identifier」の値をユニークな(一意の)名前に変更してください。例えば、ここでは「com.tauri.hello」に変更してユニークなアプリ識別子に変更しました。

・「src-tauri」→「tauri.conf.json」ファイルでTAURIの設定
"bundle": {
	"active": true,
	"targets": "all",
	"identifier": "com.tauri.hello",
	"icon": [
		"icons/32x32.png",
        "icons/128x128.png",
        "icons/128x128@2x.png",
        "icons/icon.icns",
        "icons/icon.ico"
		]
},

ターミナルで次のコマンドを実行すると、リリースビルドします。「$ cargo tauri dev」と異なり、ビルドが成功しても自動的にアプリは実行されません。

・リリースビルドのコマンド
$ cargo tauri build

リリースビルドに成功したら「src-tauri」→「target」→「release」に実行ファイル「hello.exe」が作成されます。さらに「src-tauri」→「target」→「release」→「bundle」→「msi」にインストーラファイル「hello_0.0.0_x64_en-US.msi」が作成されます(図10)。試しに、この2つのファイルを実行して動作確認をしてみましょう。

図10:アプリの実行ファイルとインストーラのMSIファイル

インストーラファイル作成の設定

「src-tauri」→「tauri.conf.json」はTAURIの設定ファイルです。この中にはインストーラの設定をする項目もあります。インストーラの設定はJSON形式で記述します。

例えば、図11のように「icon」プロパティでアプリアイコンを指定します。「windows」プロパティでWindows向けの設定をしたり「width」プロパティでウィンドウ幅を設定したり、「height」プロパティでウィンドウ高さを設定したりします。

図11:インストーラを作成する際に設定するtauri.conf.jsonファイル

アプリアイコンの作成

アプリアイコンは、必ずオリジナルのものに変更してください。例えば1024x1024ピクセルの画像「src-tauri」→「icons」→「app.png」ファイルを用意して次のコマンドを実行すると、図12のように様々な大きさのアイコンが作成されます。もちろん、Visual Studio Codeで「hello」フォルダーを開いた状態です。

・app.pngファイルからアイコンを作成
$ cargo tauri icon src-tauri/icons/app.png

図12:app.pngファイルから作成されたアイコン

なお、公開する際はアイコンをオリジナルのものに変更したアプリをビルドしてください。おそらく、デフォルトのアイコンには著作権があります。

サンプルプロジェクトのソースコード

最後にサンプルプロジェクトのソースコードを簡単に見ていきましょう。「hello」→「src」フォルダーの「index.html」から「main.js」と「styles.css」を読み込んでWebページをプログラミングおよび装飾します。また「hello」→「src-tauri」→「src」フォルダーのmain.rsでWebページのmain.jsとメッセージを送受信します。

「hello」→「src」→「index.html」ファイル

「link」タグで「styles.css」を読み込みます。スタイルシートはセレクタを装飾します。「script」タグでmain.jsファイルを読み込みます。JavaScriptプログラムはHTMLを制御します。「input」タグには文字を入力でき、[Greet]ボタンを押すと入力した文字の入った文字列がウィンドウに表示されます。

・「hello」→「src」→「index.html」ファイル
<!doctype html>
<html lang="en">
  <head>
(中略)
    <link rel="stylesheet" href="styles.css" />
    <script type="module" src="/main.js" defer></script>
  </head>

  <body>
    <div class="container">
(中略)
      <form class="row" id="greet-form">
        <input id="greet-input" placeholder="Enter a name..." />
        <button type="submit">Greet</button>
      </form>

      <p id="greet-msg"></p>
    </div>
  </body>
</html>

「hello」→「src」→「main.js」ファイル

DOMコンテンツが読み込まれたら、「#greet-form」セレクタの「submit」イベントが発火した際に、「greet」関数でmain.rsのgreet関数を呼び出し、返ってきた文字列を「#greet-msg」セレクタに表示する、というコードを書いています。

・「hello」→「src」→「main.js」ファイル
const { invoke } = window.__TAURI__.tauri;

let greetInputEl;
let greetMsgEl;

async function greet() {
  greetMsgEl.textContent = await invoke("greet", { name: greetInputEl.value });
}

window.addEventListener("DOMContentLoaded", () => {
  greetInputEl = document.querySelector("#greet-input");
  greetMsgEl = document.querySelector("#greet-msg");
  document.querySelector("#greet-form").addEventListener("submit", (e) => {
    e.preventDefault();
    greet();
  });
});

「hello」→「src」→「styles.css」ファイル

スタイルシートで各セレクタに装飾を施します。ここでは「index.html」から読み込まれたセレクタを装飾します。

・「hello」→「src」→「styles.css」ファイル
:root {
  font-family: Inter, Avenir, Helvetica, Arial, sans-serif;
  font-size: 16px;
  line-height: 24px;
  font-weight: 400;

  color: #0f0f0f;
  background-color: #f6f6f6;

  font-synthesis: none;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
}
(後略)

「hello」→「src-tauri」→「src」→「main.rs」ファイル

main.jsのgreet関数から「greet」メッセージと入力した名前が送られてきたら「Hello, {}! You've been greeted from Rust!」の「{}」にその名前を挿入した文字列を、再びmain.jsのgreet関数に返します。

JavaScriptとRustのメッセージのやり取りは、今後も解説する機会が数多くあるので、今回は簡単に解説しました。

・「hello」→「src-tauri」→「src」→「main.rs」ファイル
#![cfg_attr(not(debug_assertions), windows_subsystem = "windows")]

#[tauri::command]
fn greet(name: &str) -> String {
    format!("Hello, {}! You've been greeted from Rust!", name)
}

fn main() {
    tauri::Builder::default()
        .invoke_handler(tauri::generate_handler![greet])
        .run(tauri::generate_context!())
        .expect("error while running tauri application");
}

おわりに

今回は、TAURIの基礎知識と、Webページからデスクトップアプリを作成する手順を解説しました。デバッグビルドで開発して、リリースビルドで公開用の実行ファイルとインストーラファイルを作成しました。

今回のサンプルは、[Greet]ボタンを押すとWebページで入力した名前をRustで挿入し、「ハロー、(名前)! あなたはRustから挨拶されました!」という意味の文字列を、再びWebページで表示するものです。みなさんの環境でも、このサンプルのデスクトップアプリの動作を体験できたでしょうか。ぜひ、実際に試してみてください。

著者
大西 武 (オオニシ タケシ)
1975年香川県生まれ。大阪大学経済学部経営学科中退。プログラミング入門書など30冊以上を商業出版する作家。Microsoftで大賞やNTTドコモでグランプリなど20回以上全国区のコンテストに入賞するアーティスト。オリジナルの間違い探し「3Dクイズ」が全国放送のTVで約10回出題。
https://profile.vixar.jp

連載バックナンバー

開発言語技術解説
第15回

「TAURI」でデータベースを使ってみよう

2024/5/10
第15回の今回は「TAURI」でオープンソースのデータベース「SQLite3」を使用して、テーブル表に表示する解説をしていきます。
開発言語技術解説
第14回

「TAURI」で気象庁の「CSVデータ」を解析する

2024/5/1
第14回の今回は気象庁のWebサイトから指定した地域の1年間の気象データをダウンロードして「TAURI」で解析していきます。
開発言語技術解説
第13回

「TAURI」で「簡易RSSリーダー」を開発してみよう

2024/4/16
第13回の今回は「TAURI」で「RSSフィード」を読み込んでWebページに一覧表示し、リンクのページを開くための新規ウィンドウを作成するところまでを解説します。

Think ITメルマガ会員登録受付中

Think ITでは、技術情報が詰まったメールマガジン「Think IT Weekly」の配信サービスを提供しています。メルマガ会員登録を済ませれば、メルマガだけでなく、さまざまな限定特典を入手できるようになります。

Think ITメルマガ会員のサービス内容を見る

他にもこの記事が読まれています