RORK LABEN
MAX — Rork MaxがネイティブSwiftアプリを生成。iPhone・iPad・Watch・TV・Vision Pro・iMessageに対応しますNATIVE — AR/LiDARスキャン、Metalの3Dゲーム、ウィジェット、Live Activities、Core MLまで踏み込めますFUNDING — Rorkがa16zから$2.8Mを調達。月間74.3万訪問・成長率85%と勢いがありますPRICING — 無料で開始でき、有料プランは月額$25から利用できますFLOW — アイデアを英語で説明すると動くコードを生成。共有リンク発行やiOS/Androidビルドに対応しますCOMPARE — 従来のRorkはExpo/React Nativeでクロスプラットフォーム。用途で使い分けられますMAX — Rork MaxがネイティブSwiftアプリを生成。iPhone・iPad・Watch・TV・Vision Pro・iMessageに対応しますNATIVE — AR/LiDARスキャン、Metalの3Dゲーム、ウィジェット、Live Activities、Core MLまで踏み込めますFUNDING — Rorkがa16zから$2.8Mを調達。月間74.3万訪問・成長率85%と勢いがありますPRICING — 無料で開始でき、有料プランは月額$25から利用できますFLOW — アイデアを英語で説明すると動くコードを生成。共有リンク発行やiOS/Androidビルドに対応しますCOMPARE — 従来のRorkはExpo/React Nativeでクロスプラットフォーム。用途で使い分けられます
記事一覧/アプリ開発
アプリ開発/2026-06-27中級

画面を離れてもアニメーションが回り続ける — Rork(Expo)アプリのフォーカス連動でバッテリーを守る

Rork が生成した Expo アプリで、別画面に進んだりホームに戻ったあともグラデーションや呼吸アニメーションが裏で回り続け、ジャンクとして表に出ないままバッテリーを静かに削っていく——その原因は Reanimated の withRepeat が UI スレッドで走り続けることと、ナビゲーションスタックが画面をマウントしたまま保持することにあります。useIsFocused と AppState を束ねたライフサイクル設計で、画面外とバックグラウンドのループを確実に止める実装を、動くコードで示します。

Rork462React Native188Expo115アニメーション8パフォーマンス27

プレミアム記事

癒し系アプリの「呼吸ガイド」を作っていたとき、画面のグラデーションがゆっくり伸縮するアニメーションを入れました。見た目は気に入っていたのですが、ある日ベータ版を一日持ち歩いた帰りに端末がほんのり温かく、バッテリーの内訳を見ると、このアプリが「バックグラウンドのアクティビティ」で妙に上位に来ていたのです。

不思議だったのは、フレーム落ち(ジャンク)としては一切表に出ていなかった点でした。スクロールはなめらかで、体感の不具合はゼロ。けれど呼吸アニメーションは、設定画面に進んでも、ホームに戻ってロックしても、UI スレッドの上で律儀に伸縮を続けていました。見えないところで回り続ける無音のループ——これがバッテリーを削る正体でした。

個人開発でいくつもの壁紙・癒し系アプリを運用してきて学んだのは、アニメーションの「重さ」よりも「いつ止まるか」を設計するほうが、電池持ちには効くということです。ここでは Rork が出力する Expo アプリを題材に、画面外とバックグラウンドのループを確実に止めるライフサイクル設計を共有します。

なぜ画面外でもアニメーションは止まらないのか

直感に反しますが、別画面に進んでもアニメーションは勝手に止まりません。理由は2つあります。

ひとつは、React Navigation のスタックは前の画面をアンマウントせずマウントしたまま残すからです。詳細画面に進んでも、その下のリスト画面は生きていて、そこで withRepeat のループが走っていればそのまま回り続けます。タブナビゲーターはさらに顕著で、タブを切り替えても各タブの画面は基本的にマウントされ続けます。

もうひとつは、Reanimated の withRepeat が UI スレッド(ワークレット)上で自走するからです。JavaScript スレッドのレンダリングが止まっても、UI スレッドのアニメーションは独立して進みます。これは滑らかさのための設計ですが、裏を返すと「JS から見えない場所で走り続ける」ことを意味します。

そして肝心なのは、これがジャンクとして検出されないことです。フレーム落ちは「描画が間に合わない」状態ですが、ここでの問題は「描画が間に合っているのに、見えない画面のために描き続けている」状態です。プロファイラのヒッチ表示には出ず、Energy Log(消費電力)にだけ静かに積み上がります。

