[Android] FragmentをHello Worldから始めるみる

cat65 01 - [Android] FragmentをHello Worldから始めるみる
FragmentはActivityと共に重要な機能を果たしていますが、いまいちわかりにくところがあります。最初に簡単なHello Worldを表示させるところから始めてみましょう。

Android Studio 4.1.1
API 30

R904D.P21641J - [Android] FragmentをHello Worldから始めるみるimpression?a id=2545321&p id=969&pc id=1263&pl id=47128 - [Android] FragmentをHello Worldから始めるみる

Fragment

 
AndroidではActivityは重要な機能を司っていますが、勢いなんでもかんでもActivityに機能を入れてしまって巨大なActivityが出来上がってしまいます。これではメンテナンスがやりにくいコードになってしまい、チームでの開発がより困難になります。
 
Fragmentは「断片」という意味ですが、ActivityのUI部分を肩代わりでき、いくつものFragmentをActivityから開いたり閉じたりできます。
 
また、複数のActivityから使いまわすような再利用も可能です。
 
fragment 01 - [Android] FragmentをHello Worldから始めるみる
 
Activityには以下の役割があります

  • Viewの生成と制御
  • リソースを取得したりするContextのタスク
  • コンポーネントとしてIntentを受け取る

ActivityにはActivityにしか出来ない事を担わせて、View生成と制御の部分はFragmentに任せようということです。
 

 

タグ<fragment>

 
レイアウトに <fragment> タグを使ってHello Worldを表示させます。
ただしこの方法は静的なので拡張性があまりないのですが、Fragmentを理解するためにあえて簡単なところから始めます。
 
<fragment>
MainActivityからsetContentViewで呼び出すレイアウトです。例としてLinearLayoutを使っていますが、他のレイアウトでも可能です。ボタンなどのViewと同じようにタグを設定します。

nameには パッケージ名 + Fragmentクラス名 を入れます。
この例ではパッケージ名:com.example.testfragment
Fragmentクラス名:SampleFragment
なので
com.example.testfragment.SampleFragment
(このままコピペしないように)
 

 
Fragment クラス:
次にFramentを継承したクラスを作成します。
 

 
API29でAndroidXになりandroid.support.v4.app.Fragmentは使わなくなりました。
 
 
onCeateView():
ActivityのようにFragmentにもライフサイクルがありViewを生成するタイミングで呼ばれるのが onCeateView() です。onCreateViewで渡される LayoutInfrater にFragmentのレイアウトをinflate(挿入)して返します。
 
Fragment のレイアウト:
レイアウトにTextViewを入れて定番のHello World(の代わりに”Hello Fragment”)の文字列をリソースから呼びます。
 

 

サンプルコード

 
以上をまとめて、分かりやすいように背景色を設定してみます。

SampleFragment.java
fragment_main.xml
を追加で作成

as4 fragment 01 - [Android] FragmentをHello Worldから始めるみる

MainActivityは特に何も追加しません。
MainActivity.java

 
MainActivityで呼んでいるレイアウト
android:nameには パッケージ名 + Fragmentクラス名 を入れます。

activity_main.xml

 
Fragmentのクラスです。
SampleFragment.java

 
Fragmentが呼んでいるレイアウト
fragment_main.xml

 
リソース
strings.xml

 
これで実行させてみるとこのようになります。
全体のMainActivityの画面の中にある、Hello Fragmentの背景がグレーの矩形範囲がFragmentになります。

 
fragment 02b - [Android] FragmentをHello Worldから始めるみる
 
 
関連ページ:

 
References:
androidx.fragment.app | Android Developers
フラグメント | Android Developers

アプリ開発が上達するお勧め

アプリ開発を始めたけどわからないところがあり、誰かに聞きたいけど周りにはそんな人はいない…あるいは、会社で働いていて日中そんなに時間をとれないなど、オンラインのプログラミングスクールがいいでしょう。

TECH ACADEMY
Androidアプリコース



Code Camp
現役エンジニアによるオンラインプログラミングスクール【CodeCamp】


直接(ネットで)誰か分かる人に聞いた方が早く解決して、上達も早いと思います。



侍エンジニア塾
侍エンジニア塾 無料体験レッスン


とても簡単なことなのに本やネットの画像だけでは分かりにくいことはあります。実際に質問してピンポイントで教えてもらうと、なんだそんなこと、と言うのがけっこうあります。


シェアする

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

フォローする