侧边栏 DrawerLayout布局使用教程

首先我们使用DrawerLayout布局:
<android.support.v4.widget.DrawerLayout
xmlns:android=“http://schemas.android.com/apk/res/android
android:id="@+id/draw_layout"
android:layout_width=“match_parent”
android:layout_height=“match_parent”>
</android.support.v4.widget.DrawerLayout>
DrawerLayout布局内用两个大布局即可实现侧边栏的效果.

我们可以看到以下代码中,首先使用了RelativeLayout布局,这是主页面的布局,接下来LinearLayout为侧边栏的布局.注意LinearLayout布局内需要设置android:layout_gravity=“start” 也可以设置为end.即可实现

    <FrameLayout
        android:id="@+id/frag_content"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        />
</RelativeLayout>
<LinearLayout
    android:layout_width="200dp"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:id="@+id/zuo_lin"
    android:layout_gravity="start"
    android:background="@color/colorPrimary"
    >
    <ImageView
        android:layout_width="60dp"
        android:layout_height="60dp"
        android:id="@+id/img_left"
        android:layout_marginTop="20dp"
        android:layout_gravity="center_horizontal"
        android:src="@mipmap/ic_launcher_round"
        />
    <TextView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_gravity="center_horizontal"
        android:gravity="center"
        android:layout_marginTop="20dp"
        android:text="这是侧栏" />

    <TextView
        android:id="@+id/xList_left"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="20dp"
        android:gravity="center"
        android:text="xListView" />

    <TextView
        android:id="@+id/tab_left"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginTop="20dp"
        android:gravity="center"
        android:text="TabLayout" />
</LinearLayout>

布局就看到这里,
下面我们来看代码处理:
首先我们要实现View.OnClickListener接口,接下来我们查找控件,设置监听,要提前建好Fragment
public class MainActivity extends AppCompatActivity implements View.OnClickListener {

private ImageView img_left;
private TextView xList_left;
private TextView tab_left;
private DrawerLayout draw_layout;
private AFragment aFragment;
private BFragment bFragment;
private FragmentManager manager;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    initView();
    initData();
}
//创建Fragment对象
private void initData() {
    aFragment = new AFragment();
    bFragment = new BFragment();
}
//获取控件 设置监听
private void initView() {
    img_left = (ImageView) findViewById(R.id.img_left);
    img_left.setOnClickListener(this);

    xList_left = (TextView) findViewById(R.id.xList_left);
    xList_left.setOnClickListener(this);

    tab_left = (TextView) findViewById(R.id.tab_left);
    tab_left.setOnClickListener(this);

    draw_layout = (DrawerLayout) findViewById(R.id.draw_layout);
    //获取Fragment管理类
    manager = getSupportFragmentManager();
}
//监听事件
@Override
public void onClick(View v) {
    switch (v.getId()){
        case R.id.img_left:
            Toast.makeText(MainActivity.this,"您的头像",Toast.LENGTH_SHORT).show();
            break;
        case R.id.xList_left:
            manager.beginTransaction().replace(R.id.frag_content,aFragment).commit();
            //不要忘记closeDrawers();
            draw_layout.closeDrawers();
            break;
        case R.id.tab_left:
            manager.beginTransaction().replace(R.id.frag_content,bFragment).commit();
            draw_layout.closeDrawers();
            break;
    }

}

}
注意不要忘记closeDrawers()以及break;
DrawerLayout实现侧边栏效果比较简单,看到这里,您应该已经明白了

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值