打造流暢Android App跳轉體驗!Navigation with Kotlin 一篇文章就能搞定你的APP跳轉問題!
提供了一種簡單的方式來處理 Android 應用程序中不同fragment之間的導航。
以下圖例
是在專案中導入navigation
並設置跳轉的例子
我們看到當完成一個專案時
可以一目瞭然整個轉案的跳轉邏輯
data:image/s3,"s3://crabby-images/8337a/8337aac2b03a2fde4d8cc9758af82caeab6536ea" alt="navigation"
添加相關library至build.gradle內
注意:「Navigation」 元件必須使用 Android Studio 3.3 或以上版本
透過Android Studio
右鍵單擊項目目錄中的 res 文件夾 > New > Android Resource File來新增Navigation xml。
另外如果想純手動加入,也可以在res下建立 navigation folder 裡面新增nav_graph.xml
data:image/s3,"s3://crabby-images/55334/55334cec3c2bd25cebb3e581cc0760b58b8aae19" alt="navigation_03"
data:image/s3,"s3://crabby-images/0539c/0539c76596d9e3149927274c724a0864a1281c80" alt="navigation_04"
data:image/s3,"s3://crabby-images/1f2e1/1f2e11b0ed1025f366b61e180fe788bd62cf7ce5" alt="navigation_05"
加入 fragment
id = 命名
name = fragment的path
label = 標示訊息或類似tag
tools:layout = 要預覽顯示的layout xml resource
加入 startDestination
例如:app:startDestination="@id/landingFragment"
data:image/s3,"s3://crabby-images/71d8a/71d8a59ffc824e870d9aba473645fc171a3aa157" alt="navigation_06"
android:name="androidx.navigation.fragment.NavHostFragment"
app:navGraph="@navigation/navigation_main" (選擇性,加了會在IDE預覽)
app:defaultNavHost="true"
data:image/s3,"s3://crabby-images/7a3c0/7a3c0016526988d41371d757874d30a7f587ed1b" alt="navigation_07"
在fragment內 加入action
加入後設定destination
如:app:destination="@id/signInFragment"
(action 寫在外面也可全域跳轉)
data:image/s3,"s3://crabby-images/a006a/a006a0aa1e445b3290d052cb3a831fd9a7acc79f" alt="navigation_08"
直接在要跳轉的地方加入
findNavController().navigate(R.id.action_FirstFragment_to_SecondFragment)
data:image/s3,"s3://crabby-images/b037e/b037e8b04b4b02f7d904f3b2a1488a975d453d64" alt="navigation_09"
data:image/s3,"s3://crabby-images/1931d/1931dd06c1ab2c716682805726b60e4d89fc164d" alt="navigation_010"
直接再加入一張navigation的方式:
data:image/s3,"s3://crabby-images/e4500/e45006e7d1c9e440b3653977d82f3cfeaac185c7" alt="navigation_011"
新增一張 nav graph xml後
使用include導入的方式:
data:image/s3,"s3://crabby-images/61be5/61be5a18615b02407b62a954aab0243ee5a8ba96" alt="navigation_012"
跟上面一樣在nav graph 直接加入 dialog tag
並導入你做好的DialogFragment就能用
(id = 命名 , name = fragment的path, label = 標示訊息或類似tag, tools:layout = 要顯示的layout xml resource)
data:image/s3,"s3://crabby-images/4f864/4f8647a2e76b8eb2a343bb03ab8094b75627b937" alt="navigation_013"
一樣在nav graph 直接加入argument
則可以預設帶入傳遞的變數
(argType = 變數型態, defaultValue = 預設值 )
data:image/s3,"s3://crabby-images/f7d78/f7d78f35fcdfcc2b85183decfacd15565f33552d" alt="navigation_014"
a. 不使用上面xml的方式預設值
可以下方兩組程式碼直接傳遞變數
b. 如果是有用xml方式帶入預設值的
則可以用下面收變數的程式碼直接接收
data:image/s3,"s3://crabby-images/6b69c/6b69c568b8bfafe098812151be16e55b6846cebe" alt="navigation_020"
帶入 enterAnim, exitAnim, popEnterAnim ,popExitAnim 則可以輕鬆預設跳轉動畫
使用下方code 可以使用navigation內建的activity跳離動畫
透過 Navigation 提供的api讓相關view關聯
便可處理多個back stack跳轉問題
例如setupWithNavController 與bottom navigation view關聯
setupActionBarWithNavController 與action bar關聯
此圖,闡述了一般跳轉邏輯
data:image/s3,"s3://crabby-images/9ce69/9ce6996f325a822ab1c81935b9cad3f58392f35d" alt="navigation_015"
fragment依照順序跳轉 1 -> 2 -> 3 最後再從 3回到1
且再次跳轉 1 -> 2 -> 3 再回到1
此時眾fragment 在back stack內 順序為[1,2,3,1,2,3,1]
若是想要跳轉回1的時候在stack內不再有目的fragment以上的內容可以在xml的action內加入
popUpTo 與 popUpToInclusive
這邊便可以讓下次跳轉回目的地fragment 上方有個stack instance給清除掉
同樣navigation也提供對應builder讓你設置上面講到過的一些功能,NavOptions範例:
val options = NavOptions.Builder()
.set....
.build()
最後跳轉時帶入
findNavController().navigate(R.id.action_FirstFragment_to_SecondFragment,null, options)
data:image/s3,"s3://crabby-images/9a3f3/9a3f347254899f13541a2da6e797fb8b8ef6d3dc" alt="navigation_018"