Open13

KMP「Kotlin Multiplatform」で困ったことまとめ

harutiroharutiro

KMPのプロジェクトの作成する方法

KMPのプロジェクトを作成するときは、Intellijのプラグインに入っているテンプレートを使うと古いため、
https://kmp.jetbrains.com/ を用いて作成すると良い。

Android, iOS以外にもWebやデスクトップ、サーバーも作れる

https://kmp.jetbrains.com/

ComposeMultiplatform

UIライブラリの部分だけは、こっちでも良いかも?

https://terrakok.github.io/Compose-Multiplatform-Wizard/

harutiroharutiro

iOSのデバイスを切り替えたい時は

iOSのデバイス切り替えは、Rub/Debugのコンフィグを変えて行う

harutiroharutiro

Lock file was changed. Run the kotlinUpgradeYarnLock task to actualize lock file (yarnファイルのエラー)

yarnファイルでエラーが出た時の対応

Execution failed for task ':kotlinStoreYarnLock'.
> Lock file was changed. Run the `kotlinUpgradeYarnLock` task to actualize lock file

以下のコマンドを実行して、yarnファイルをアップデートする

 ./gradlew kotlinUpgradeYarnLock
harutiroharutiro

Wasmだと日本語フォントがぶち殺される。

そのためフォントを自分で用意し直す必要がある

以下の記事を見ながらフォントを変える必要がある。

フォントはGoogleIconのフォントでも使うといいと思う

ポイントは、読み込ませたResフォルダに関しては一度ビルドを通さないとClassが再生成されないため、追加したタイミングでBuildを通してからFontの設定をしよう

https://medium.com/@boobalaninfo/integrate-custom-fonts-in-kotlin-compose-multiplatform-bc0f30c0b7e6

harutiroharutiro

[!TIP]
ただし、iOSのようなsafari系のブラウザだと何も表示されないので注意

Wasmで作成したアプリをデプロイしてみる

1. デプロイするためのファイルの作成

案外簡単にできる。
以下の手順を踏んでとりあえずデプロイするためのファイルを作る

https://kotlinlang.org/docs/wasm-get-started.html#generate-artifacts

2. Gitignoreの変更

次に、gitignoreに以下を追加して作成したファイルをgitに含めるようにする。

!*/composeApp/build/dist/wasmJs/productionExecutable/

3. cloudflarePagesでデプロイ

以下のようにデプロイするためのファイルを出力した場所に設定して、コマンドを何も書かなければ、とりあえず、手動でエクスポートして、ファイルをアップロードして、動かしてくれるシステムは完成!!


harutiroharutiro

「Compose for Web でアドレスバーのURLとCompose Navigationのrouteを同期させてみる試み」をCloudflarePagesでやってみる

以下サイトをめっちゃ参考にしています。
https://zenn.dev/tbsten/articles/ecc5d9327a85e9

CloudflarePagesにおいては_worker.jsファイルでのリライト設定を行う
jsで行うので、逆にやりやすいかもしれない。

_worker.js
export default {
  async fetch(request, env, ctx) {
    const url = new URL(request.url);

    // リライトルール: `.js`以外のリクエストを`index.html`にルーティング
    if (!url.pathname.match(/\.js$/)) {
      url.pathname = "/index.html";
      return fetch(url.toString(), request);
    }

    // `.js`ファイルのリクエストはそのまま返す
    return fetch(request);
  }
};

デプロイURL
https://cmp-history-api-sample.pages.dev/

作成したForkのレポジトリ
https://github.com/harutiro/cmp-history-api-sample?tab=readme-ov-file

harutiroharutiro

ありえないぐらいBuildが遅い場合の対策方法

Gradleのキャッシュ機能を使った方がいい

#Gradle
org.gradle.caching=true
org.gradle.configureondemand=true
org.gradle.parallel=true
org.gradle.jvmargs=-Xmx8192M -Dfile.encoding=UTF-8 -Dkotlin.daemon.jvm.options\="-Xmx8192M"
  1. caching: Gradleビルドキャッシュを利用する
  2. configureondemand: 実験的機能。タスクの依存関係にあるプロジェクトのみを実行するのでマルチプロジェクトで効果的
  3. parallel: 並列数をorg.gradle.workers.max(デフォルトはCPU数)に指定
  4. jvmargs: ビルドJVMの起動パラメータ(Xmxはローカル/CIに合わせて)

https://note.com/techbookfest/n/n1f59e37bad56

https://qiita.com/kaakaa_hoe/items/741f44f9c23262abbcca