TabLayout与Fragment嵌套+侧滑

MainActivity

package com.example.pulltorefresh;

import android.support.design.widget.TabLayout;
import android.support.v4.view.ViewPager;
import android.support.v4.widget.DrawerLayout;
import android.support.v7.app.ActionBarDrawerToggle;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.Gravity;
import android.view.MenuItem;

public class MainActivity extends AppCompatActivity {

    private DrawerLayout drawerLayout;
    private ActionBarDrawerToggle toggle;
    private ViewPager viewPager;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //为空的时候才添加fragment
        if (savedInstanceState == null){
            getSupportFragmentManager().beginTransaction()
                    .add(R.id.left_drawer, new Fragmentone())
                    .commit();
        }

        initView();//初始化view
    }

    private void initView() {
        getSupportActionBar().setDisplayHomeAsUpEnabled(true);
        drawerLayout = findViewById(R.id.drawer);
        toggle = new ActionBarDrawerToggle(this, drawerLayout, R.string.open_drawer, R.string.close_drawer);
        drawerLayout.addDrawerListener(toggle);
        toggle.syncState();

        viewPager = findViewById(R.id.pager);

        viewPager.setAdapter(new MainPageAdapter(getSupportFragmentManager()));
        TabLayout tabLayout = findViewById(R.id.tablayout);
        tabLayout.setupWithViewPager(viewPager);

    }
    public void showPage(int position){
        viewPager.setCurrentItem(position);
        drawerLayout.closeDrawer(Gravity.START);
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        if (toggle.onOptionsItemSelected(item)){
            return true;
        }
        return super.onOptionsItemSelected(item);
    }

}

MainPagerAdapter

package com.example.pulltorefresh;

import android.support.annotation.Nullable;
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentPagerAdapter;
import android.support.v4.view.PagerAdapter;

public class MainPageAdapter extends FragmentPagerAdapter {

    private String[] menus = new String[]{"首页","视频", "我的"};

    public MainPageAdapter(FragmentManager fm) {
        super(fm);
    }

    @Override
    public Fragment getItem(int i) {
        switch (i){
            case 0:
                return new AFragment();
            case 1:
                return new BFragment();
            case 2:
                return new CFragment();
            default:
                return new AFragment();
        }
    }

    @Nullable
    @Override
    public CharSequence getPageTitle(int position) {
        return menus[position];
    }

    @Override
    public int getCount() {
        return menus.length;
    }
}

FragmentOne侧滑

package com.example.pulltorefresh;

import android.app.AlertDialog;
import android.app.Dialog;
import android.content.DialogInterface;
import android.net.Uri;
import android.os.Bundle;
import android.support.annotation.NonNull;
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.AdapterView;
import android.widget.ListView;
import android.widget.Toast;

public class Fragmentone extends Fragment {

    private ListView listView;

    @Nullable
    @Override
    public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        return inflater.inflate(R.layout.drawer_one, container, false);
    }

    @Override
    public void onViewCreated(@NonNull View view, @Nullable Bundle savedInstanceState) {
        super.onViewCreated(view, savedInstanceState);

        listView = view.findViewById(R.id.lists);
        listView.setAdapter(new OneAdapter(getActivity()));

        listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                //图片下标0,不做操作
                if (position == 0){
                    Toast.makeText(getActivity(), "我是图片", Toast.LENGTH_SHORT).show();
                   // imageBitmaps(); //对图片的操作
                }
                ((MainActivity)getActivity()).showPage(position - 1);
            }

        });
    }
}

OnePageAdapter

package com.example.pulltorefresh;

import android.content.Context;
import android.support.v4.app.FragmentActivity;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;

public class OneAdapter extends BaseAdapter {

    private String[] TabMenu = new String[]{"首页","视频","我的"};
    private Context mContext;

    public OneAdapter(Context mContext) {
        this.mContext = mContext;
    }

    @Override
    public int getCount() {
        return TabMenu.length + 1;
    }
    private final int COUNT = 2;
    private final int IMAGE = 0;
    private final int TEXT = 1;

    @Override
    public int getViewTypeCount() {
        return COUNT;
    }

    @Override
    public int getItemViewType(int position) {
        return position == 0? IMAGE : TEXT;
    }

    @Override
    public String getItem(int position) {
        if (position == 0){
            return null;
        }
        return TabMenu[position - 1];
    }

    @Override
    public long getItemId(int position) {
        return position;
    }

    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        ViewHolder mHolder = null;
        if (convertView == null){
            convertView = LayoutInflater.from(mContext).inflate(
                    getItemViewType(position) == IMAGE ? R.layout.image_menu : R.layout.text_menu, parent, false);
            mHolder = new ViewHolder(convertView);
        }else {
            mHolder = (ViewHolder) convertView.getTag();
        }
        if (getItemViewType(position) == TEXT){
            mHolder.bindData(getItem(position));
        }
        return convertView;
    }

    class ViewHolder{
        ImageView imageView;
        TextView textView;

        public ViewHolder(View itemView){
            imageView = itemView.findViewById(R.id.img);
            textView = itemView.findViewById(R.id.text);
            itemView.setTag(this);
        }
        public void bindData(String item) {
             textView.setText(item);
        }
    }
}

布局文件

activity_main.xml

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

   <RelativeLayout
       android:layout_width="match_parent"
       android:layout_height="match_parent">

      <android.support.design.widget.TabLayout
          android:id="@+id/tablayout"
          android:layout_width="match_parent"
          android:layout_height="wrap_content"
          android:layout_alignParentBottom="true"

          app:tabTextColor="@color/colorPrimary"
          app:tabSelectedTextColor="@color/colorAccent"
          app:tabIndicatorColor="@android:color/transparent"
          app:tabIndicatorHeight="1dp"
          android:background="#44ccff"
          />
      <android.support.v4.view.ViewPager
          android:id="@+id/pager"
          android:layout_width="match_parent"
          android:layout_height="match_parent"
          android:layout_above="@+id/tablayout"
          />
   </RelativeLayout>

   <FrameLayout
       android:id="@+id/left_drawer"
       android:layout_width="301dp"
       android:layout_height="match_parent"
       android:layout_gravity="start"
       android:background="#ccf"
       />

</android.support.v4.widget.DrawerLayout>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值