ActionBarCompat and NavigationDrawer
In previous posts I talked about new ActionBarCompat.
In this post we'll try to use ActionBarCompat with the NavigationDrawer.
If you have already implemented a NavigationDrawer with ActionBar, it is very easy to migrate to ActionBarCompat.
I will use code I wrote with post Creating a Navigation Drawer.
Here you can see steps:
First of all you have to add ActionBarCompat to your project.
Then:
In your Activity you have to extend ActionBarActivity.
Change getActionBar() with get getSupportActionBar().
Pay attention with invalidateOptionsMenu().
You have to change it with supportInvalidateOptionsMenu();
It is very easy!
Some last tips:
Be careful not to use attributes that work only with API 14+, like ?android:attr/listPreferredItemHeightSmall or ?android:attr/textAppearanceListItemSmall.
In this case you can use different styles using folder values-v14.
Be careful with menu width. Older devices can have very small screens. It could be a good idea to use different width, with a default 240dp, and a value of 320dp only with large screens (with folder values-sw320dp).
data:image/s3,"s3://crabby-images/262a4/262a499976d1083b29373f1380afc93d6961a282" alt=""
That's all... it works...(and certainly can be improved).
You can get code from GitHub:
In this post we'll try to use ActionBarCompat with the NavigationDrawer.
If you have already implemented a NavigationDrawer with ActionBar, it is very easy to migrate to ActionBarCompat.
I will use code I wrote with post Creating a Navigation Drawer.
Here you can see steps:
First of all you have to add ActionBarCompat to your project.
Then:
In your Activity you have to extend ActionBarActivity.
Change getActionBar() with get getSupportActionBar().
data:image/s3,"s3://crabby-images/6cebf/6cebf19ec10bddb0ccf9257f64e192260b80b749" alt=""
Pay attention with invalidateOptionsMenu().
You have to change it with supportInvalidateOptionsMenu();
data:image/s3,"s3://crabby-images/7655d/7655ddcab6e368a98d110da4483c36696261ffa5" alt=""
It is very easy!
Some last tips:
Be careful not to use attributes that work only with API 14+, like ?android:attr/listPreferredItemHeightSmall or ?android:attr/textAppearanceListItemSmall.
data:image/s3,"s3://crabby-images/3d2a5/3d2a555d303f6f858e5401e633fafe1d9d613267" alt=""
In this case you can use different styles using folder values-v14.
Be careful with menu width. Older devices can have very small screens. It could be a good idea to use different width, with a default 240dp, and a value of 320dp only with large screens (with folder values-sw320dp).
data:image/s3,"s3://crabby-images/262a4/262a499976d1083b29373f1380afc93d6961a282" alt=""
data:image/s3,"s3://crabby-images/e144c/e144cd6cc2b1f843905de07315a7703c6d85b182" alt=""
That's all... it works...(and certainly can be improved).
You can get code from GitHub:
Comments
Post a Comment