【Android Studio】ボタンにアイコン画像とテキストを表示する方法
data:image/s3,"s3://crabby-images/82001/82001827714f254de824c3044b77986fe4a3b279" alt=""
この記事ではButton ウィジェットにアイコン画像とテキストを表示する方法 の使い方を紹介します。
Theme.AppCompat の場合
data:image/s3,"s3://crabby-images/c2973/c2973f4121426d209a7f9ff8c5cd8f570dea994b" alt=""
Theme.MaterialComponents の場合
data:image/s3,"s3://crabby-images/a44a3/a44a3839cb58b4ca01bdd2ca8a8c27b27c0efa46" alt=""
画像だけのボタンには ImageButton ウィジェットを使います。
data:image/s3,"s3://crabby-images/b6762/b6762d0bd450128f87f3b2f512c53d75b48195f6" alt="【Android Studio】ボタンに画像を表示する方法 – ImageButtonビュー"
準備
開発環境
Android Studio | 4.2.1 |
---|---|
Android Emulator | Nexus 4 (API 30) |
minSdk | 16 |
targetSdk | 30 |
テーマについて
app → res → values → themes.xml の3行目で設定しているテーマによって、ボタンのデザインが異なります。
data:image/s3,"s3://crabby-images/11888/11888ecdee1aca12d29107906047ab9c9ceb02d3" alt=""
画像について
使うアイコン画像は drawable フォルダに置いています。サイズは縦横 24 dp にしています。
data:image/s3,"s3://crabby-images/9efe2/9efe206e3f75e8df88b7cad05daeb5d470bd926b" alt=""
ボタンの作り方
アイコン画像を左側に表示する
data:image/s3,"s3://crabby-images/d5670/d56703acc570c41be81ec7f713e0b51aa7a2fddc" alt=""
Theme.AppCompat の場合
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="お知らせ"
android:drawableLeft="@drawable/notifications_24"
android:drawableStart="@drawable/notifications_24" />
minSdkVersion を 17 以上にしている場合は drawableLeft は必要ありません。
Theme.MaterialComponents の場合
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="お知らせ"
app:icon="@drawable/notifications_24" />
drawableLeft, drawableStart の代わりに app:icon 属性を使って画像を指定します。
アイコン画像を右側に表示する
data:image/s3,"s3://crabby-images/7f844/7f844c572a4b8fe8d51027fac25760d225f63f5e" alt=""
Theme.AppCompat の場合
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="お知らせ"
android:drawableRight="@drawable/notifications_24"
android:drawableEnd="@drawable/notifications_24" />
minSdkVersion を 17 以上にしている場合は drawableRight は必要ありません。
Theme.MaterialComponents の場合
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="お知らせ"
app:icon="@drawable/notifications_24"
app:iconGravity="end" />
app:iconGravity 属性を使ってアイコン画像を右側に設定しています。
アイコン画像を上に表示する
data:image/s3,"s3://crabby-images/94d42/94d42caad1738be5f0001cfef58b2510ad0aace1" alt=""
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="お知らせ"
android:drawableTop="@drawable/notifications_24" />
アイコン画像を下に表示する
data:image/s3,"s3://crabby-images/a6518/a6518eb7fd9a52a7ca7645aa70420f01d9463783" alt=""
<Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="お知らせ"
android:drawableBottom="@drawable/notifications_24" />