I would like to have an ActionBar with custom navigation where the custom views look like the standard action bar tabs. I know it sounds like reinventing the wheel but it means we can have the menu button on the same row as the tabs as shown below. This is a design requirement and practically makes much more UI sense for this app than the standard android behaviour.
I've tried using an IcsLinearLayout from ActionBarSherlock like so:
<IcsLinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:orientation="horizontal"
android:layout_height="50dip">
<Button
android:id="@+id/tab_1"
android:layout_height="match_parent"
android:gravity="center"
android:layout_width="wrap_content"
android:textStyle="bold"
android:text="TAB_1"
android:background="@drawable/abs__item_background_holo_light"
/>
<Button
android:id="@+id/tab_2"
android:layout_height="match_parent"
android:gravity="center"
android:layout_width="wrap_content"
android:textStyle="bold"
android:text="TAB_2"
android:background="@drawable/abs__item_background_holo_light"
/>
</IcsLinearLayout>
But that replicates ActionButtons and I have no idea how to replicate Tabs.
I assume I will need:
Any pointers to samples or similar solutions (even within the ActionBarSherlock library) would be greatly appreciated.
//enabling embedded tabs
//pre-ICS
if (actionBarSherlock instanceof ActionBarImpl) {
enableEmbeddedTabs(actionBarSherlock);
//ICS and forward
} else if (actionBarSherlock instanceof ActionBarWrapper) {
try {
Field actionBarField = actionBarSherlock.getClass().getDeclaredField("mActionBar");
actionBarField.setAccessible(true);
enableEmbeddedTabs(actionBarField.get(actionBarSherlock));
} catch (Exception e) {
Log.e(TAG, "Error enabling embedded tabs", e);
}
}
//helper method
private void enableEmbeddedTabs(Object actionBar) {
try {
Method setHasEmbeddedTabsMethod = actionBar.getClass().getDeclaredMethod("setHasEmbeddedTabs", boolean.class);
setHasEmbeddedTabsMethod.setAccessible(true);
setHasEmbeddedTabsMethod.invoke(actionBar, true);
} catch (Exception e) {
Log.e(TAG, "Error marking actionbar embedded", e);
}
}
this code works perfectly . Tried it in my app . for further reference - https://groups.google.com/forum/#!topic/actionbarsherlock/hmmB1JqDeCk
By using hierarchy viewer I think we've worked out how to do this. It turns out it wasn't difficult at all. You need a ScrollingTabContainerView from the ABS library and you can add tabs to that.
public class MainActivity extends SherlockActivity implements ActionBar.TabListener {
/**
* Called when the activity is first created.
*/
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
ScrollingTabContainerView root = new ScrollingTabContainerView(this);
ActionBar.Tab tab1 = getSupportActionBar().newTab();
tab1.setText("TAB 1");
tab1.setTabListener(this);
ActionBar.Tab tab2 = getSupportActionBar().newTab();
tab2.setText("TAB 2");
tab2.setTabListener(this);
root.addTab(tab1, 0, true);
root.addTab(tab2, 1, false);
getSupportActionBar().setCustomView(root);
getSupportActionBar().setDisplayShowCustomEnabled(true);
getSupportActionBar().setTitle("App Title");
}
@Override
public boolean onCreateOptionsMenu(Menu menu){
menu.add("MENU ITEM 1");
menu.add("MENU ITEM 2");
return true;
}
@Override
public void onTabSelected(ActionBar.Tab tab, FragmentTransaction ft) {
//To change body of implemented methods use File | Settings | File Templates.
}
@Override
public void onTabUnselected(ActionBar.Tab tab, FragmentTransaction ft) {
//To change body of implemented methods use File | Settings | File Templates.
}
@Override
public void onTabReselected(ActionBar.Tab tab, FragmentTransaction ft) {
//To change body of implemented methods use File | Settings | File Templates.
}
I hope this helps someone.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With