actionbar必须在Android3.0 以上的版本中使用如果需要兼容要使用v7包
看知乎客户端那个侧滑栏挺好玩的,查了一下是v7包里面带的效果,于是就写了个demo
效果就是那个
一个“三“
然后点击变”←“。图片显示不出来好蛋疼。。
首先是布局:
这里比较重要的是,这个DrawerLayout下必须有两个view,而且必须有属性。。,否则点击按钮会报错。因为点击按钮的时候显示的就是第二个布局。其实和slidingMenu挺像的。。。
android:id="@+id/drawer_layout"
android:layout_width="match_parent"
android:layout_height="match_parent" >
android:id="@+id/content_frame"
android:layout_width="match_parent"
android:layout_height="match_parent" />
android:id="@+id/left_drawer"
android:layout_width="240dp"
android:layout_height="match_parent"
android:layout_gravity="left"
android:background="@android:color/white"
android:choiceMode="singleChoice"
android:divider="@android:color/transparent"
android:dividerHeight="0dp" />
然后代码:
public class MainActivity extends AppCompatActivity implements AdapterView.OnItemClickListener {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
left_drawer = (ListView) findViewById(R.id.left_drawer);
left_drawer.setAdapter(new MyAdapter());
mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
getSupportActionBar().setDisplayHomeAsUpEnable
d(true);
mDrawerToggle = new ActionBarDrawerToggle(this, mDrawerLayout
,
R.string.navigation_drawer_open,
R.string.navigation_drawer_close);
mDrawerLayout.setDrawerListener(mDrawerToggle);
// getActionBar().setTitle("开头"); 这个不能用,getActionBar返回空。
getSupportActionBar().setTitle("开头");
}
@Override
protected void onPostCreate(Bundle savedInstanceState) {
mDrawerToggle.syncState();// 这个必须要,没有的话进去的默认是个箭头。。正常应该是三横杠的
super.onPostCreate(savedInstanceState);
}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
return mDrawerToggle.onOptionsItemSelected(item)
|| super.onOptionsItemSelected(item);
}
@Override
public void onConfigurationChanged(Configuration newConfig) {
super.onConfigurationChanged(newConfig);
mDrawerToggle.onConfigurationChanged(newConfig);
}
如果想加actionBar:
@Override
public boolean onCreateOptionsMenu(Menu menu) {
MenuInflater inflater = getMenuInflater();
inflater.inflate(R.menu.main, menu);
return true;
}