ImageVerifierCode 换一换
格式:DOCX , 页数:17 ,大小:185.61KB ,
资源ID:6497819      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/6497819.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(Android Fragment实现.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

Android Fragment实现.docx

1、Android Fragment实现Android手机平板使用Fragment实现兼容手机和平板的程序我们先来看一下Android手机的设置界面,点击一下Sound,可以跳转到声音设置界面,如下面两张图所示:然后再来看一下Android Pad的设置界面,主设置页面和声音设置页面都是在一个界面显示的,如下图所示:如果这分别是两个不同的App做出的效果,那没有丝毫惊奇之处。但如果是同一个App,在手机上和平板上运行分别有以上两种效果的话,你是不是就已经心动了?我们现在就来模拟实现一下。首先你需要对Fragment有一定的了解,如果你还没接触过Fragment,建议可以先阅读 Android Fr

2、agment完全解析,关于碎片你所需知道的一切 这篇文章。并且本次的代码是运行在Android 4.0版本上的,如果你的SDK版本还比较低的话,建议可以先升升级了。新建一个Android项目,取名叫FragmentDemo。打开或新建MainActivity作为程序的主Activity,里面有如下自动生成的内容:1. java view plaincopyprint?2. public class MainActivity extends Activity 3. Override4. public void onCreate(Bundle savedInstanceState) 5. supe

3、r.onCreate(savedInstanceState);6. setContentView(R.layout.activity_main);7. 8. 复制代码作为一个Android老手,上面的代码实在太小儿科了,每个Activity中都会有这样的代码。不过今天我们的程序可不会这么简单,加载布局这一块还是大有文章的。打开或新建res/layout/activity_main.xml作为程序的主布局文件,里面代码如下:1. html view plaincopyprint?2. 3. xmlns:tools=4. android:layout_width=fill_parent5. and

4、roid:layout_height=fill_parent6. android:orientation=horizontal7. tools:context=.MainActivity 8. 9. android:id=+id/menu_fragment10. android:name=com.example.fragmentdemo.MenuFragment11. android:layout_width=fill_parent12. android:layout_height=fill_parent13. /14. 15. 这个布局引用了一个MenuFragment,我们稍后来进行实现,

5、先来看一下今天的一个重点,我们需要再新建一个activity_main.xml,这个布局文件名和前面的主布局文件名是一样的,但是要放在不同的目录下面。16. 在res目录下新建layout-large目录,然后这个目录下创建新的activity_main.xml,加入如下代码:17. html view plaincopyprint?18. 19. xmlns:tools=20. android:layout_width=fill_parent21. android:layout_height=fill_parent22. android:orientation=horizontal23. a

6、ndroid:baselineAligned=false24. tools:context=.MainActivity25. 26. 27. android:id=+id/left_fragment28. android:name=com.example.fragmentdemo.MenuFragment29. android:layout_width=0dip30. android:layout_height=fill_parent31. android:layout_weight=132. /33. 34. android:id=+id/details_layout35. android:

7、layout_width=0dip36. android:layout_height=fill_parent37. android:layout_weight=338. 复制代码这个布局同样也引用了MenuFragment,另外还加入了一个FrameLayout用于显示详细内容。其实也就是分别对应了平板界面上的左侧布局和右侧布局。这里用到了动态加载布局的技巧,首先Activity中调用 setContentView(R.layout.activity_main) ,表明当前的Activity想加载activity_main这个布局文件。而Android系统又会根据当前的运行环境判断程序是否运行

8、在大屏幕设备上,如果运行在大屏幕设备上,就加载layout-large目录下的activity_main.xml,否则就默认加载layout目录下的activity_main.xml。关于动态加载布局的更多内容,可以阅读 Android官方提供的支持不同屏幕大小的全部方法 这篇文章。下面我们来实现久违的MenuFragment,新建一个MenuFragment类继承自Fragment,具体代码如下:1. java view plaincopyprint?2. public class MenuFragment extends Fragment implements OnItemClickLis

9、tener 3. /*4. * 菜单界面中只包含了一个ListView。5. */6. private ListView menuList;7. /*8. * ListView的适配器。9. */10. private ArrayAdapter adapter;11. /*12. * 用于填充ListView的数据,这里就简单只用了两条数据。13. */14. private String menuItems = Sound, Display ;15. /*16. * 是否是双页模式。如果一个Activity中包含了两个Fragment,就是双页模式。17. */18. private boo

10、lean isTwoPane;19. /*20. * 当Activity和Fragment建立关联时,初始化适配器中的数据。21. */22. Override23. public void onAttach(Activity activity) 24. super.onAttach(activity);25. adapter = new ArrayAdapter(activity, android.R.layout.simple_list_item_1, menuItems);26. 27. /*28. * 加载menu_fragment布局文件,为ListView绑定了适配器,并设置了监听

11、事件。29. */30. Override31. public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) 32. View view = inflater.inflate(R.layout.menu_fragment, container, false);33. menuList = (ListView) view.findViewById(R.id.menu_list);34. menuList.setAdapter(adapter);35. menuL

