Biz 1. Akışta blankFragment2 ve blankFragment3'ü birleştirerek Nested Graph haline getirerek kapsüllemiştik. Birleştirdikten sonra aşağıdaki gibi navigation isimli id'ye sahip ve startDestination'ı blankFragment2 olan bir root dizini oluşmuştu.
Dikkat ettiyseniz navigate ettiğimiz durumda gideceğimiz sayfaya hazırladığımız navigation isimli nested graph'ın id'sini verdik. Biz bu şekilde yapmış olsak da sistem, nested graph üzerinde startDestination'da tanımlı olan destination'a gidecek.
"Nested Graph'a Git" butonuna basıldıktan sonra da aşağıdaki gibi BlankFragment2 görüntüleniyor.
Biliyorsunuz destination'ları nested graph haline çevirmenin bir kapsülleme işlemi olduğunu belirtmiş ve kapsülün içerisindeki diğer destination'lara erişimin direkt yapılamayacağından söz etmiştik.
Bunun için örneğimi aşağıdaki gibi düzenleyip, bu sefer OnClick event'ını kapsülün içerisindeki diğer fragment olan BlankFragment3'e veriyorum.
Bunun sebebi NavController'ın blankFragment3 isimli bir destination'ı tanımıyor olmasından kaynaklanıyor. Sebebi ise navigation isimli nested graph içerisinde yer alıyor olması. Çünkü nested graph kapsüllenerek çalışan bir sistem ve yalnızda startDestination üzerinde tanımlanan destination'a direkt erişim izni sağlar. Bunu da yalnızca nested graph id'si üzerinden gerçekleştirir. Yani aynı örneğimdeki OnClick event'ını direkt olarak BlankFragment2'ye de versem aynı hatayı alırdım.