安卓开发25:碎片 Fragment使用
Fragment说明
为了解决不同屏幕分辩率的动态和灵活UI设计。大屏幕如平板小屏幕如手机,平板电脑的设计使得其有更多的空间来放更多的UI组件,而多出来的空间存放UI使其会产生更多的交互,从而诞生了fragment。fragments 的设计不需要你来亲自管理view hierarchy 的复杂变化,通过将Activity 的布局分散到frament 中,可以在运行时修改activity 的外观,并且由activity 管理的back stack 中保存些变化。
生命周期:
1.onAttach() 当Fragment附加到Activity上调用。
2.onCreate() Fragment初始化操作
3.onCreateView() 用于首次绘制用户界面的回调方法,必须返回要创建的Fragments 视图UI。假如你不希望提供Fragments 用户界面则可以返回NULL。
4.onActivityCreated() 父Activity和Fragment的UI都被完全创建完后调用。
5.onDestoryView() Fragment的UI被分离时调用。
6.onDatch() Fragment从父Activity身上分离的时候调用。
7.onPause() 当用户离开这个Fragments 的时候调用,这时你要提交任何应该持久的变化,因为用户可能不会回来。
通过XML布局方式将Fragment放进Activity中
MainActivity
package com.example.test.com; import android.app.Activity; import android.os.Bundle; import android.view.Window; public class MainActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); requestWindowFeature(Window.FEATURE_NO_TITLE); setContentView(R.layout.main); } }
main.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="700dp" android:layout_height="300dp" android:orientation="horizontal" android:padding="10dp" > <!-- 通过name指定 TestFragment --> <fragment android:id="@+id/fragment1" android:name="com.example.test.com.TestFragment" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginBottom="52dp"/> </RelativeLayout>
TestFragment
package com.example.test.com; import android.app.Fragment; import android.os.Bundle; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; /** * 一个测试的Fragment * @author zhuli.zhul * @date 2013 2013-8-23 下午6:44:22 */ public class TestFragment extends Fragment { /** * 显示页面 */ @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { super.onCreateView(inflater, container, savedInstanceState); return inflater.inflate(R.layout.test_f, container, false); //指定test_f layout } }
test_f.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="700dp" android:layout_height="300dp" android:orientation="horizontal" android:padding="10dp" > <Button android:id="@+id/button1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentLeft="true" android:layout_centerVertical="true" android:layout_marginLeft="148dp" android:text="Button" /> </RelativeLayout>
说明:
使用这种xml中指定Fragment的方法,有一种缺陷就是不能再Java代码中动态修改Fragment。下面我们会有一种通过Java代码动态控制Fragment的简单例子。
动态添加和控制Fragment
MainActivity
package com.example.test.com; import android.app.Activity; import android.app.FragmentManager; import android.app.FragmentTransaction; import android.os.Bundle; import android.view.Window; public class MainActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); requestWindowFeature(Window.FEATURE_NO_TITLE); setContentView(R.layout.main); //通过fragmentManager 就可以动态新增一个Fragment FragmentManager fragmentManager = getFragmentManager(); FragmentTransaction fTransaction = fragmentManager.beginTransaction(); fTransaction.add(R.id.frame, new TestFragment()); //新增 //Fragment fragment = fragmentManager.findFragmentById(R.id.frame); //通过id查找 //fTransaction.remove(fragment); //删除 //fTransaction.replace(R.id.frame, new TestFragment()); //替换 fTransaction.commit(); //提交 } }
main.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="700dp" android:layout_height="300dp" android:orientation="horizontal" android:padding="10dp" > <!-- 这个是可以动态修改的FrameLayout --> <FrameLayout android:id="@+id/frame" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentLeft="true" android:layout_alignParentTop="true" android:layout_marginLeft="106dp" android:layout_marginTop="92dp" > </FrameLayout> </RelativeLayout>
TestFragment
package com.example.test.com; import android.app.Fragment; import android.os.Bundle; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; /** * 一个测试的Fragment * @author zhuli.zhul * @date 2013 2013-8-23 下午6:44:22 */ public class TestFragment extends Fragment { /** * 显示页面 */ @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { super.onCreateView(inflater, container, savedInstanceState); return inflater.inflate(R.layout.test_f, container, false); //指定test_f layout } }
test_f.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="700dp" android:layout_height="300dp" android:orientation="horizontal" android:padding="10dp" > <Button android:id="@+id/button1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentLeft="true" android:layout_centerVertical="true" android:layout_marginLeft="148dp" android:text="Button2" /> </RelativeLayout>
说明:
效果是一样的,但是可以动态添加删除以及隐藏显示等操作。