【Android Studio】contentDescription属性のWarning解消方法
data:image/s3,"s3://crabby-images/eab34/eab343220223b22f1cfc089b4ce53601066beefd" alt=""
この記事では ImageView や ImageButton に表示される contentDescription の Warning 解消法を紹介しています。
ImageView や ImageButton の色が変わっている部分にカーソルを合わせると Missing contentDescription attribute on image と表示されます。
data:image/s3,"s3://crabby-images/64460/64460bdd6496c685b03a78776a26280591bdb05f" alt=""
これは contentDescription 属性がありませんという Warning です。
contentDescription 属性は「ImageView に指定している画像が何を意味するのか、どんな画像なのか」を示すものです。
TalkBack など目が不自由な方が使うユーザー補助機能を有効にしていると、この属性に指定した値が読み上げられる仕組みになっています。
この記事では2つの Warning の解消方法を紹介していますので、プロジェクトに合わせてお試しください。
Warning を消す方法
この Warning を消す方法は
- contentDescription 属性を付ける
- Warning を無視する
の2つがあります。
どちらの方法でも良いですが、画像が重要な意味を持っていたり、テキストコンテンツが多いアプリの場合は contentDescription 属性の使用を検討することをお勧めします。
① contentDescription 属性を付ける方法
ImageView の色が変わっている部分にカーソルを合わせると、左側に豆電球のアイコンが表示されるのでクリックします。
data:image/s3,"s3://crabby-images/cb7bb/cb7bbd49839814381f6d6532a9f068f8cc6f10c6" alt=""
Set contentDesciption を選択します。
data:image/s3,"s3://crabby-images/07ac4/07ac484b96370df7d885f71c7b45093e19168c32" alt=""
android:contentDescription=”” が追加されるので、画像の意味を表す適当な文字列を指定します。
data:image/s3,"s3://crabby-images/e4f79/e4f79d45f394e4f7067f2421227c89b04e6eb801" alt=""
今度は contentDescription の部分に Warning がついてしまいました。
カーソルを合わせてみると Hardcoded string “Icon”, should use “@string” resource と表示されます。
data:image/s3,"s3://crabby-images/9487f/9487f9613158c619fa08f83d4fe40cc19db3b6b2" alt=""
これは「文字列を直接書かずに string リソースを使うべきです」という Warning です。string リソースは strings.xml を指しているので、strings.xml に文字列を定義しましょう。
Android Studio 画面左側のプロジェクト構造から app → res → values → strings.xml を開きます。
data:image/s3,"s3://crabby-images/07543/0754322c09a543301687dfd7da07b1361fd79ff1" alt=""
strings.xml を開いたら文字列を定義します。name 値や文字列はプロジェクトに合わせて変更してください。
<string name="image_desc_icon">Icon</string>
xml ファイルに戻って、以下のように書き換えます。
android:contentDescription="@string/image_desc_icon"
以上で Warning を消すことができます。
data:image/s3,"s3://crabby-images/3a800/3a800fa5bc1a4860a2ae2d7a500af57c7077c2bd" alt=""
② Warning を無視する方法
要素ごとに指定する
ImageView の色が変わっている部分にカーソルを合わせると左側に豆電球のアイコンが表示されるのでクリックします。
data:image/s3,"s3://crabby-images/3e793/3e793e308b6013e733239de28d5deffd59b98788" alt=""
Suppress: Add ignore:tools=”contentDesciption” attribute を選択します。
data:image/s3,"s3://crabby-images/32600/326007d9802573b1580557a5cddb79571e5811e5" alt=""
contentDescription を ignore(無視する)コードが追加され、Warning が消えました。
data:image/s3,"s3://crabby-images/670e4/670e4195029a393d2898f671f684730d495027d0" alt=""
一括指定する
複数の ImageView 要素を使用している場合、全てに tools:ignore=”contentDescription” を書くのが面倒なことがあります。
その場合は、ルート要素に一括指定することもできます。
data:image/s3,"s3://crabby-images/3853d/3853d22f3d464b0fdc7c6ed26f4312dab3141eba" alt=""
まとめ
以上が ImageView を使用した時に出る Warning の解消法でした。
Warning はエラーとは違って、プログラムの動作自体に影響が出るわけではありませんが、全て解消しておいた方がコードがスッキリとして気持ちが良いものです。
Warning が出た場合はお試しください。