SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

Android Studio 2で始めるアプリ開発入門

Androidアプリのフラグメント(1) ~一つのAndroidアプリでタブレットとスマホに対応~

Android Studio 2で始めるアプリ開発入門 第9回


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

 Androidアプリを開発するにはAndroid Studioを使います。そのAndroid Studioのメジャーアップデートであるバージョン2.0が正式公開されました。本連載では、最新のAndroid Studio 2系を使い、Androidアプリ開発の基本を解説していきます。前回はAndroidのメニューを扱いました。今回と次回の2回に分けて、1つのアプリでスマホとタブレットの両方に対応できる仕組みであるフラグメントを解説します。

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

本連載の書籍化について(2018年5月追記)

 本連載は、加筆・再構成およびAndroid Studio 3対応を行い、書籍化しています。最新情報については、こちらもぜひ併せてご参照ください。

対象読者

  • Androidアプリ開発未経験な方
  • Java言語は一通り習得済みである方

フラグメント

 今回は、サンプルの作成に入る前に、フラグメントとは何かを説明していきます。

前回までのサンプル

 前回まで使用したサンプルはスマホを前提としたものでした。例えば、第7回で作成した「画面遷移アプリ」(IntentSample)を10インチタブレットで使用すると、以下のような画面になり、非常に使いづらいものになります。

図1 画面遷移アプリを10インチタブレットで起動した画面
図1 画面遷移アプリを10インチタブレットで起動した画面

 大画面タブレットはスマホとは違う画面構成が必要になります。一方で、画面サイズに応じて別のアプリを作成するのは非効率ですし、ユーザビリティも下がります。

 Androidでは1つのアプリで画面サイズに応じてレイアウトを変える仕組みとして、フラグメントというのがあります。フラグメントを利用すると、同一アプリがスマホではリスト画面+注文完了画面の2画面構成となり、10インチタブレットでは、左側にリスト、右側に注文完了、のように1画面で表示させるようにできます。

図2 10インチではリストと完了表示を1画面に収めた状態
図2 10インチではリストと完了表示を1画面に収めた状態

 今回と次回の2回に分けて、IntentSampleをこのように改造しながら、フラグメントの基礎を解説していきます。そのうち今回は、スマホ端末でIntentSampleと同等の動きをフラグメントを使って実現できるところまでコーディングしていきます。次回は、それを10インチで分割表示できるようにします。

フラグメントとは

 さて、図2の画面構成を考えてみましょう。図2では下図のように、左側にリスト表示のブロックが配置され、右側に注文完了表示のブロックが配置されています。

図3 10インチ画面での構成
図3 10インチ画面での構成

 リストブロックは、もともとスマホサイズでは第1画面として表示されていました。一方、注文完了ブロックはスマホサイズでは第2画面として表示されていました。つまり、画面=アクティビティとしては1つでも、その中に独立した画面ブロックが配置された状態です。

 このように、画面の一部を独立したブロックとして扱えるのがフラグメントであり、アクティビティ同様に画面構成を担うxmlファイルと処理を担うJavaクラスのセットで成り立っています。

会員登録無料すると、続きをお読みいただけます

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

次のページ
サンプルプロジェクト作成

この記事は参考になりましたか?

  • X ポスト
  • このエントリーをはてなブックマークに追加
Android Studio 2で始めるアプリ開発入門連載記事一覧

もっと読む

この記事の著者

WINGSプロジェクト 齊藤 新三(サイトウ シンゾウ)

WINGSプロジェクトについて>有限会社 WINGSプロジェクトが運営する、テクニカル執筆コミュニティ(代表 山田祥寛)。主にWeb開発分野の書籍/記事執筆、翻訳、講演等を幅広く手がける。2018年11月時点での登録メンバは55名で、現在も執筆メンバを募集中。興味のある方は、どしどし応募頂きたい。著書記事多数。 RSS X: @WingsPro_info(公式)、@WingsPro_info/wings(メンバーリスト) Facebook <個人紹介>WINGSプロジェクト所属のテクニカルライター。Web系製作会社のシステム部門、SI会社を経てフリーランスとして独立。屋号はSarva(サルヴァ)。HAL大阪の非常勤講師を兼務。

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

山田 祥寛(ヤマダ ヨシヒロ)

静岡県榛原町生まれ。一橋大学経済学部卒業後、NECにてシステム企画業務に携わるが、2003年4月に念願かなってフリーライターに転身。Microsoft MVP for Visual Studio and Development Technologies。執筆コミュニティ「WINGSプロジェクト」代表。主な著書に「独習シリーズ(Java・C#・Python・PHP・Ruby・JSP&サーブレットなど)」「速習シリーズ(ASP.NET Core・Vue.js・React・TypeScript・ECMAScript、Laravelなど)」「改訂3版JavaScript本格入門」「これからはじめるReact実践入門」「はじめてのAndroidアプリ開発 Kotlin編 」他、著書多数

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事は参考になりましたか?

この記事をシェア

  • X ポスト
  • このエントリーをはてなブックマークに追加
CodeZine(コードジン)
https://codezine.jp/article/detail/9595 2018/05/23 15:36

おすすめ

アクセスランキング

アクセスランキング

イベント

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

アクセスランキング

アクセスランキング