首页 文章

导航组件:条件导航中的工具栏问题

提问于
浏览
0

根据navigation priciples,您的应用中的第一个目的地应该是您的用户在注册/登录或任何其他条件导航后启动应用时通常会看到的屏幕,我称之为起始目的地'homeFragment' .

按照这个原则,在阅读conditional navigation by Maria Neumayer上的帖子后,我在处理条件导航流程时遇到了工具栏和后退导航的一些问题 .

我正在使用ConstraintLayout,工具栏和NavHostFragment的单个活动来构建应用程序:

<android.support.constraint.ConstraintLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".ui.activities.NavigationTestActivity">

    <android.support.v7.widget.Toolbar
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />

    <fragment
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:id="@+id/nav_host_fragment"
        android:name="androidx.navigation.fragment.NavHostFragment"
        app:navGraph="@navigation/nav_graph"
        app:defaultNavHost="true"
        />

</android.support.constraint.ConstraintLayout>

主图形看起来像这样,主目的地作为起始目的地,与动作连接到细节片段(此动作从按钮触发)和使用嵌套图形实现的条件导航:

Main Graph

我调用了这个嵌套图形welcomeGraph,它包含登录或注册的屏幕,你可以在这里看到它:

Welcome Nested Graph

在homeFragment onResume中,我检查登录/注册是否已经完成(由存储在sharedPrefs中的虚拟布尔值确定),如果不是,我启动了注册/登录的欢迎嵌套图 .

在登录目的地,我有一个'Completed'按钮,它将sharedPrefs中的虚拟布尔值设置为true,并触发一个动作popToWelcomeGraph(包括),它应该关闭整个嵌套图并带我回到homeFragment(这个工作) .

问题 - 嵌套图中的工具栏问题:

由于欢迎图在用户登陆应用程序后立即生成,工具栏不应在该嵌套图的第一个目标中显示后退/向上箭头,而应该感觉它就像是应用程序中的第一个屏幕,并且点击后退应该退出应用程序 .

问题:是否可以在此处更改工具栏以模拟嵌套图中的第一个屏幕是应用程序中的第一个屏幕,直到登录/注册完成?这会是一种不好的做法吗?

1 回答

  • 0

    你必须实现如下的通信器接口

    interface ActivityCommunicator {
        void alterToolbar();
    }
    

    并将其实现到您的活动类,如下所示

    class HomeActivity extends AppCompatActivity implements ActivityCommunicator {
    
    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        // Activity code
    }
    
    @Override
    public void alterToolbar() {
        ActionBar actionBar = getSupportActionBar();
        // False to hide back button and true to show it
        actionBar.setDisplayHomeAsUpEnabled(false);
    }
    

    }

    从您的片段中,您可以像下面一样调用它

    public class MainFragment extends Fragment {
    
    @Nullable
    @Override
    public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        ActivityCommunicator activityCommunicator = (ActivityCommunicator) getActivity();
        activityCommunicator.alterToolbar();
        // Fragment code
        return super.onCreateView(inflater, container, savedInstanceState);
    }
    

    }

    您可以根据需要更改alterToolbar()实现

相关问题