侧滑_tablelayout

//activity

<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/drlayout"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context="com.example.af.MainActivity">


    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent">
        <!--主页面的布局-->
        <android.support.design.widget.TabLayout
            android:id="@+id/tab"
            android:layout_width="match_parent"
            android:layout_height="50dp" />


        <android.support.v4.view.ViewPager
            android:id="@+id/vp"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />




    </RelativeLayout>
    <!--侧拉菜单的布局   android:layout_gravity="start"  菜单在左边  end  菜单在右边 -->
    <RelativeLayout
        android:id="@+id/rel"
        android:layout_width="240dp"
        android:layout_height="match_parent"
        android:layout_gravity="start"
        android:background="#ffff00">


        <ImageView
            android:id="@+id/img"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:src="@mipmap/ic_launcher" />


        <ListView
            android:id="@+id/lv"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_below="@id/img"></ListView>
    </RelativeLayout>


</android.support.v4.widget.DrawerLayout>

//content

<?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"
    android:gravity="center">


    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/tv"
        android:textColor="#f00"/>


</LinearLayout>

//item

<?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">


    <TextView
        android:id="@+id/tvv"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:text="我是主页面" />
</LinearLayout>

//main

package com.example.af;


import android.os.Bundle;
import android.support.design.widget.TabLayout;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import android.support.v4.view.ViewPager;
import android.support.v4.widget.DrawerLayout;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.RelativeLayout;


import java.util.ArrayList;
import java.util.List;


public class MainActivity extends AppCompatActivity {
    private List<String> datas = new ArrayList<String>();
    private DrawerLayout drawerLayout;
    private ListView listView;
    private RelativeLayout rel;
    private List<String> lists = new ArrayList<String>();


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        drawerLayout = (DrawerLayout) findViewById(R.id.drlayout);
        listView = (ListView) findViewById(R.id.lv);
        rel = (RelativeLayout) findViewById(R.id.rel);


        //drawerLayout
        for (int i = 1; i < 20; i++) {
            lists.add("条目" + i);
        }
        ArrayAdapter<String> adapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, lists);
        listView.setAdapter(adapter);
        listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                //关闭侧滑菜单
                drawerLayout.closeDrawer(rel);
                //drawerLayout.openDrawer(rel);//打开侧滑菜单
                //设置参数
                Content content = new Content();
                Bundle bundle = new Bundle();
                bundle.putString("value", lists.get(position));
                content.setArguments(bundle);
                //切换fragment
                //getSupportFragmentManager().beginTransaction().replace(R.id.fcontent, content).commit();
            }
        });


        drawerLayout.setDrawerListener(new DrawerLayout.DrawerListener() {


            //slideOffset:侧滑菜单 宽度的像素值
            @Override
            public void onDrawerSlide(View drawerView, float slideOffset) {


            }


            @Override
            public void onDrawerOpened(View drawerView) {
                Log.d("zzz", "open");


            }


            @Override
            public void onDrawerClosed(View drawerView) {
                Log.d("zzz", "close");
            }


            @Override
            public void onDrawerStateChanged(int newState) {
                Log.d("zzz", "状态改变:" + newState);


            }
        });


        //TabLayout
        TabLayout tabLayout = (TabLayout) findViewById(R.id.tab);
        ViewPager viewPager = (ViewPager) findViewById(R.id.vp);
        datas.add("推荐");
        datas.add("要闻");
        datas.add("娱乐");
        datas.add("科技");
        datas.add("汽车");
        datas.add("体育");
        datas.add("图片");
        datas.add("动漫");
        datas.add("社会");
        datas.add("游戏");
//        tabLayout.addTab();
        viewPager.setAdapter(new MyAdapter(getSupportFragmentManager()));
        //进行关联
        tabLayout.setupWithViewPager(viewPager);
    }




    class MyAdapter extends FragmentPagerAdapter {


        //带参的构造方法
        public MyAdapter(FragmentManager fm) {
            super(fm);
        }


        //返回选项卡的文本 ,,,添加选项卡
        @Override
        public CharSequence getPageTitle(int position) {
            return datas.get(position);
        }


        @Override
        public Fragment getItem(int position) {
            Log.d("zzz", "position:" + position);


            //创建fragment对象并返回
            Bundle bundle = new Bundle();
            bundle.putString("key", datas.get(position));


            ContentFragment contentFragment = new ContentFragment();
            contentFragment.setArguments(bundle);


            return contentFragment;
        }


        @Override
        public int getCount() {
            return datas.size();//返回选项卡的数量
        }
    }


}

//fram
package com.example.af;


import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;


public class ContentFragment  extends Fragment {


    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        View view=View.inflate(getActivity(),R.layout.content,null);
        TextView textView= (TextView) view.findViewById(R.id.tv);
        Bundle bundle=getArguments();
        textView.setText(bundle.getString("key"));
        return view;
    }
}

//Content

package com.example.af;


import android.os.Bundle;
import android.support.annotation.Nullable;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;



public class Content extends Fragment {


    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        View v = View.inflate(getActivity(), R.layout.item, null);
        return v;
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值