导入兼容包

来源:互联网 发布:安纳金·天行者知乎 编辑:程序博客网 时间:2024/06/06 06:38
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中移除(取消了关联)
1 0
原创粉丝点击