質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.33%

  • Android

    6750questions

    Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

  • iOS

    4197questions

    iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

  • Monaca

    1013questions

    「Monaca」はiOS、Android、Windows向けのアプリ開発に対応した、Cordovaベースのモバイルアプリ開発プラットフォームです。HTML5、JavaScriptといったWeb標準技術を用いてモバイルアプリ開発を行うことができます。

  • Cordova

    441questions

    Cordovaは様々なデバイスで使うことができるオープンソースなモバイル用開発プラットフォームです。開発者に各デバイスの元のプラットフォームで開発する必要をなくし、HTML・JavaScript・CSSなどの一般的なウェブのテクノロジーを使ってすべてのデバイスで展開することができるモバイルのアプリケーションを生成することを可能にします。

Monaca cordova-plugin-local-notifications 通知タップ時の処理

受付中

回答 0

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 79

giwagiwagiwa

score 17

Monaca + Ionic を使用してアプリ開発を行っています。
iBeaconの電波を受信して、ローカル通知を表示⇒ローカル通知をタップすると
専用の画面に遷移させるというような機能を実装したいです。

ローカル通知にはcordova-plugin-local-notificationsを使用しています。

通知自体は表示することができるのですが
通知タップ後の画面遷移先の指定方法がわかりません。

通知タップ時には必ずアプリの初期画面が表示されるものなのでしょうか。
初期処理時に通知から起動されたのかを判定して処理を分岐させるのが一般的なのでしょうか。
その判定はMonacaで可能なのでしょうか。
ご存じの方ご教授願えないでしょうか。

cordova.plugins.notification.local.schedule(
          {
            id: 1,
            text: 'クーポンが届いています。',
            sound: null,
            data: {
              test: id
            }
          });
      }

こちらの質問と類似していますが
ローカル通知のプラグイン(cordova-plugin-local-notifications)
でも実現可能なのでしょうか。
https://teratail.com/questions/100237

追記=====================================

devicereadyからcordova.plugins.notification.local.launchDetails
の値を参照すれば通知から起動されたかは判断できるということがわかりました。
ただ、アプリ起動中(バックグラウンド・フォアグラウンド)にローカル通知をタップしてもこの判定は動かないので困っています。。。
アプリが起動していないとiBeaconの電波受信もできずローカル通知自体が来ないです。
通知が来た状態でアプリのプロセスをキルし、通知からアプリ起動すると以下のプログラムで動作しました。

function onLoad() {
        console.log('onLoad');
        window.skipLocalNotificationReady = true;

        document.addEventListener("deviceready", onDeviceReady, false);
    }

  function onDeviceReady() {
      //通知から起動してきたかを判定
      cordova.plugins.notification.local.fireQueuedEvents();
      console.log('launchDetails-notification:'+cordova.plugins.notification.local.launchDetails);
      var launchDetails = cordova.plugins.notification.local.launchDetails
      if(launchDetails){
        $('#LaunchMsg').text('LaunchApp from notification');
        }
}


何か良い方法はないでしょうか。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

まだ回答がついていません

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.33%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る

  • Android

    6750questions

    Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

  • iOS

    4197questions

    iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

  • Monaca

    1013questions

    「Monaca」はiOS、Android、Windows向けのアプリ開発に対応した、Cordovaベースのモバイルアプリ開発プラットフォームです。HTML5、JavaScriptといったWeb標準技術を用いてモバイルアプリ開発を行うことができます。

  • Cordova

    441questions

    Cordovaは様々なデバイスで使うことができるオープンソースなモバイル用開発プラットフォームです。開発者に各デバイスの元のプラットフォームで開発する必要をなくし、HTML・JavaScript・CSSなどの一般的なウェブのテクノロジーを使ってすべてのデバイスで展開することができるモバイルのアプリケーションを生成することを可能にします。