Webページからアプリを起動しよう

  • このエントリーをはてなブックマークに追加

株式会社8bitでは「ノミトモ」「Grmo」などのWebサービスを運営していますが、近年はスマホアプリへの対応も行っています。

その際、Webからアプリを起動させたい時があると思います。

具体的には「メールアドレスの有効性チェックを行い、URLを叩くとWebページにアクセスして
アプリを起動」など・・・

AndroidやiOS両方とも比較的低コストで導入できるので、特にWebサービスと連動するアプリの場合は導入していきたいですね。

Androidの場合

Androidでは「カスタムURLスキーム」と呼ばれる方法で呼び出すことが可能です。

 

アプリ側の設定

[android:name=”Web2AppActivity”]ですが、この名前はなんでもいいです。
わかりやすい名前にしてください。

[android:scheme=”hogehoge-scheme”]とありますが、”hogehoge-scheme”が
アプリを認識させるカスタムURLスキームとなります。

基本的になんでも良いですが、わかりやすく簡潔かつ他のアプリと被らないようにしてください。

AndroidStudioからActivityを新規作成して、onCreateの中にこの記述を入れてください。
詳しくはHTML記述部分で説明しますがURLになる部分の出し分けで、受け取ったアプリの処理を
変えるようにしています。

HTML側の設定(呼び出す側)

通常のURLリンクと同じように記述します。

違うのは「http://~」ではなく先ほどアプリ側で設定したカスタムURLスキームから始まります。

後ろの[host/main]ですがこちらはアプリ側で処理を分けるための引数代わりに使っていますので
用途によって色々と変更してください。

なお、JavaScript上でもアプリを呼び出すことは可能ですが、PCから呼び出した場合は
存在しないプロトコルとなり、アプリを呼び出すことは不可能ですのでご注意ください。

 

iOSの場合

iOSの場合もカスタムURLスキームを使いますが、少し記述方法が異なります。

 

アプリ側の設定

Xcodeを起動し、info.plistに[URL Types]をArrayで追加しその中に[URL identifire]と
[URL Schemes]を追加します。
  • URL identifire ・・・ アプリ識別のための文字列(ユニーク)
  • URL Schemes ・・・ スキーマの文字列(例:hogehoge-scheme)

 

受け取った後の処理はAppDelegate.swiftに記述しておきます。

Androidと同じようにURLの引数によって処理を分けるようにしています。

HTML側の設定(呼び出す側)

Androidとほぼ同じように記述します。

Androidとは違うのは[host/main]ではなく[host/?main]となっているところです。
多分Androidと同じ記述でもできるのでしょうが・・・
まぁ単純にアプリを呼び出すだけだと同じURLでも良いと思います。

 

最後に・・・

今回は制作したアプリを起動する方法として記述しましたが、カスタムURLスキームの値を知っていれば、他のアプリを起動することも可能です。

ただ、Webサービス利用者からすると突然アプリが起動することに驚くかもしれないので
アプリを起動するときはそのあたりをしっかりと明示する必要があるかなと思います。

 

執筆者:松本[ エンジニア ]

関連記事

マークアップ

CSSを使わないSVGアニメーションの作り方【キーフレームアニメーション編】

SVG画像をアニメーションさせる時は、CSSを使用するのが一般的かと思いますが、SVGファイルに直接記述してアニメーションさせることもできます。 SMILという名前の、SVGのアニメーション機能です。IEでは使用できなかったため、使いづらかったのですが、今後は気後れすることなく使用できます。 SMILにはざっくり3種類のアニメーションがありますが、複雑なのでまずは簡単なキーフレームアニメーションから、早速試してみましょう。 目次1 静止画のSVG2 基本のアニメーション2.1 […]

スマホアプリ

【Android Studio】Androidアプリでラジオボタンの『選択時』『非選択時』のボタンの背景色と文字色を変える

Androidアプリでラジオボタンを通常のボタンのようにして、かつ『選択時』『非選択時』のボタンを変えたい…ということがあるかと思います。 そんな時はdrawableに要素を用意して、背景色や文字色に指定するだけで簡単に変更することができます。 目次1 ラジオボタンを設置2 背景色を設定3 文字色を設定 ラジオボタンを設置 それではプロジェクトを開きましょう。 とりあえずはラジオボタンを2つ設置しました。 今回はボタンぽくしたいのでラジオボタンのデフォルト要素をクリアします。 […]

マークアップ

祝解禁!IEがなくなって使えるようになった便利なCSS 8選

2022年6月16日、IEのサポートが切れました。フロントのエンジニアにとっての念願が叶った、記念すべき日です。IE6の頃から苦しめられてきた私ももちろんのこと浮かれています。 ただ、IEを除外することによって使用できるCSSが大幅に増え、勉強しなければならないこともまた増えました。少しずつ慣れていきましょう。 今日は使用できるようになったCSSで、頻度が高そうなものからいくつかご紹介したいと思います。 目次1 object-fit1.1 今まで1.2 これから2 filte […]

株式会社8bit (エイトビット)

東京都目黒区でWebサイト制作、Webシステム開発などを行っております。
コーポレートサイトやWebサービスの企画・提案を得意としており、自社での経験を元にアイデアをカタチにするお手伝いをさせていただいております。

Web制作に関するご相談はお気軽にどうぞ

弊社に制作をご依頼いただく際の費用感をご確認いただける、
見積りシミュレーションをご用意いたしました。