編輯:關於Android編程
1.Fragment概述
在一個Activity中, Fragment代表UI的一個部分或者一個行為。一個Activity可以結合多個Fragment對象,也可以在多個activity中使用相同Fragment字節碼對應的不同對象。一個Fragment對象必須被嵌入在一個主Activity對象中,該Fragment的生命周期與主Activity息息相關。比如,當主Activity處於paused狀態,其對應的所有Fragment對象均處於paused狀態,只有當主Activity處於resumed狀態時,Fragment才能處於自由控制狀態。
2.創建Fragment
為了創建一個Fragment,應該去繼承Fragment或者其子類,覆寫相應的方法。比如onCreate(),OnCreateView(),onPause()等等
(1).添加UI界面
為該Fragment展現一個布局,必須去實現onCreateView()回掉方法。
注意:當該Fragment繼承了ListFragment時,不需要覆寫onCreateView()方法,因為默認返回一個ListView對象
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View view = inflater.inflate(R.layout.list, null); return view; }
(2).添加Fragment到Activity
1).通過layout布局文件
android:name屬性應該為Fragment對應類的完整路徑。
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="horizontal" > <fragment android:id="@+id/list" android:name="com.example.news.ArticleListFragment" android:layout_width="0dp" android:layout_height="match_parent" android:layout_weight="1" /> <fragment android:id="@+id/viewer" android:name="com.example.news.ArticleReaderFragment" android:layout_width="0dp" android:layout_height="match_parent" android:layout_weight="2" /> </LinearLayout>
2).通過Java代碼
當Activity運行時,可以自由的在該activity上添加fragment對象,但應該指定一個ViewGroup容器,可以FragmentTransaction完成fragment的添加移除或者替換。
manager = getFragmentManager(); if(manager.findFragmentByTag("right") == null){ manager.beginTransaction().replace(R.id.right, new RightFrag(), "right").commit(); }
(3).fragment唯一標示符
每個fragment需要定義一個唯一的標識符,如果activity被銷毀又重新啟動,系統能夠恢復該fragment的狀態。如果想重新恢復,需滿足下面有3種方式之一:
1).定義ID
在布局文件中,定義android:id屬性
<fragment android:id="@+id/list" android:name="com.example.news.ArticleListFragment" android:layout_width="0dp" android:layout_height="match_parent" android:layout_weight="1" />
2).指明tag
android:tag 指明 或者 一個fragment對象add()或者replace()時指定tag
<fragment android:id="@+id/list" android:tag="first" android:name="com.example.news.ArticleListFragment" android:layout_width="0dp" android:layout_height="match_parent" android:layout_weight="1" />
或者
manager.beginTransaction() .replace(R.id.right, new RightFrag(), "right")//在事務中指明該fragment的tag .commit();
3).viewgroup ID
如果該fragment均沒有id和tag,系統將使用container view布局的id
3.Fragment的管理
通過getFragmentManager()方法,可以得到FragmentManager對象,主要完成下面的功能
FragmentManager manager = getFragmentManager();
(1).得到已經存在Fragment對象
如果該fragment在布局文件中指定了id,通過findFragmentById()得到對象,或者指定了tag可以通過findFragmentByTag()得到對象
Fragment fragment = getFragmentManager().findFragmentByTag("right"); //or Fragment fragment = getFragmentManager().findFragmentById(id);
(2).注冊OnBackStackChangedListener監聽器
可以用來監聽該任務對應的返回棧信息,當該返回棧狀態發生改變時,執行對應的onBackStackChanged() 方法
manager.addOnBackStackChangedListener(new FragmentManager.OnBackStackChangedListener() { @Override public void onBackStackChanged() { Toast.makeText(MainActivity.this, "返回堆狀態發生改變", 1).show(); } });
(3).彈出返回棧
模擬用戶點擊返回鍵,將指定的fragment從返回棧中彈出,該操作為異步的。前提是該fragment對象使用.beginTransaction().addToBackStack("right")添加了進返回棧
manager.popBackStack(); //Pop the top state off the back stack
(4).FragmentTransaction事務
事務主要包含一些操作的集合,比如增加移除替換,動畫設置等等
/* * 通過manager開啟一個事務,該事務包含一些操作的集合,通事務可以 add(), remove(), replace() * 完成對Fragment的操作,並使用commit()提交 */ FragmentTransaction transaction = manager.beginTransaction(); transaction.replace(R.id.right, new RightFrag(), "right"); transaction.setTransition(FragmentTransaction.TRANSIT_FRAGMENT_OPEN);//設置動畫 transaction.addToBackStack("right"); // 將該fragment加入返回堆 // 提交事務 transaction.commit();
(5).Fragment狀態管理
/* * 管理Fragment的狀態 * 如果在一個主activityViewGroup中添加一個fragment, * 如果手機屏幕旋轉了,當前activity被銷毀重建,fragment也被activityManager創建 * 故在onCreate中,需要判斷一下 */ @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); manager = getFragmentManager(); if (manager.findFragmentByTag("right") == null) { // if(savedInstanceState == null)也可判斷該fragment是否已經加載 manager.beginTransaction() .replace(R.id.right, new RightFrag(), "right") .setTransition(FragmentTransaction.TRANSIT_FRAGMENT_OPEN)// 設置動畫 .addToBackStack("right") // 將該fragment加入返回堆 // 提交事務 .commit(); } }
4.Fragment間信息交互
(1).取得對象
/* * 點擊該Fragment的button按鈕,將該button的text設置為另一個fragment中Edittext的文本值 */ public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View view = inflater.inflate(R.layout.list, null); final Button button = (Button) view.findViewById(R.id.confirm); button.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { //通過FragmentManager找到另一個fragment中的edittext對象,並取得text內容 EditText editText = (EditText)(getFragmentManager().findFragmentByTag("left").getView().findViewById(R.id.name)); button.setText(editText.getText().toString()); } }); return view; }
(2).通回掉函數
public class MainActivity extends Activity { private FragmentManager manager; private Button button; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); button.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { RightFragment rightFrag = (RightFragment) (getFragmentManager().findFragmentByTag("right")); /* * 通過set方法,向其傳遞一個實例化對象,由於rightFrag.set()方法內部執行RightFragment.CallBack.get()方法,完成了參數的傳遞 */ rightFrag.set(new RightFragment.CallBack() { @Override public void get(String str) { button.setText(str); } }); } }); } } public class RightFragment extends ListFragment { private LoaderManager manager; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); manager = getLoaderManager(); } /* * 點擊該Fragment的button按鈕,將該button的text設置為另一個fragment中Edittext的文本值 */ public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View view = inflater.inflate(R.layout.list, null); return view; } /** * 通過調用該方法,接收一個回掉函數對象,callBack.get(str); * @param callBack */ public void set(CallBack callBack) { EditText editText = (EditText) getView().findViewById(R.id.name); callBack.get(editText.getText().toString()); } /* * 回掉接口 */ interface CallBack { public void get(String str); } }
5.FragmentManage:
FragmentManager能夠實現管理activity中fragment. 通過調用activity的getFragmentManager()取得它的實例.
FragmentManager可以做如下一些事情:
(1)使用findFragmentById() (用於在activity layout中提供一個UI的fragment)或findFragmentByTag()
(適用於有或沒有UI的fragment)獲取activity中存在的fragment
(2)將fragment從後台堆棧中彈出, 使用 popBackStack() (模擬用戶按下BACK 命令).
(3)使用addOnBackStackChangeListener()注冊一個監聽後台堆棧變化的listener.
6.FragmentTransaction:
FragmentTransaction對fragment進行添加,移除,替換,以及執行其他動作。
從 FragmentManager 獲得一個FragmentTransaction的實例 :
FragmentManager fragmentManager = getFragmentManager(); FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();
每一個事務都是同時要執行的一套變化.可以在一個給定的事務中設置你想執行的所有變化,使用諸如 add(), remove(), 和 replace().然後, 要給activity應用事務, 必須調用 commit().
在調用commit()之前, 你可能想調用 addToBackStack(),將事務添加到一個fragment事務的back stack. 這個back stack由activity管理, 並允許用戶通過按下 BACK 按鍵返回到前一個fragment狀態.
舉個例子, 這裡是如何將一個fragment替換為另一個, 並在後台堆棧中保留之前的狀態:
// Create new fragment and transaction Fragment newFragment = new ExampleFragment(); FragmentTransaction transaction = getFragmentManager().beginTransaction(); // Replace whatever is in the fragment_container view with this fragment, // and add the transaction to the back stack transaction.replace(R.id.fragment_container, newFragment); transaction.addToBackStack(null); // Commit the transaction transaction.commit();
在這個例子中, newFragment 替換了當前layout容器中的由R.id.fragment_container標識的fragment.通過調用 addToBackStack(), replace事務被保存到back stack, 因此用戶可以回退事務,並通過按下BACK按鍵帶回前一個fragment.
如果添加多個變化到事務(例如add()或remove())並調用addToBackStack(), 然後在你調用commit()之前的所有應用的變化會被作為一個單個事務添加到後台堆棧, BACK按鍵會將它們一起回退.
添加變化到 FragmentTransaction的順序不重要, 除以下例外:
必須最後調用 commit().
如果添加多個fragment到同一個容器, 那麼添加的順序決定了它們在view hierarchy中顯示的順序.
當執行一個移除fragment的事務時, 如果沒有調用 addToBackStack(), 那麼當事務提交後, 那個fragment會被銷毀,並且用戶不能導航回到它. 有鑒於此, 當移除一個fragment時,如果調用了 addToBackStack(), 那麼fragment會被停止, 如果用戶導航回來,它將會被恢復.
提示: 對於每一個fragment事務, 你可以應用一個事務動畫, 通過在提交事務之前調用setTransition()實現.
調用 commit() 並不立即執行事務.恰恰相反, 它將事務安排排期, 一旦准備好, 就在activity的UI線程上運行(主線程).如果有必要, 無論如何, 你可以從你的UI線程調用 executePendingTransactions() 來立即執行由commit()提交的事務. 但這麼做通常不必要, 除非事務是其他線程中的job的一個從屬.
警告: 你只能在activity保存它的狀態(當用戶離開activity)之前使用commit()提交事務.
如果你試圖在那個點之後提交, 會拋出一個異常.這是因為如果activity需要被恢復, 提交之後的狀態可能會丟失.對於你覺得可以丟失提交的狀況, 使用 commitAllowingStateLoss().
背景之前在網上搜索了好多好多關於CNN,卷積神經網絡的文章,很多都講如何卷積、卷積層如何操作、具體如何進行卷積計算、卷積的好處。我也在此之前走了好多彎路,已經很了解如何卷
大家都知道在Android中通過AIDL可以跨進程調用Service中的數據,網上也有很多實例,但是大部分實例都是關於基本數據類型的遠程調用,很少講到復雜數據的調用,今天
Android 啟動模式: 啟動模式:LaunchMode在多個Activity跳轉的過程中扮演著重要的角色,它可以決定是否
顯示效果: 我在參考鏈接中看到了作者的仿的qq提示框,但是在使用的時候並不是很方面,有一些不足,於是我參照Android系統AlertDialog