今天继续完成剩下的学习部分,现在项目很多地方使用viewpager来提供滑动,今天记录学习viewpager配合fragment的显示,增加一个CallLogsFragment配合之前SMSListFragment
1.CallLogsFragment,主要显示手机的电话记录,这都是之前的代码,所以只要把Activity转换成Fragment就可以了,也一样, 
Activity.setContentView(int) 转变成Fragment.onCreateView(View) 并且 findViewById也在里面了
Activity.onCreate() 代码 转成  Fragment.onActivityCreated()中
Activity.onResume() 代码 转成 Fragment.onResume() 中

代码如下:

  1. public class CallLogsFragment extends Fragment{
  2. private ListView vList;
  3. private CallPanelView vDial;
  4. private TextView vShowDial;
  5. private CallListAdapter mAdapter;
  6. private Animation mDialHidAnim;
  7. private Animation mDialShowAnim;
  8. @Override
  9. public View onCreateView(LayoutInflater inflater, ViewGroup container,
  10. Bundle savedInstanceState) {
  11. // TODO Auto-generated method stub
  12. View root = inflater.inflate(R.layout.activity_calls_list_screen, null);
  13. vList = (ListView) root.findViewById(R.id.activity_call_list_lv);
  14. vShowDial = (TextView) root.findViewById(R.id.activity_call_show_dial);
  15. vDial = (CallPanelView) root.findViewById(R.id.dial_panel_view);
  16. return root;
  17. }
  18. @Override
  19. public void onActivityCreated(Bundle savedInstanceState) {
  20. // TODO Auto-generated method stub
  21. super.onActivityCreated(savedInstanceState);
  22. prepareResourceAndData();
  23. bindView();
  24. }
  25. @Override
  26. public void onResume() {
  27. // TODO Auto-generated method stub
  28. super.onResume();
  29. mAdapter.setCallNumbers(CallCache.getInstance().getCallNumbers());
  30. }
  31. private void prepareResourceAndData() {
  32. mAdapter = new CallListAdapter(getActivity());
  33. mDialHidAnim = AnimationUtils.loadAnimation(getActivity().getApplicationContext(),
  34. R.anim.dial_panel_hidden);
  35. mDialHidAnim.setAnimationListener(new AnimationListener() {
  36. public void onAnimationStart(Animation animation) {}
  37. public void onAnimationRepeat(Animation animation) {}
  38. public void onAnimationEnd(Animation animation) {
  39. // End
  40. vShowDial.setVisibility(View.VISIBLE);
  41. vDial.setVisibility(View.GONE);
  42. }
  43. });
  44. mDialShowAnim = AnimationUtils.loadAnimation(getActivity().getApplicationContext(),
  45. R.anim.dial_panel_show);
  46. mDialShowAnim.setAnimationListener(new AnimationListener() {
  47. public void onAnimationStart(Animation animation) {}
  48. public void onAnimationRepeat(Animation animation) {}
  49. public void onAnimationEnd(Animation animation) {
  50. // End
  51. vShowDial.setVisibility(View.GONE);
  52. }
  53. });
  54. }
  55. private void bindView() {
  56. vList.setAdapter(mAdapter);
  57. vList.setOnItemClickListener(new OnItemClickListener() {
  58. @Override
  59. public void onItemClick(AdapterView<?> parent, View view,
  60. int position, long id) {
  61. // TODO Auto-generated method stub
  62. CallItemView itemview = (CallItemView) view;
  63. itemview.toggleExpand();
  64. hidDialPanel(true);
  65. }
  66. });
  67. vList.setOnScrollListener(new OnScrollListener() {
  68. public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {}
  69. @Override
  70. public void onScrollStateChanged(AbsListView view, int scrollState) {
  71. // TODO Auto-generated method stub
  72. if (scrollState == OnScrollListener.SCROLL_STATE_TOUCH_SCROLL) {
  73. hidDialPanel(false);
  74. }
  75. }
  76. });
  77. vDial.setPanelAnim(mDialShowAnim, mDialHidAnim);
  78. vShowDial.setVisibility(View.GONE);
  79. vShowDial.setOnClickListener(new OnClickListener() {
  80. @Override
  81. public void onClick(View v) {
  82. // TODO Auto-generated method stub
  83. vDial.show();
  84. }
  85. });
  86. }
  87. private void hidDialPanel(boolean anim) {
  88. if (vDial.getVisibility() == View.VISIBLE) {
  89. if(anim){
  90. vDial.dismiss();
  91. }else{
  92. vDial.setVisibility(View.GONE);
  93. vShowDial.setVisibility(View.VISIBLE);
  94. }
  95. }
  96. }
  97. }
  98. }

