Is there a way to reduce the spacing between the Action Item Icons on Action Bar?
I wanted to reduce the spacing bettween Action Item icons added to the ActionBar. Is there a way we can do this?
Solution 1:
use a custom android:actionButtonStyle.
<item name="android:actionButtonStyle">@style/ActionButtonStyle</item>
and the magic is here:
<style name="ActionButtonStyle" parent="@android:style/Widget.Holo.Light.ActionButton">
<item name="android:minWidth">0dip</item>
<item name="android:paddingLeft">0dip</item>
<item name="android:paddingRight">0dip</item>
</style>
normaly minWidth is set to 56 dip.
Solution 2:
For SDK versions 17+ you should use paddingStart and paddingEnd properties, if you have minSdkVersion < 17 you must use different styles for each version, like this:
res/values/styles.xml :
<item name="android:actionButtonStyle">@style/ActionButtonStyle</item>
<style name="ActionButtonStyle" parent="@android:style/Widget.Holo.Light.ActionButton">
<item name="android:minWidth">0dip</item>
<item name="android:paddingLeft">0dip</item>
<item name="android:paddingRight">0dip</item>
</style>
res/values-v17/styles.xml :
<item name="android:actionButtonStyle">@style/ActionButtonStyle</item>
<style name="ActionButtonStyle" parent="@android:style/Widget.Holo.Light.ActionButton">
<item name="android:minWidth">0dip</item>
<item name="android:paddingStart">0dip</item>
<item name="android:paddingEnd">0dip</item>
</style>
Solution 3:
Thanks to Shai for his hint, that works pretty well for me (on an Android 4.0.x device): (my whole style.xml)
<resources xmlns:android="http://schemas.android.com/apk/res/android">
<!--
Base application theme, dependent on API level. This theme is replaced
by AppBaseTheme from res/values-vXX/styles.xml on newer devices.
-->
<style name="AppBaseTheme" parent="android:Theme.Light">
<!--
Theme customizations available in newer API levels can go in
res/values-vXX/styles.xml, while customizations related to
backward-compatibility can go here.
-->
</style>
<!-- Application theme. -->
<style name="AppTheme" parent="AppBaseTheme">
<!-- All customizations that are NOT specific to a particular API-level can go here. -->
<item name="android:actionButtonStyle">@style/ActionButtonStyle</item>
</style>
<style name="ActionButtonStyle" parent="@android:style/Widget.Holo.Light.ActionButton">
<item name="android:minWidth">0dip</item>
<item name="android:paddingLeft">0dip</item>
<item name="android:paddingRight">0dip</item>
</style>
Solution 4:
For supporting older version using appCompat you need nothing but this:
In your application's appTheme :
<item name="actionButtonStyle">@style/ActionButtonStyle</item>
and create a style in style.xml
<!--this will reduce space between actionBar Icons-->
<style name="ActionButtonStyle" parent="Widget.AppCompat.ActionButton">
<item name="android:minWidth">0dip</item>
<item name="android:maxWidth">50dip</item>
<item name="android:paddingLeft">0dip</item>
<item name="android:paddingRight">0dip</item>
</style>
That's it. You are done.
Solution 5:
In appTheme add
<item name="actionButtonStyle">@style/CustomActionButtonStyle</item>
and then in style.xml create this style
<style name="CustomActionButtonStyle" parent="Widget.AppCompat.ActionButton">
<item name="android:paddingStart">0dip</item>
<item name="android:paddingEnd">0dip</item>
</style>