[Android] Fragment コードで記述する

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

Android Studio 3.1.2
Android 8.1.0

 



Fragment

 
前回はタグ<fragment>を使って簡単にHello Worldを表示させました。

fragment 00 100x100 - [Android] Fragment コードで記述する
FragmentはActivityと共に重要な機能を果たしていますが、いまいちわかりにくところがあります。最初に簡単なHello World...

これと同じようになるようにコードで書いてみます。この方法は自由に、ダイナミックにFragmentを追加、削除ができるので本来の目的に沿ったやり方です。
 

 

FragmentManager

 
Activityが呼び出すレイアウト、activity_mainに前回使った<fragment>の代わりにFrameLayoutなどのViewGroupを使います。
例えばDefaultのConstraintLayoutにViewGroupとしてFrameLayoutを張り付けます。

activity_main.xmml

 
次に、ActvityにFragmentを設定していきます。Fragmentの設定には一連のオペレーションであるトランザクション(フラグメントの追加、削除、置換など)を施します。

    1. FragmentManagerのインスタンス生成
    2. FragmentTransactionのインスタンスを取得
    3. インスタンスに対して張り付け方を指定する
    4. commit()で張り付けを実行する

実際のコードではこのようにします。
 

 
savedInstanceState == null
最初に、BundleのsavedInstanceStateがnull、何もないときだけ設定をするようにします。FragmentはActivityのライフサイクル中に何度でも呼ばれることが可能なので最初だけ設定をするようにします。
 

 
FragmentManager:
FragmentManagerには2つの候補があります。サポートライブラリを使った方がAndroidバージョンが低いものもカバーできますので、基本的にはこちらがいいでしょう。ただし、その分ファイルサイズが大きくなります。

またFragmentManagerは生成されたFragmentのインスタンスの状況を管理して、再度呼ばれると復元してくれます。
getSupportFragmentManager()からこのインスタンスを生成できます。getFragmentManager()というのがありますが、これはandroid.app.FragmentManager用なので間違えないようにしましょう。
 
FragmentTransaction:
追加、削除、置換などのメソッドが用意されています。

Ref: FragmentTransaction
 
Fragmentのレイアウトとクラスは前回と同様です。

fragment 00 100x100 - [Android] Fragment コードで記述する
FragmentはActivityと共に重要な機能を果たしていますが、いまいちわかりにくところがあります。最初に簡単なHello World...
 

サンプルコード

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

 
MainActivityで呼んでいるレイアウト
activity_main.xml

 
Fragmentのクラスです。
TestFragment.java

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

 
リソース
strings.xml

 
これで実行させてみるとこのようになります。
 
fragment 02 - [Android] Fragment コードで記述する
 
 
関連ページ:

 
Ref:
フラグメント | Android Developers

誤字脱字、意味不明で分からにゃイ、
などのご意見はこちらから mailフォーム

ブックマークしておくと便利です このエントリーをはてなブックマークに追加


 


ページのトップへ戻る




シェアする

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

フォローする