2.对昨天主页面布局修改,增加ViewPager,去掉原有的容器framelayout:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <
  3. <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
  4. android:id="@+id/door_root_content_fl"
  5. android:layout_width="match_parent"
  6. android:layout_height="match_parent" >
  7. <LinearLayout
  8. android:layout_width="match_parent"
  9. android:layout_height="match_parent"
  10. android:orientation="vertical" >
  11. <android.support.v4.view.ViewPager
  12. android:id="@+id/door_viewpager_content_vp"
  13. android:layout_width="match_parent"
  14. android:layout_height="0dp"
  15. android:layout_weight="1" />
  16. <LinearLayout
  17. android:layout_width="match_parent"
  18. android:layout_height="55dp"
  19. android:orientation="horizontal" >
  20. <Button
  21. android:id="@+id/door_menu_btn"
  22. android:layout_width="match_parent"
  23. android:layout_height="match_parent"
  24. android:gravity="center"
  25. android:text="菜单" />
  26. </LinearLayout>
  27. </LinearLayout>
  28. <
  29. </FrameLayout>

3.V4 support 包里面已经帮我们写好了 FragmentPagerAdapter,看源码可以知道在 PageAdapter.instantiateItem中,有:

  1. Fragment fragment = mFragmentManager.findFragmentByTag(name);
  2. if (fragment != null) {
  3. if (DEBUG) Log.v(TAG, "Attaching item #" + itemId + ": f=" + fragment);
  4. mCurTransaction.attach(fragment);
  5. } else {
  6. fragment = getItem(position);
  7. if (DEBUG) Log.v(TAG, "Adding item #" + itemId + ": f=" + fragment);
  8. mCurTransaction.add(container.getId(), fragment,
  9. makeFragmentName(container.getId(), itemId));
  10. }

可以看出
ViewPager在添加fragment
的时候先在FragmentManager里面找有没有,如果没有就会去请求PageAdapter.getItem(position)来生成
fragment,进行添加,因此我们只要重写FragmentPagerAdapter并实现getItem方法就可以了,代码如下:

  1. class FragmentAdapter extends FragmentPagerAdapter{
  2. public FragmentAdapter(FragmentManager fm) {
  3. super(fm);
  4. // TODO Auto-generated constructor stub
  5. }
  6. @Override
  7. public Fragment getItem(int position) {
  8. // TODO Auto-generated method stub
  9. return getPagerFragmentByPosition(position);
  10. }
  11. @Override
  12. public int getCount() {
  13. // TODO Auto-generated method stub
  14. return 2;
  15. }
  16. }private Fragment getPagerFragmentByPosition(int position){
  17. if(position == FRAG_INDEX_CALL_LOG){
  18. return new CallLogsFragment();
  19. }
  20. if(position == FRAG_INDEX_SMS){
  21. return new SMSListFragment();
  22. }
  23. return null;
  24. }

