导入兼容包

本文详细介绍了Android中ViewPager的使用方法及Fragment的生命周期管理,包括如何配置ViewPager与PagerAdapter、实现页面滑动监听,以及Fragment的定义、动态管理和生命周期等。
1####    ViewPager
ViewPager是support v4包中的页面切换视图,使用时需要导入support.v4的包

   
 xml:声明
    <android.support.v4.view.ViewPager
        android:id="@+id/m_pager"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />



    java:配置和多个view的关系需要使用PagerAdapter
    初始化:
    ViewPager mPager = (ViewPager) findViewById(R.id.m_pager);

    定义需要的页面
    List<View> list = new ArrayList<View>();
    ...
    list.add(v1);
    list.add(v2);
定义适配器,需要继承PagerAdapter

   
 class MyPagerAdapter extends PagerAdapter {
        private List<View> list;

        MyPagerAdapter(List<View> list) {
            this.list = list;
        }



        
// 配置多少个页面
        @Override
        public int getCount() {
            return null == list ? 0 : list.size();
        }

        @Override
        public boolean isViewFromObject(View v, Object obj) {
            return v == obj;
        }

        // 视图移除缓冲区时触发
        @Override
        public void destroyItem(ViewGroup container, int position, Object object) {
            //获取要移除的视图对象
            View v = list.get(position);
            container.removeView(v);
        }

        // 视图进入缓冲区时触发
        @Override
        public Object instantiateItem(ViewGroup container, int position) {
            View v = list.get(position);
            // 将进入缓冲区的视图对象,添加到容器
            container.addView(v);
            return v;
        }

    }


设置适配器

    MyPagerAdapter adapter = new MyPagerAdapter(list);
    //设置适配器
    mPager.setAdapter(adapter);

ViewPager页面滑动监听,需要使用OnPageChangeListener对象来监听

  
  // ViewPager的监听
    private ViewPager.OnPageChangeListener pageChange = 
    new ViewPager.OnPageChangeListener() {

        // 页面选中
        @Override
        public void onPageSelected(int position) {
            Log.e("m_tag", "onPageSelected:" + position);
        }

        // 界面滑动中(position表示滑动中第一个界面的下标,offset表示第一个界面在屏幕外的比例0-1,
        第三个参数表示在屏幕外的像素值)
        @Override
        public void onPageScrolled(int position, float offset,
                int offsetInPixels) {
            Log.e("m_tag", "onPageScrolled:" + position + " " + offset + " "
                    + offsetInPixels);
        }

        // 滑动的状态
        @Override
        public void onPageScrollStateChanged(int state) {
            Log.e("m_tag", "onPageScrollStateChanged:" + state);
        }
    };

设置监听
    
    mPager.setOnPageChangeListener(pageChange);
设置选中的位置

    mPager.setCurrentItem(index);


####    Fragment
碎片布局。android3.0之后的新功能,Fragment需要依赖于Activity而存在,不能独立使用。

   
 Fragment的定义
    public class LeftFragment extends ListFragment {
    private String[] items = { "字符串1", "字符串2", "字符串
    3", "字符串4", "字符串5", "字符串6" };

    // 监听到所依赖的Activity已经onCreate时触发
    @Override
    public void onActivityCreated(Bundle savedInstanceState) {
        super.onActivityCreated(savedInstanceState);
        //Fragment中可以通过getActivity()获取所依赖的Activity对象
        ArrayAdapter<String> adapter = new ArrayAdapter<String>(getActivity(),
                android.R.layout.simple_list_item_1, items);
        setListAdapter(adapter);
    }
    
    @Override
    public void onListItemClick(ListView l, View v, int position, long id) {
        Toast.makeText(getActivity(), "点击了"+position, 2000).show();
    }

    }



两种添加到Activity的方式

第一种:在xml中使用<fragment标签来引入

   
 <fragment
        android:layout_width="200dp"
        android:layout_height="match_parent" 
        android:name="com.xykj.fragmentdemo.LeftFragment"/>


注意:使用兼容包中的Fragment则需要使用兼容包中的Fragment管理器,在support v4中FragmentActivity中才有Fragment管理器

    public class MainActivity extends FragmentActivity

#####    Java中动态管理Fragment
1、定义Fragment
    
   
 public class RightFragment extends Fragment {

        public static RightFragment getInstance(String content,int position){
            RightFragment f = new RightFragment();
            Bundle b = new Bundle();
            b.putString("name", content);
            b.putInt("index",position);
            //记录一些初始参数(放在显示之前)
            f.setArguments(b);
            return f;
        }

        // 当Activity添加Fragment之后从该Fragment上获取布局的方法
        @Override
        public View onCreateView(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {
            View layout = inflater.inflate(R.layout.right_fragment_layout, null);
            TextView tv = (TextView) layout.findViewById(R.id.m_tx);
            String content = getArguments().getString("name");
            tv.setText(content);
            return layout;
    }
    
    }


2、使用FragmentManager和FragmentTransaction来操作Fragment,在Fragment中可以使用getFragmentManager()得到碎片管理器

    从布局中加载Fragment
    getFragmentManager().findFragmentById(R.id.content);

    //碎片操作工具(显示、隐藏、添加、移除、替换、绑定、取消绑定这样的管理)
    FragmentTransaction ft = getFragmentManager().beginTransaction();
    //设置操作动画
    ft.setCustomAnimations(android.R.anim.slide_in_left, android.R.anim.slide_out_right);
    //替换
    ft.replace(R.id.content, fragment);
    //提交操作
    ft.commit();
回退栈:可以在提交之前使用addToBackStack方法添加回退栈

    //可以添加操作到回退栈中
    ft.addToBackStack(null);
注意:FragmentTransaction的conmmit方法必须要在Activity保存状态之前使用,如果保存状态之后用则会导致异常,为了防止异常可以使用

    ft.commitAllowingStateLoss();
####    Fragment生命周期

    onAttach: Fragment被加入到Activity中时触发
    onCreate: Fragment创建完毕
    onCreateView: Activity从Fragment身上拿到布局时触发
    onActivityCreate: 当Activity的onCreate方法调用完毕时触发
    onStart: 启动
    onResume: 恢复
    运行ing...
    onPause: 暂停
    onStop: 停止
    onDestroyView:销毁布局
    onDestroy: 碎片进入销毁
    onDetach: fragment从Activity中移除(取消了关联)
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值