我想只更改操作栏中的一个菜单项。我尝试更改相同的图标颜色,而不是将其透明为所需的颜色,但边缘显示操作栏的背景。
这是我的操作栏的样子:
https://www.dropbox.com/s/1sjnk975dnj17kr/before.png?dl=0
这是我想达到的目标:
https://www.dropbox.com/s/ul7hh2gxtfox1pk/goal.png?dl=0
以下是我的xml文件:
menu_main.xml
<item
android:id= "@+id/location"
android:icon="@drawable/ic_room_white_48dp"
android:title=""
android:orderInCategory="2"
app:showAsAction="always"/>
<item
android:id= "@+id/report"
android:icon="@drawable/report"
android:title=""
android:orderInCategory="3"
app:showAsAction="always"/>
<item
android:id= "@+id/message"
android:icon="@drawable/ic_comment_white_48dp"
android:title=""
android:orderInCategory="4"
app:showAsAction="always"/>
styles.xml
<style name="AppTheme" parent="AppTheme.Base"/>
<style name="AppTheme.Base" parent="Theme.AppCompat.Light">
<item name="colorPrimary">#B9ACC1</item>
<item name="colorPrimaryDark">#827689</item>
<item name="colorAccent">#827689</item>
<item name="android:actionButtonStyle">@style/MyActionButtonStyle</item>
</style>
<style name="MyActionButtonStyle" parent="@android:style/Widget.Holo.Light.ActionButton">
<item name="android:padding">15dip</item>
</style>
答案 0 :(得分:1)
更新1: 添加一种避免xml和代码重复的方法。
更新2: 添加静态侦听器。
我不知道您是否可以通过更改menu.xml来实现目标,但工具栏是一个viewGroup,因此您可以使用view.xml实现您的目标:
toolbar.xml:
<LinearLayout
android:layout_width="?attr/actionBarSize"
android:layout_height="match_parent"
android:layout_marginRight="8dp"
android:background="#000000">
<Button
android:id="@+id/button_first"
android:layout_width="?attr/actionBarSize"
android:layout_height="match_parent"
android:background="@android:drawable/ic_lock_idle_lock" />
</LinearLayout>
<LinearLayout
android:layout_width="?attr/actionBarSize"
android:layout_height="match_parent"
android:layout_marginRight="8dp"
android:background="#000000">
<Button
android:id="@+id/button_second"
android:layout_width="?attr/actionBarSize"
android:layout_height="match_parent"
android:background="@android:drawable/ic_lock_idle_lock" />
</LinearLayout>
</android.support.v7.widget.Toolbar>
在您的所有xml上添加此代码可能会很无聊所以我建议您使用这样的<include />
属性:
main.xml中
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<include
android:id="@+id/toolbar"
layout="@layout/toolbar"/>
</RelativeLayout>
然后,您只需设置工具栏并使用按钮
MainActivity.java
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
final Button buttonFirst = (Button) findViewById(R.id.button_first);
final Button buttonSecond = (Button) findViewById(R.id.button_second);
buttonFirst.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
}
});
buttonSecond.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
}
});
}
如果你的所有按钮都有相同的监听器,你可以将它们设置为静态以避免代码重复:
IconListener.java:
public class IconListener {
public static View.OnClickListener listenerButtonOne = new View.OnClickListener() {
@Override
public void onClick(View v) {
//DO what you want
}
};
public static View.OnClickListener listenerButtonTwo = new View.OnClickListener() {
@Override
public void onClick(View v) {
//Do what you want
}
};
}
所以你的MainActivity.java变成了
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
final Button buttonFirst = (Button) findViewById(R.id.button_first);
final Button buttonSecond = (Button) findViewById(R.id.button_second);
buttonFirst.setOnClickListener(IconListener.listenerButtonOne)
buttonSecond.setOnClickListener(IconListener.listenerButtonTwo);
}