アニメ手段ごとの「画面外で止まるか」

止め方を設計する前に、自分のアプリが使っているアニメーション手段が、画面外で自動的に止まるのか・止まらないのかを把握しておくと判断が速くなります。

手段画面外で自動停止止め方
Reanimated withRepeat止まらないcancelAnimation を明示的に呼ぶ
Animated(RN標準)の loop止まらないref を保持して .stop()
Lottie(lottie-react-native)止まらないref の pause() / autoPlay を外す
expo-video / expo-av止まらないplayer の pause()
CSS的な無限ループ(WebView)状況次第WebView の停止か非表示
FlatList セル内のループ仮想化で部分的に停止可視判定で個別制御

要点は、**ほとんどの手段は「自分で止めない限り止まらない」**ということです。FlatList の仮想化だけは画面外セルをアンマウントしてくれますが、ヘッダーやパララックス層は仮想化の外なので例外です。

ここまでお読みいただきありがとうございます。

この記事の続きを読む

この先には、実装コードやベンチマーク結果など、実務でお役に立てる内容をご用意しています。このサイトは広告を掲載しておらず、サーバーや開発にかかる費用はメンバーの皆様のご支援で成り立っています。もしお役に立てていましたら、ご支援いただけますと大変ありがたいです。

この記事で得られること
withRepeat のループや Lottie/動画が画面外でも回り続ける理由を、ナビゲーションスタックのマウント保持と UI スレッド常駐から理解し、useIsFocused と AppState を束ねて確実に止められる
cancelAnimation で値が途中の位置に止まる事故を防ぐリセット手順と、useFocusEffect のクリーンアップで二重起動を起こさない実装パターンを手に入れられる
アニメ手段ごとに『画面外で自動停止するか』を一覧で把握し、呼吸アニメや壁紙プレビューの常時ループだけを狙って止める線引きを設計できる
Stripe による安全な決済 · いつでもキャンセル可能

この記事を購入する

この先の内容をすべてお読みいただけます。一度のご購入で、いつでも何度でもアクセスできます。このサイトは広告を掲載しておらず、皆さまのご支援がサーバー費用などの運営を支えています。

または
メンバーシップなら全記事が読み放題 →
シェア

お読みいただきありがとうございます

Rork Lab は広告なしで運営しており、サーバー費用などの運営コストはメンバーシップのご支援で賄っています。実装コード・ベンチマーク・本番設計パターンなど、実務でお役立ていただける記事を毎日更新しています。もし読んでよかったと感じていただけましたら、ぜひご覧ください。

  • コピー&ペーストで使える実装コード付き
  • 毎日新しい上級ガイドを追加
  • ¥580/月 または ¥1,480 の永久アクセス
メンバーシップを見る →

関連記事

アプリ開発2026-06-27
「本当に削除しますか?」を出す前に — 取り消せる削除という選択肢
リストの項目を消すたびに確認ダイアログを出すと、ユーザーは反射的にOKを押すようになります。Rork(Expo)アプリで「取り消せる削除」を実装し、確認を出すべき場面と出さない場面を切り分ける設計ノートです。
アプリ開発2026-06-27
アラビア語に切り替えても画面が鏡像化されない — Rork(Expo)アプリのRTL対応と再起動の罠
Rork が生成した Expo アプリにアラビア語を足したのに、画面が左右反転せず戻るボタンが逆側に残る——その原因は I18nManager.forceRTL が再起動を要求することにあります。expo-localization での方向判定、Updates.reloadAsync での確実な反映、marginStart への置き換え、矢印だけの鏡像化まで、動くコードで RTL 対応の本番設計を示します。
アプリ開発2026-06-03
壁紙アプリ 6 本のオンボーディングを共通化して、1 ヶ月の初日定着を見た所感
Rork で骨格を作った壁紙アプリ 6 本のオンボーディングを 1 つの設定駆動コンポーネントに統一し、1 ヶ月の初日継続率とプッシュ許諾率がどう動いたかを、個人開発の現場目線で淡々と記録した実運用メモです。
📚RECOMMENDED BOOKS
大規模言語モデル入門
山田育矢
LLM開発
生成AIプロンプトエンジニアリング入門
我妻幸長
プロンプト
Claude CodeによるAI駆動開発入門
平川知秀
AI駆動開発
※ アフィリエイトリンクを含みます
もっと見る →