4.页面完整代码:

  1. public class DoorFragmentActivity extends FragmentActivity{
  2. public static final String FRAG_SMS = "sms_list_frag";
  3. public static final String FRAG_TEXT = "text_frag";
  4. public static final int FRAG_INDEX_CALL_LOG = 0;
  5. public static final int FRAG_INDEX_SMS = 1;
  6. private Fragment mTextFragment;
  7. private FragmentManager mFragMgr;
  8. private ViewPager vViewPager;
  9. private Button mMenuBtn;
  10. @Override
  11. protected void onCreate(Bundle savedInstanceState) {
  12. // TODO Auto-generated method stub
  13. super.onCreate(savedInstanceState);
  14. setContentView(R.layout.door_fragment_activity_layout);
  15. initFragments();
  16. bindViews();
  17. }
  18. private void bindViews(){
  19. mMenuBtn = (Button) findViewById(R.id.door_menu_btn);
  20. mMenuBtn.setOnClickListener(new OnClickListener() {
  21. @Override
  22. public void onClick(View v) {
  23. // TODO Auto-generated method stub
  24. showOutFragments(FRAG_TEXT, true);
  25. }
  26. });
  27. vViewPager = (ViewPager) findViewById(R.id.door_viewpager_content_vp);
  28. vViewPager.setAdapter(new FragmentAdapter(mFragMgr));
  29. }
  30. private void initFragments(){
  31. mFragMgr = getSupportFragmentManager();
  32. TextFragment textfrag = new TextFragment();
  33. textfrag.setMessage("这是 菜单界面");
  34. mTextFragment = textfrag;
  35. }
  36. private void showOutFragments(String tag, boolean needback){
  37. FragmentTransaction trans = mFragMgr.beginTransaction();
  38. trans.setCustomAnimations(R.anim.frag_enter,
  39. R.anim.frag_exit);
  40. trans.add(R.id.door_root_content_fl, getFragmentByTag(tag), tag);
  41. if(needback){
  42. trans.addToBackStack(tag);
  43. }
  44. trans.commit();
  45. }
  46. private Fragment getFragmentByTag(String tag){
  47. if(FRAG_TEXT.equals(tag)){
  48. return mTextFragment;
  49. }
  50. return null;
  51. }
  52. private Fragment getPagerFragmentByPosition(int position){
  53. if(position == FRAG_INDEX_CALL_LOG){
  54. return new CallLogsFragment();
  55. }
  56. if(position == FRAG_INDEX_SMS){
  57. return new SMSListFragment();
  58. }
  59. return null;
  60. }
  61. class FragmentAdapter extends FragmentPagerAdapter{
  62. public FragmentAdapter(FragmentManager fm) {
  63. super(fm);
  64. // TODO Auto-generated constructor stub
  65. }
  66. @Override
  67. public Fragment getItem(int position) {
  68. // TODO Auto-generated method stub
  69. return getPagerFragmentByPosition(position);
  70. }
  71. @Override
  72. public int getCount() {
  73. // TODO Auto-generated method stub
  74. return 2;
  75. }
  76. }
  77. }
  78. }

5.效果图,左右滑动显示通话记录和短信:

    1. <pre code_snippet_id="94266" snippet_file_name="blog_20131203_4_3649255"></pre>
    2. <pre></pre>

