zoukankan      html  css  js  c++  java
  • Android studio DrawerLayout示例

    示例2.左右两个侧滑菜单的实现

    嗯,不知道你有没有发现,从上面的DrawerLayout的布局,我们大概可以猜到,DrawerLayout 最多由三个部分组成,中间的内容部分,左边的侧滑菜单部分,右边的侧滑菜单部分组成! 下面我们来写一个带有两个侧滑菜单的示例!

     

    代码实现

    首先我们创建两个Fragment以及对应的布局,他们分别是左右侧滑菜单!

    左边Fragment

    布局:fg_left.xml,这里就用了一个图片而以,点击后弹出一个新的Activity; 当然你可以根据自己的需求进行扩展!

    复制代码
    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:orientation="vertical" android:layout_width="match_parent"
        android:layout_height="match_parent">
    
        <ImageView
            android:id="@+id/img_bg"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:background="@mipmap/bg_menu_left"/>
    
    </LinearLayout>
    复制代码

    对应的LeftFragment.java

    复制代码
    public class LeftFragment extends Fragment{
    
        private DrawerLayout drawer_layout;
    
        @Override
        public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
            View view = inflater.inflate(R.layout.fg_left, container, false);
            ImageView img_bg = (ImageView) view.findViewById(R.id.img_bg);
            img_bg.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    getActivity().startActivity(new Intent(getActivity(),OtherActivity.class));
                    drawer_layout.closeDrawer(Gravity.START);
                }
            });
            return view;
        }
    
        //暴露给Activity,用于传入DrawerLayout,因为点击后想关掉DrawerLayout
        public void setDrawerLayout(DrawerLayout drawer_layout){
            this.drawer_layout = drawer_layout;
        }
    }
    复制代码

    右面的Fragment

    布局就三个按钮,点击后替换中间部分的Fragment,布局fg_right.xml代码如下:

    复制代码
    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="#2F9AF2"
        android:gravity="center"
        android:orientation="vertical">
    
        <Button
            android:id="@+id/btn_one"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="菜单项一" />
    
        <Button
            android:id="@+id/btn_two"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="菜单项二" />
    
        <Button
            android:id="@+id/btn_three"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="菜单项三" />
    
    </LinearLayout>
    复制代码

    然后对应的是RightFragment.java

    复制代码
    public class RightFragment extends Fragment implements View.OnClickListener{
    
        private DrawerLayout drawer_layout;
        private FragmentManager fManager;
    
        @Override
        public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
            View view = inflater.inflate(R.layout.fg_right, container, false);
            view.findViewById(R.id.btn_one).setOnClickListener(this);
            view.findViewById(R.id.btn_two).setOnClickListener(this);
            view.findViewById(R.id.btn_three).setOnClickListener(this);
            fManager = getActivity().getSupportFragmentManager();
            return view;
        }
    
        @Override
        public void onClick(View v) {
            switch (v.getId()){
                case R.id.btn_one:
                    ContentFragment cFragment1 = new ContentFragment("1.点击了右侧菜单项一",R.color.blue);
                    fManager.beginTransaction().replace(R.id.fly_content,cFragment1).commit();
                    drawer_layout.closeDrawer(Gravity.END);
                    break;
                case R.id.btn_two:
                    ContentFragment cFragment2 = new ContentFragment("2.点击了右侧菜单项二",R.color.red);
                    fManager.beginTransaction().replace(R.id.fly_content,cFragment2).commit();
                    drawer_layout.closeDrawer(Gravity.END);
                    break;
                case R.id.btn_three:
                    ContentFragment cFragment3 = new ContentFragment("3.点击了右侧菜单项三",R.color.yellow);
                    fManager.beginTransaction().replace(R.id.fly_content,cFragment3).commit();
                    drawer_layout.closeDrawer(Gravity.END);
                    break;
            }
        }
    
        public void setDrawerLayout(DrawerLayout drawer_layout){
            this.drawer_layout = drawer_layout;
        }
    
    }
    复制代码
     

    另外还有一个中间部分填充的ContentFragment,布局:fg_content.xml如下:

    复制代码
    <?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical">
    
        <TextView
            android:id="@+id/tv_content"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerInParent="true"
            android:textSize="25sp" />
    
    </RelativeLayout>
    复制代码

    ContentFragment.java

    复制代码
    public class ContentFragment extends Fragment {
    
        private TextView tv_content;
        private String strContent;
        private int bgColor;
    
        public ContentFragment(String strContent,int bgColor) {
            this.strContent = strContent;
            this.bgColor = bgColor;
        }
    
        @Override
        public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
            View view = inflater.inflate(R.layout.fg_content, container, false);
            view.setBackgroundColor(getResources().getColor(bgColor));
            tv_content = (TextView) view.findViewById(R.id.tv_content);
            tv_content.setText(strContent);
            return view;
        }
    }
    复制代码

    编写好以后,就到我们的Activity的布局了以及Activity的代码了: 在此之前我们还需要些一个顶部条形栏的布局:

    view_topbar.xml

    复制代码
    <?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#DCDEDB">
    
        <Button
            android:id="@+id/btn_right"
            android:layout_width="40dp"
            android:layout_height="40dp"
            android:layout_centerVertical="true"
            android:layout_alignParentRight="true"
            android:background="@drawable/btn_selctor"/>
    
    </RelativeLayout>
    复制代码

    然后是activity_main.xml

    复制代码
    <android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        android:id="@+id/drawer_layout"
        android:layout_width="match_parent"
        android:layout_height="match_parent">
    
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="vertical">
    
            <include
                android:id="@+id/topbar"
                layout="@layout/view_topbar"
                android:layout_width="wrap_content"
                android:layout_height="48dp" />
    
            <FrameLayout
                android:id="@+id/fly_content"
                android:layout_width="match_parent"
                android:layout_height="match_parent" />
    
        </LinearLayout>
    
        <fragment
            android:id="@+id/fg_left_menu"
            android:name="jay.com.drawerlayoutdemo2.LeftFragment"
            android:layout_width="300dp"
            android:layout_height="match_parent"
            android:layout_gravity="start"
            android:tag="LEFT"
            tools:layout="@layout/fg_left" />
    
        <fragment
            android:id="@+id/fg_right_menu"
            android:name="jay.com.drawerlayoutdemo2.RightFragment"
            android:layout_width="100dp"
            android:layout_height="match_parent"
            android:layout_gravity="end"
            android:tag="RIGHT"
            tools:layout="@layout/fg_right" />
    
    </android.support.v4.widget.DrawerLayout>
    复制代码

    最后是MainActivity.java

    复制代码
    public class MainActivity extends AppCompatActivity implements View.OnClickListener {
    
        private DrawerLayout drawer_layout;
        private FrameLayout fly_content;
        private View topbar;
        private Button btn_right;
        private RightFragment fg_right_menu;
        private LeftFragment fg_left_menu;
        private FragmentManager fManager;
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
            fManager = getSupportFragmentManager();
            fg_right_menu = (RightFragment) fManager.findFragmentById(R.id.fg_right_menu);
            fg_left_menu = (LeftFragment) fManager.findFragmentById(R.id.fg_left_menu);
            initViews();
        }
    
        private void initViews() {
            drawer_layout = (DrawerLayout) findViewById(R.id.drawer_layout);
            fly_content = (FrameLayout) findViewById(R.id.fly_content);
            topbar = findViewById(R.id.topbar);
            btn_right = (Button) topbar.findViewById(R.id.btn_right);
            btn_right.setOnClickListener(this);
    
            //设置右面的侧滑菜单只能通过编程来打开
            drawer_layout.setDrawerLockMode(DrawerLayout.LOCK_MODE_LOCKED_CLOSED,
                    Gravity.END);
    
            drawer_layout.setDrawerListener(new DrawerLayout.DrawerListener() {
                @Override
                public void onDrawerSlide(View view, float v) {
    
                }
    
                @Override
                public void onDrawerOpened(View view) {
    
                }
    
                @Override
                public void onDrawerClosed(View view) {
                    drawer_layout.setDrawerLockMode(
                            DrawerLayout.LOCK_MODE_LOCKED_CLOSED, Gravity.END);
                }
    
                @Override
                public void onDrawerStateChanged(int i) {
    
                }
            });
    
            fg_right_menu.setDrawerLayout(drawer_layout);
            fg_left_menu.setDrawerLayout(drawer_layout);
        }
    
        @Override
        public void onClick(View v) {
            drawer_layout.openDrawer(Gravity.RIGHT);
            drawer_layout.setDrawerLockMode(DrawerLayout.LOCK_MODE_UNLOCKED,
                    Gravity.END);    //解除锁定
        }
    }
    复制代码
  • 相关阅读:
    搭建typescript练习环境
    原有vue项目支持typescript
    express使用session
    express使用cookie
    javascript原型链
    javascript事件循环
    express中间件及body-parser第三方中间件获取post传值
    express路由、静态托管、ejs模板引擎
    nodejs驱动mongodb 实现数据增删改查,将数据库数据渲染在页面,通过表单项数据库新增数据
    柏松分布
  • 原文地址:https://www.cnblogs.com/1329197745a/p/14905765.html
Copyright © 2011-2022 走看看