我有一个拆分的ActionBar,我正在尝试添加几乎与谷歌播放'现在播放'相同的功能..
我可以使用onCreateOptionsMenu让菜单项显示在屏幕底部,但是当使用actionBar.setCustomView时,我似乎无法在屏幕底部显示自定义视图。自定义视图位于顶部ActionBar下方。
有谁知道如何将自定义视图强制到底部,或者将自定义视图添加到onCreateOptionsMenu?
以下是我的代码片段:
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
ActionBar actionBar = getActionBar();
actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS);
actionBar.setDisplayShowTitleEnabled(true);
actionBar.setDisplayOptions(ActionBar.DISPLAY_SHOW_CUSTOM);
//Custom view to add
actionBar.setCustomView(R.layout.albumitem);
//This view shows up just under the top actionbar at the moment,
despite menu items being at the bottom
菜单选项代码:(这些显示在我想要自定义视图的底部)
@Override
public boolean onCreateOptionsMenu(Menu menu) {
new MenuInflater(this).inflate(R.menu.option_menu, menu);
return (super.onCreateOptionsMenu(menu));
}
我相信Google Play音乐应用底部现在播放的菜单是一个分割操作栏内的自定义视图:
答案 0 :(得分:17)
所以我设法找到了一个肮脏的解决方案......好吧,我的业余观点很脏......
在oncreateOptionsMenu中,我已经夸大了一个名为option_menu的菜单,如下所示:
@Override
public boolean onCreateOptionsMenu(Menu menu) {
new MenuInflater(this).inflate(R.menu.option_menu, menu);
在该option_menu项目的xml中,我已经实现了一个actionViewClass,在这种情况下我使用了相对布局(我猜我可以只使用View ..?):
<item
android:id="@+id/layout_item"
android:actionViewClass="android.widget.RelativeLayout"
android:showAsAction="always|withText"
android:title="Text 1"/>
</menu>
然后我夸大了xml布局,并将其添加到菜单中定义的layout_item中:
@Override
public boolean onCreateOptionsMenu(Menu menu) {
new MenuInflater(this).inflate(R.menu.option_menu, menu);
relativeLayout = (RelativeLayout) menu.findItem(R.id.layout_item)
.getActionView();
View inflatedView = getLayoutInflater().inflate(R.layout.now_playing,
null);
relativeLayout.addView(inflatedView);
return (super.onCreateOptionsMenu(menu));
}
请随意根据需要编辑/改进此答案。
答案 1 :(得分:1)
我已经完成了基于你的解决方案,包括顶部的自定义布局+底部的自定义布局+标题/副标题+主页图标。这是代码:
public class SplitABActivity extends Activity{
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
ActionBar ab = getActionBar();
ab.setTitle("Action Bar Title");
ab.setSubtitle("Action Bar Subtitle");
ab.setDisplayShowHomeEnabled(true);
LayoutInflater inflater = (LayoutInflater) getSystemService(Activity.LAYOUT_INFLATER_SERVICE);
RelativeLayout layout = (RelativeLayout) inflater.inflate(R.layout.ab_custom_layout, null);
ab.setCustomView(layout);
ab.setSplitBackgroundDrawable(new ColorDrawable(Color.BLUE));
ab.setDisplayOptions(ActionBar.DISPLAY_SHOW_CUSTOM | ActionBar.DISPLAY_SHOW_HOME | ActionBar.DISPLAY_SHOW_TITLE);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
MenuInflater inflater = getMenuInflater();
inflater.inflate(R.menu.menu_including_layout, menu);
RelativeLayout layout = (RelativeLayout) menu.findItem(R.id.layout_item).getActionView();
View v = getLayoutInflater().inflate(R.layout.ab_bottom_layout, null);
layout.addView(v);
return super.onCreateOptionsMenu(menu);
}
}
ab_custom_layout.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="right"
>
<TextView android:id="@+id/element1"
android:layout_width="wrap_content" android:layout_height="wrap_content"
android:textColor="#fff"
android:background="#ff0000"
android:text="Element 1"/>
<TextView
android:id="@+id/element2"
android:layout_width="wrap_content" android:layout_height="wrap_content"
android:textColor="#000"
android:background="#f0f0f0"
android:layout_toRightOf="@+id/element1"
android:text="Element 2"/>
</RelativeLayout>
menu_including_layout.xml
<menu xmlns:android="http://schemas.android.com/apk/res/android" >
<item android:id="@+id/action1"
android:title="Action 1"
android:icon="@android:drawable/ic_dialog_alert"
android:showAsAction="ifRoom" />
<item android:id="@+id/action2"
android:title="Action 2"
android:icon="@android:drawable/ic_dialog_info"
android:showAsAction="ifRoom" />
<item
android:id="@+id/layout_item"
android:actionViewClass="android.widget.RelativeLayout"
android:showAsAction="always|withText"
android:title="Layout Item"/>
</menu>
ab_bottom_layout.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
>
<TextView
android:id="@+id/bottom_layout_txt_status"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Click this button"/>
<ImageButton android:id="@+id/bottom_layout_btn_chat"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@android:drawable/ic_menu_camera"
android:layout_toRightOf="@+id/bottom_layout_txt_status"
android:contentDescription="@string/app_name"/>
</RelativeLayout>
代码对我来说非常适合。当我的平板电脑处于人像状态时,我可以看到拆分的ActionBar。在景观上,它足够宽,可以存储在顶部的所有项目。
希望有所帮助