Fragment 和 FragmentActivity的使用(二)的更多相关文章

  1. Fragment和FragmentActivity的使用方法

    认识:首先我们知道Fragment是我们在单个Activity上要切换多个UI界面,显示不同内容.模块化这些UI面板以便提供给其他Acitivity使用便利.同时我们显示的Fragment也会受到当前 ...

  2. Fragment与FragmentActivity的关系

    前阵用viewpaper+fragment做滑动引导,查阅了下网上的资料,发现在有两种做法,一个是自建类直接继承Activity另一种是继承FragmentActivity,很是迷惑,在查了些goog ...

  3. Fragment 和 FragmentActivity的使用

    Fragment 和 FragmentActivity的使用 http://blog.csdn.net/izy0001989624/article/details/17072211

  4. Fragment与FragmentActivity通信封装

    在项目里面会经常用到Fragment与FragmentActivity,比如Fragment之间的界面切换与Fragment之间的值传递等等,为了方便起见我把Fragment和FragmentActi ...

  5. 转 Fragment 和 FragmentActivity的使用

    今天学习下 Android中的 Fragment 和 FragmentActivity,因为没有4.0手机,平台是2.3.3 所以我是使用 v4 support 包来进行学习. 要想用Fragment ...

  6. ☆ fragment和fragmentactivity解析 (转)

    一.为什么要使用Fragment  1.当我们需要动态的多界面切换的时候,就需要将UI元素和Activity融合成一 个模块.在2.3中我们一般通过各种Activity中进行跳转来实现多界面的跳转和单 ...

  7. Android Fragment和FragmentActivity区别和用法

    Android Fragment是Android4.0以上才有的:而FragmentActivity是为了兼容4.0以下版本的Fragment使用的. 所以如果你想兼容4.0以下Android版本使用 ...

  8. fragment和fragmentactivity解析

    一.为什么要使用Fragment  1.当我们须要动态的多界面切换的时候,就须要将UI元素和Activity融合成一个模块.在2.3中我们一般通过各种Activity中进行跳转来实现多界面的跳转和单个 ...

  9. Android组件内核之Fragment管理与内核(二)

    阿里P7Android高级架构进阶视频免费学习请点击:https://space.bilibili.com/474380680本篇文章将先从以下三个内容来介绍Fragment管理与内核: [Fragm ...

随机推荐

  1. 使用libuv实现生产者和消费者模式

    生产者和消费者模式(Consumer + Producer model) 用于把耗时操作(生产线程),分配给一个或者多个额外线程执行(消费线程),从而提高生产线程的响应速度(并发能力) 定义 type ...

  2. easyui的datagrid和panel如何让标题动态改变?

    解决方法: 用$(this).datagrid("getPanel").panel("setTitle","new title").$(th ...

  3. Careercup - Google面试题 - 5205167846719488

    2014-05-03 23:35 题目链接 原题: For a given node in binary search tree find a next largest number in searc ...

  4. [resource]23个python的机器学习包

    23个python的机器学习包,从常见的scikit-learn, pylearn2,经典的matlab替代orange, 到最新最酷的Theano(深度学习)和torch 7 (well,其实lua ...

  5. PAT-乙级-1052. 卖个萌 (20)

    1052. 卖个萌 (20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 萌萌哒表情符号通常由“手”.“眼”. ...

  6. jsp java 数据库 乱码总结

    Java中文问题的由来: Java的内核和class文件是基于unicode的,这使Java程序具有良好的跨平台性,但也带来了一些中文乱码问题的麻烦.原因主要有两方面,Java和JSP文件本身编译时产 ...

  7. poj 3620 Avoid The Lakes(广搜,简单)

    题目 找最大的一片湖的面积,4便有1边相连算相连,4角不算. runtime error 有一种可能是 数组开的太小,越界了 #define _CRT_SECURE_NO_WARNINGS #incl ...

  8. 深入浅出ES6(二):迭代器和for-of循环

    作者 Jason Orendorff  github主页  https://github.com/jorendorff 我们如何遍历数组中的元素?20年前JavaScript刚萌生时,你可能这样实现数 ...

  9. Mysql 1030 Got error -1 from storage engine 错误解决

    检查你的my.cnf或my.ini,里面会有一个参数innodb_force_recovery,你看看他的值,默认是没有这个参数,没有的话,他的默认值是0,这个参数的值如果大于0,innodb会被禁止 ...

  10. 深入浅出Java并发包—锁机制(三)

    接上文<深入浅出Java并发包—锁机制(二)>  由锁衍生的下一个对象是条件变量,这个对象的存在很大程度上是为了解决Object.wait/notify/notifyAll难以使用的问题. ...