[Android & Kotlin] Buttonをコードだけで記述する

レイアウトを コードだけで記述 することが必要な場合があります。ダイナミックにUIを変更したいケースなどです。

Android Studio
2021.1.1




Button

 
レイアウトは他にもありますが、まずLinearLayoutのケースで基本的な設定を確認してみたいと思います。
 

 

 

setContentView

 
setContentView はその名の通り、スクリーン画面にViewを設定するメソッドです。設定されるViewはいくつかあるLayout形式の一つでまとめられたViewグループになります。
 
1x1.trans - [Android & Kotlin] Buttonをコードだけで記述する

setContentView のメソッドは引数の取り方でいくつかあります

  1. setContentView(int layoutResID)
    • レイアウトXMLファイルのIDを指定
  2. setContentView(View view)
    • 簡略形です。今回はこれを使います
  3. setContentView(View view, ViewGroup.LayoutParams params)

Ref: setContentView
 
1. の例では activity_main.xml を設定しています
 


 
このactivity_main.xmlの設定は静的、staticなものでアプリ起動中に簡単に変更することはできません。レイアウトを動的、dynamicに変化させたい場合は上の 2. を使います。
 

 

LinearLayoutのケース

 
ButtonをタップするとTextViewの表示を変える簡単な例

https://akira-watson.com/android/kotlin/button-sample.html

これはレイアウトファイル xml で作成しました。
これをコードで書くとこのようになります。Buttonのインスタンス生成は、
 


 
レイアウトファイルに記述していた箇所をコードで書きますが、今回はデフォルトのConstrraintlayoutではなく昔からある LinieaLayout でやってみます。(記述が簡単なので)
 


 
レイアウトXMLファイルを使わないので、その他にButtonやTextViewのレイアウトも設定します。
 
クリックリスナーは変わりません

 

サンプルコード

 
まとめるとこのようになります。
MainActivity.kt


 
リソースファイルは必要です。
res\values\strings.xml


 
1x1.trans - [Android & Kotlin] Buttonをコードだけで記述する

 

 
LinearLayoutはこのようにできましたが、他のレイアウトも同様にできます。
 
 
関連ページ:
Javaの場合

https://akira-watson.com/android/button-hardcoding.html

レイアウトファイルを使った場合

https://akira-watson.com/android/kotlin/button-sample.html

 
References:
LinearLayout | Android Developers
Button | Android Developers
レイアウト | Android Developers

シェアする

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

フォローする