摘要:必須嵌套在中,其生命周期受生命周期的影響。利用實現此類設計時,您無需管理對視圖層次結構的復雜更改。您應該將每個都設計為可重復使用的模塊化組件。使用與進行交互開啟事務將填充到創建的容器中提交事務。
極力推薦文章:歡迎收藏
Android 干貨分享
本篇文章主要介紹 Android 開發中的部分知識點,通過閱讀本篇文章,您將收獲以下內容:
Fragment 的設計原理
Fragment 的生命周期
Fragment 在宿主Activity 中的生命周期
Fragment 在Activity 中的使用方法
Activity獲取 Fragment 的方法
Fragment 獲取宿主Activity 的方法
兩個Fragment 通訊的方法
Fragment 與Activity 通訊方法
Fragment 片段,在Activity 中常用于負責用戶界面部分,可以將多個Fragment 組合在一個Activity中來創建多窗口UI,或者在Activity中重復使用某個Fragment。您可以將Fragment 視為Activity的模塊化組成部分,Fragment 具有自己的生命周期,能接收自己的輸入事件,并且可以在Activity 運行時候添加或者移除Fragment。
Fragment 必須嵌套在Activity中,其生命周期受Activity生命周期的影響。
Fragment 簡介 Fragment 繼承關系如下:java.lang.Object ???? android.app.Fragment1. Fragment的設計原理
Fragment 主要是為了給大屏幕(平板等)上更加動態和靈活的UI設計提供支持。由于平板電腦的屏幕比手機屏幕大得多,因此可用于組合和交換UI 組件的空間更大。利用Fragment 實現此類設計時,您無需管理對視圖層次結構的復雜更改。 通過將 Activity 布局分成Fragment,您可以在運行時修改 Activity 的外觀,并在由 Activity 管理的返回棧中保留這些更改。
您應該將每個Fragment都設計為可重復使用的模塊化 Activity 組件。也就是說,由于每個Fragment 都會通過各自的生命周期回調來定義其自己的布局和行為,您可以將一Fragment加入多個 Activity,因此,您應該采用可復用式設計,避免直接從某個Fragment直接操縱另一個Fragment。 這特別重要,因為模塊化片段讓您可以通過更改Fragment的組合方式來適應不同的屏幕尺寸。 在設計可同時支持平板電腦和手機的應用時,您可以在不同的布局配置中重復使用您的Fragment,以根據可用的屏幕空間優化用戶體驗。 例如,在手機上,如果不能在同一 Activity 內儲存多個片段,可能必須利用多帶帶片段來實現單窗格 UI。
2.Fragment 生命周期Fragment生命周期圖
Fragment 生命周期回調方法
public void onAttach(Context context) { // TODO Auto-generated method stub Log.i(TAG, "----onAttach----"); super.onAttach(context); } @Override public void onCreate(Bundle savedInstanceState) { Log.i(TAG, "----onCreate----"); // 在Fragment 中調用Activity 中的方法 ((FragmentAutoCreate) getActivity()).test(); // TODO Auto-generated method stub super.onCreate(savedInstanceState); } @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { Log.i(TAG, "----onCreateView----"); // 將layout布局轉換成View View view = inflater.inflate(R.layout.fragment_left_layout, null); Toast.makeText(getActivity(), "通過對外提供方法setMsg(String msg),供Activity 調用", 0).show(); return view; } @Override public void onActivityCreated(Bundle savedInstanceState) { Log.i(TAG, "----onActivityCreated----"); // TODO Auto-generated method stub super.onActivityCreated(savedInstanceState); } @Override public void onStart() { Log.i(TAG, "----onStart----"); // TODO Auto-generated method stub super.onStart(); } @Override public void onResume() { Log.i(TAG, "----onResume----"); // TODO Auto-generated method stub super.onResume(); } @Override public void onPause() { Log.i(TAG, "----onPause----"); // TODO Auto-generated method stub super.onPause(); } @Override public void onStop() { Log.i(TAG, "----onStop----"); // TODO Auto-generated method stub super.onStop(); } @Override public void onDestroyView() { Log.i(TAG, "----onDestroyView----"); // TODO Auto-generated method stub super.onDestroyView(); } @Override public void onDestroy() { Log.i(TAG, "----onDestroy----"); // TODO Auto-generated method stub super.onDestroy(); } @Override public void onDetach() { Log.i(TAG, "----onDetach----"); // TODO Auto-generated method stub super.onDetach(); }3.Fragment 在宿主Activity 的生命周期
Fragment 不能脫離Activity而存在,其生命周期受Activity 生命周期影響
實現方法如下
public class FragmentRight extends Fragment { @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { // 將layout布局轉換成View View view = inflater.inflate(R.layout.fragment_right_layout, null); // 取出值 Bundle values = getArguments(); if (values != null) { String str = values.getString("key", ""); Toast.makeText(getActivity(), "接收Activity傳遞的至為:" + str, 0).show(); } else { Toast.makeText(getActivity(), "接收Activity傳遞的至為空", 0).show(); } return view; } }2.在Activity 的xml中引用
2. 動態添加Fragment到Activity中 1.創建自定義Fragment類 同上
public class FragmentRight extends Fragment { @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { // 將layout布局轉換成View View view = inflater.inflate(R.layout.fragment_right_layout, null); // 取出值 Bundle values = getArguments(); if (values != null) { String str = values.getString("key", ""); Toast.makeText(getActivity(), "接收Activity傳遞的至為:" + str, 0).show(); } else { Toast.makeText(getActivity(), "接收Activity傳遞的至為空", 0).show(); } return view; } }2.創建Fragment填充布局載體
3.使用FragmentManager動態填充
1.創建容器接收Fragment 的 Activity容器。
2.使用FragmentManager與Fragment 進行交互
3.開啟事務將Fragment 填充到Activity 創建的容器中
4.提交事務。
public class FragmentAutoCreate extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { // TODO Auto-generated method stub super.onCreate(savedInstanceState); setContentView(R.layout.activity_fragment_autocreate); // 獲取fragmentManager --->開啟事務--->容器中填充內容--->提交事務 // FragmentManager : Activity 內部用來與Fragment進行交互的接口 FragmentManager fragmentManager = getFragmentManager(); // 開啟一個事務 FragmentTransaction transaction = fragmentManager.beginTransaction(); // 將左右兩側的Fragment 添加的R.id.fl_left 所代表的容器視圖中 FragmentLeft leftFragment = new FragmentLeft(); transaction.add(R.id.fl_left, leftFragment, "left_tag"); // 1. 調用 Fragment 對外提供的方法 leftFragment.setMsg("tttt"); FragmentRight rightFragment = new FragmentRight(); // 2. Activity --setArguments-> 創值給Fragment Bundle args = new Bundle(); args.putString("key", "Activity --setArguments-> 創值給Fragment "); // 傳遞數據 rightFragment.setArguments(args); transaction.add(R.id.fl_right, rightFragment); // transaction.replace(R.id.fl_right, rightFragment); // transaction.hide(rightFragment); transaction.show(rightFragment); // 提交事務 transaction.commit(); } public void test() { } }5.Activity 中獲取Fragment
Fragment idFragment=getFragmentManager().findFragmentById(R.id.fl_left); FragmentRight tagFragment = (FragmentRight) getFragmentManager().findFragmentByTag("left_tag");6.Fragment 獲取宿主Activity的方法
getActivity() 方法獲取宿主Activity
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { Log.i(TAG, "----onCreateView----"); // 將layout布局轉換成View View view = inflater.inflate(R.layout.fragment_left_layout, null); Toast.makeText(getActivity(), "通過對外提供方法setMsg(String msg),供Activity 調用", 0).show(); return view; }7.兩個Fragment的通訊的方法
通過宿主Activity 到FragmentManger 方法獲取不同的Fragment
Fragment idFragment=getFragmentManager().findFragmentById(R.id.fl_left); FragmentRight tagFragment = (FragmentRight) getFragmentManager().findFragmentByTag("left_tag");8.Fragment 與 Activity通訊方法 1.Activity 調用 setArguments 方法
public class FragmentAutoCreate extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { // TODO Auto-generated method stub super.onCreate(savedInstanceState); setContentView(R.layout.activity_fragment_autocreate); // 獲取fragmentManager --->開啟事務--->容器中填充內容--->提交事務 // FragmentManager : Activity 內部用來與Fragment進行交互的接口 FragmentManager fragmentManager = getFragmentManager(); // 開啟一個事務 FragmentTransaction transaction = fragmentManager.beginTransaction(); // 將左右兩側的Fragment 添加的R.id.fl_left 所代表的容器視圖中 FragmentLeft leftFragment = new FragmentLeft(); transaction.add(R.id.fl_left, leftFragment, "left_tag"); // 1. 調用 Fragment 對外提供的方法 leftFragment.setMsg("tttt"); FragmentRight rightFragment = new FragmentRight(); // 2. Activity --setArguments-> 創值給Fragment Bundle args = new Bundle(); args.putString("key", "Activity --setArguments-> 創值給Fragment "); // 傳遞數據 rightFragment.setArguments(args); transaction.add(R.id.fl_right, rightFragment); // transaction.replace(R.id.fl_right, rightFragment); // transaction.hide(rightFragment); transaction.show(rightFragment); // 提交事務 transaction.commit(); } public void test() { } }2.通過Fragment 對外提供接口方法
通過Fragment 對外提供接口方法,供Activity調用
public class FragmentLeft extends Fragment { private static final String TAG = " F wj"; private String mMessage; public void setMsg(String msg) { this.mMessage = msg; } @Override public void onCreate(Bundle savedInstanceState) { Log.i(TAG, "----onCreate----"); // 在Fragment 中調用Activity 中的方法 ((FragmentAutoCreate) getActivity()).test(); // TODO Auto-generated method stub super.onCreate(savedInstanceState); } @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { Log.i(TAG, "----onCreateView----"); // 將layout布局轉換成View View view = inflater.inflate(R.layout.fragment_left_layout, null); Toast.makeText(getActivity(), "通過對外提供方法setMsg(String msg),供Activity 調用", 0).show(); return view; }
至此,本篇已結束,如有不對的地方,歡迎您的建議與指正。同時期待您的關注,感謝您的閱讀,謝謝!
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/75847.html
摘要:保存路徑如下包名包名使用方法一般在文件夾中創建文件來對進行布局,布局文件中通常使用容器,包含多個控件,可以設置分類標題。在之前需要繼承此方法不是太推薦使用,已被啟用,之后更高版本,則需要繼承,使用控制布局,然后實現不同控件的處理事件。 showImg(https://segmentfault.com/img/remote/1460000019975019?w=157&h=54); 極力...
閱讀 1987·2021-09-26 10:19
閱讀 3262·2021-09-24 10:25
閱讀 1649·2019-12-27 11:39
閱讀 1933·2019-08-30 15:43
閱讀 675·2019-08-29 16:08
閱讀 3512·2019-08-29 16:07
閱讀 912·2019-08-26 11:30
閱讀 1277·2019-08-26 10:41