Недавно у меня было требование изменить картинку ImageView
, чтобы она менялась в зависимости от темы. Я использовал ExpandableListView
и ImageView
в качестве
групповой индикатор, а не нестандартный индикатор группы. Поскольку мое приложение поддерживало как светлую, так и темную тему, я хотел переключить индикаторы группы, значки панели действий на светлые и темные версии.
Вот как:
Объявление пользовательских атрибутов в файле res/values/attrs.xml
для каждого из значков ImageView или ActionBar, которые будут изменены в зависимости от темы:
<declare-styleable name="customAttrs">
<attr name="actionSearchIcon" format="reference" />
<attr name="actionAcceptIcon" format="reference" />
<attr name="actionRefreshIcon" format="reference" />
<attr name="groupIndicatorIcon" format="reference" />
</declare-styleable>
В файле темы, который будет res/values/styles.xml
или подходящим в зависимости от целевой версии, определите те же атрибуты, указывающие на
соответствующие чертежи. Например, ниже тема Black
указывает на элементы рисования, относящиеся к темной теме, а тема Light
указывает на элементы рисования, относящиеся к темной тематике.
<style name="Black" parent="@style/Theme.AppCompat">
<item name="actionSearchIcon">@drawable/ic_action_search</item>
<item name="actionAcceptIcon">@drawable/ic_action_accept</item>
<item name="actionRefreshIcon">@drawable/navigation_refresh</item>
<item name="groupIndicatorIcon">@drawable/group_indicator</item>
</style>
<style name="Light" parent="@style/Theme.AppCompat.Light">
<item name="actionSearchIcon">@drawable/ic_action_search_light</item>
<item name="actionAcceptIcon">@drawable/ic_action_accept_light</item>
<item name="actionRefreshIcon">@drawable/navigation_refresh_light</item>
<item name="groupIndicatorIcon">@drawable/group_indicator_light</item>
</style>
Наконец, переходя к фактическим макетам, указывает относительные атрибуты на атрибуты, которые вы определили, а не непосредственно на элементы рисования. Например,
в случае значков ActionBar:
<item
android:id="@+id/action_refresh"
android:icon="?attr/actionRefreshIcon"
android:orderInCategory="107"
android:title="@string/action_refresh"
app:showAsAction="always"/>
<item
android:id="@+id/action_accept"
android:icon="?attr/actionAcceptIcon"
android:orderInCategory="108"
android:title="@string/action_accept"
app:showAsAction="always"/>
<item
android:id="@+id/action_search"
android:icon="?attr/actionSearchIcon"
android:orderInCategory="50"
android:title="@string/action_search"
app:actionViewClass="android.support.v7.widget.SearchView"
app:showAsAction="collapseActionView|always"/>
Или в случае ImageView:
<ImageView
android:id="@+id/group_indicator"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:contentDescription="@string/app_name"
android:src="?attr/groupIndicatorIcon"/>
Самое интересное, что эту концепцию можно применить к любому элементу управления или любому атрибуту:)