この記事は2020年07月24日に投稿しました。
目次
リンク
1. はじめに
こんにちは、iOSのエディタアプリPWEditorの開発者の二俣です。
今回は業務で使用しているAndroidでCheckBoxを使用する方法についてです。
2. AndroidでCheckBoxを使用する
AndroidでCheckBoxを使用するには、以下のような実装になります。
またチェックされた時に呼び出されるリスナーは、CheckBoxに設定します。
実装例
activity_main.xml
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <!-- リンゴのチェックボックスを配置します --> <CheckBox android:id="@+id/appleCheckBox" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="リンゴ"/> <!-- バナナのチェックボックスを配置します --> <CheckBox android:id="@+id/bananaCheckBox" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="バナナ"/> <!-- オレンジのチェックボックスを配置します --> <CheckBox android:id="@+id/orangeCheckBox" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="オレンジ"/> </LinearLayout>
MainActivity.kt
package info.paveway.samplecheckbox import androidx.appcompat.app.AppCompatActivity import android.os.Bundle import android.view.View import android.widget.CheckBox import android.widget.Toast class MainActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) // リンゴのチェックボックスにクリックリスナーを設定します。 val appleCheckBoxListener = AppleCheckBoxListener() val appleCheckBox = findViewById<CheckBox>(R.id.appleCheckBox) appleCheckBox.setOnClickListener(appleCheckBoxListener) // バナナのチェックボックスにクリックリスナーを設定します。 val bananaCheckBoxListener = BananaCheckBoxListener() val bananaCheckBox = findViewById<CheckBox>(R.id.bananaCheckBox) bananaCheckBox.setOnClickListener(bananaCheckBoxListener) // オレンジのチェックボックスにクリックリスナーを設定します。 val orangeCheckBoxListener = OrangeCheckBoxListener() val orangeCheckBox = findViewById<CheckBox>(R.id.orangeCheckBox) orangeCheckBox.setOnClickListener(orangeCheckBoxListener) } // リンゴのチェックボックスがクリックされた時に呼び出されるリスナークラス private inner class AppleCheckBoxListener : View.OnClickListener { override fun onClick(view: View) { val checkBox = view as CheckBox // チェックボックスがチェックされるとtrue、チェックがはずれるとfalseになります。 var state = if (checkBox.isChecked) "オン" else "オフ" Toast.makeText(applicationContext, "リンゴ : " + state, Toast.LENGTH_SHORT).show() } } // バナナのチェックボックスがクリックされた時に呼び出されるリスナークラス private inner class BananaCheckBoxListener : View.OnClickListener { override fun onClick(view: View) { val checkBox = view as CheckBox // チェックボックスがチェックされるとtrue、チェックがはずれるとfalseになります。 var state = if (checkBox.isChecked) "オン" else "オフ" Toast.makeText(applicationContext, "バナナ : " + state, Toast.LENGTH_SHORT).show() } } // オレンジのチェックボックスがクリックされた時に呼び出されるリスナークラス private inner class OrangeCheckBoxListener : View.OnClickListener { override fun onClick(view: View) { val checkBox = view as CheckBox // チェックボックスがチェックされるとtrue、チェックがはずれるとfalseになります。 var state = if (checkBox.isChecked) "オン" else "オフ" Toast.makeText(applicationContext, "オレンジ : " + state, Toast.LENGTH_SHORT).show() } } }
実行結果
API Reference
CheckBoxクラス
3. おわりに
チェックオン/オフのリスナーは、前回
で紹介した、View.OnClickListenerを使用するようです。
リンク
紹介している一部の記事のコードはGitlabで公開しています。
興味のある方は覗いてみてください。
私が勤務しているニューラルでは、主に組み込み系ソフトの開発を行っております。
弊社製品のハイブリッドOS [Bi-OS][Bi-OS]は高い技術力を評価されており、特に制御系や通信系を得意としています。
私自身はiOSモバイルアプリやウィンドウズアプリを得意としております。
ソフトウェア開発に関して相談などございましたら、お気軽にご連絡ください。
また一緒に働きたい技術者の方も随時募集中です。
興味がありましたらご連絡ください。
EMAIL : info-nr@newral.co.jp / m-futamata@newral.co.jp
TEL : 042-523-3663
FAX : 042-540-1688