スマートフォンやタブレットのアプリは、iPhoneやAndroidのアプリストアに行けば無数に存在します。
それぞれアプリを企業や個人が作成し、アプリストアに申請して販売されていますが、作成する側にも幾つかの選択肢があります。
ネイティブ、Webアプリ、クロスプラットフォーム開発などと呼ばれるものが主な選択肢です。
ネイティブアプリはスマートフォン提供元が公開している、そのスマートフォンとOSのすべての機能を使い切ることができる開発方法です。
iPhoneであればObjective-C、AndroidであればJavaが開発言語になり、またそれぞれ一長一短があります。
この二つの開発言語には互換性がなく、素材などはそのまま使えたとしても、開発部分は別途行わなければなりません。
開発について両対応をネイティブアプリに求めれば開発にかかる費用は二倍になります。
この費用の増大が、スマートフォンアプリ開発を難しくし、ビジネスに規模を求められる要因の一つでしょう。
どんどん規模が大きくなり、商業化したサービス専用アプリや、ゲームのような商業的なアプリが市場を占めるようになります。
Webアプリはスマートフォンには組み込みのWebブラウザがあり、アプリ内から組み込みのWebブラウザを呼び出すことで、Webページをあたかもアプリのように使う方法です。
それであればWebブラウザを利用すればいいとも感じますが、アドレスなどを入力する必要なくアプリを起動すればそのWebサイトをアプリとして利用することができます。
Webブラウザの機能を利用するので、互換性の問題は最も少ないです。現在はブラウザ経由でスマートフォン側のカメラや写真アルバムの内容、画面の向きなど、すべてではありませんが機器情報にアクセスできますのでスマートフォンらしいアプリを作成することができます。
ただWebサーバーにアクセスが集中すると遅くなったり動作しなくなったり、またスマートフォンとしての機能の利用が大幅に制限されるのであくまでWebアプリで十分な場合にしか利用されません。
PhoneGapやCordova、Titaniumなどの開発ツールを利用し、一つのソースコードでiPhoneとAndroidで利用出来るアプリを作成するものです。
Javascriptという汎用性が高く、Web開発でよく利用される言語を利用し、開発ツールがネイティブ言語との橋渡しをします。
Web開発に比べて、開発ツール側が対応すればスマートフォンの様々な機能やセンサを利用することができます。
スマートフォンとしてユーザーが求めている機能はほとんどの場合クロスプラットフォーム開発で実現可能です。
ただネイティブアプリに比べると動作が遅かったり、完全にスマートフォンをコントロールできない部分が実現したいアプリに適切でない場合もあります。
また開発は一つの言語でできても、思う通りに動作するか、エラーが発生しないかというテストはそれぞれの機器でテストしなければいけなく、それぞれ不具合がある場合はソースコードから修正しなければなりません。
テストはソフトウェアの開発で重要な工程ですが、クロスプラットフォーム開発でこの工程までも短縮できるわけではありません
設計や開発の段階で、この三つの方法のどれかを選ぶわけですが、予算や工期が十分に取られている場合はネイティブアプリが選ばれます。やはり動作速度や安定性は利用者が最も優先するところです。
機能が複雑でなく、両対応が求められている場合などはクロスプラットフォーム開発を行うのが最適という場合もあります。
サーバー側で大きな機能をもたせているネットワークサービスで単純なクライアントを求めている場合にも、細かなサーバー側の変更に追従しやすいメリットがあります。
Webアプリについては、ほぼWeb側で機能を実現できている場合や、Webサービス側の機能が頻繁に変更されアプリストアの申請を待つ余裕がない場合などに使い勝手が良いです。
スマートフォンアプリも様々な方法が用意され、発注元や開発者にも最適な選択肢が用意されています。