12、ist.setOnItemClickListener(this);36. return view;37. 38. /*39. * 当Activity创建完毕后,尝试获取一下布局文件中是否有details_layout这个元素,如果有说明当前40. * 是双页模式,如果没有说明当前是单页模式。41. */42. Override43. public void onActivityCreated(Bundle savedInstanceState) 44. super.onActivityCreated(savedInstanceState);45. if (getActivity().findV

13、iewById(R.id.details_layout) != null) 46. isTwoPane = true;47. else 48. isTwoPane = false;49. 50. 51. /*52. * 处理ListView的点击事件,会根据当前是否是双页模式进行判断。如果是双页模式,则会动态添加Fragment。53. * 如果不是双页模式,则会打开新的Activity。54. */55. Override56. public void onItemClick(AdapterView arg0, View view, int index, long arg3) 57. if

14、(isTwoPane) 58. Fragment fragment = null;59. if (index = 0) 60. fragment = new SoundFragment();61. else if (index = 1) 62. fragment = new DisplayFragment();63. 64. getFragmentManager().beginTransaction().replace(R.id.details_layout, fragment).commit();65. else 66. Intent intent = null;67. if (index

15、= 0) 68. intent = new Intent(getActivity(), SoundActivity.class);69. else if (index = 1) 70. intent = new Intent(getActivity(), DisplayActivity.class);71. 72. startActivity(intent);73. 74. 75. 复制代码这个类的代码并不长,我简单的说明一下。在onCreateView方法中加载了menu_fragment这个布局,这个布局里面包含了一个ListView,然后我们对这个ListView填充了两个简单的数据 S

16、ound 和 Display 。又在onActivityCreated方法中做了一个判断,如果Activity的布局中包含了details_layout这个元素,那么当前就是双页模式,否则就是单页模式。onItemClick方法则处理了ListView的点击事件,发现如果当前是双页模式,就动态往details_layout中添加Fragment,如果当前是单页模式,就直接打开新的Activity。我们把MenuFragment中引用到的其它内容一个个添加进来。新建menu_fragment.xml文件,加入如下代码:1. html view plaincopyprint?2. 3. 4. an

17、droid:layout_width=fill_parent5. android:layout_height=fill_parent 6. 7. android:id=+id/menu_list8. android:layout_width=fill_parent9. android:layout_height=fill_parent10. 复制代码然后新建SoundFragment,里面内容非常简单:1. java view plaincopyprint?2. public class SoundFragment extends Fragment 3. Override4. public V

18、iew onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) 5. View view = inflater.inflate(R.layout.sound_fragment, container, false);6. return view;7. 8. 复制代码这里SoundFragment需要用到sound_fragment.xml布局文件,因此这里我们新建这个布局文件,并加入如下代码:1. html view plaincopyprint?2. 3. 7. 复制代码同样的道

19、理,我们再新建DisplayFragment和display_fragment.xml布局文件:1. java view plaincopyprint?2. public class DisplayFragment extends Fragment 3. public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) 4. View view = inflater.inflate(R.layout.display_fragment, container, fals

20、e);5. return view;6. 7. 8. html view plaincopyprint?9. 10. 14. 复制代码然后新建SoundActivity,代码如下:1. java view plaincopyprint?2. public class SoundActivity extends Activity 3. Override4. protected void onCreate(Bundle savedInstanceState) 5. super.onCreate(savedInstanceState);6. setContentView(R.layout.sound

21、_activity);7. 8. 复制代码这个Activity只是加载了一个布局文件,现在我们来实现sound_activity.xml这个布局文件:1. html view plaincopyprint?2. 3. 7. 复制代码这个布局文件引用了SoundFragment,这样写的好处就是,以后我们只需要在SoundFragment中修改代码,SoundActivity就会跟着自动改变了,因为它所有的代码都是从SoundFragment中引用过来的。好,同样的方法,我们再完成DisplayActivity:1. java view plaincopyprint?2. public clas

22、s DisplayActivity extends Activity 3. Override4. protected void onCreate(Bundle savedInstanceState) 5. super.onCreate(savedInstanceState);6. setContentView(R.layout.display_activity);7. 8. 复制代码然后加入display_activity.xml:1. html view plaincopyprint?2. 3. 复制代码现在所有的代码就都已经完成了,我们来看一下效果吧。首先将程序运行在手机上,效果图如下:分别点击Sound和Display,界面会跳转到声音和显示界面:然后将程序在平板上运行,点击Sound,效果图如下:然后点击Display切换到显示界面,效果图如下:这样我们就成功地让程序同时兼容手机和平板了。当然,这只是一个简单的demo,更多复杂的内容需要大家自己去实现了。

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1