片段工具栏中的向上导航

时间:2018-07-13 06:00:55

标签: android android-fragments back

我正在尝试在我的应用中使用向上导航。显示了向上导航按钮,但有时可以,有时却不。可以在此处XYZReader on GitHub

查看该应用

期望的行为

主要活动显示纸牌网格。选择卡片时,明细活动将显示该文章。详细信息活动使用片段和查看寻呼机,以便人们可以左右滑动到下一篇/上一篇文章。
在片段的(折叠)工具栏中,显示向上/向后导航按钮,并且当我单击该按钮时,我想返回到主要活动

实际行为(向上导航不起作用)

我在主活动的网格中选择了一篇文章,详细活动显示了相应的片段。
我点击了向上导航按钮,但没有任何反应
我希望通过向上导航将我带回到主要活动,以查看文章的网格列表。

实际行为(向上导航有效)

我在主活动的网格中选择了一篇文章,详细活动显示了相应的片段。
我向右滑动以查看下一篇文章。然后,我单击向上导航按钮,然后回到主要活动以查看文章的网格列表。

相关代码段

activity_article_detail.xml是主机/详细信息活动的布局。它只包含一个视图寻呼机视图:

<android.support.v4.view.ViewPager
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/pager"
    android:layout_width="match_parent"
    android:layout_height="match_parent"/>

fragment_article_detail.xml是片段的布局。它包含折叠的工具栏(以及嵌套的滚动视图和浮动操作按钮):

<android.support.design.widget.CoordinatorLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <android.support.design.widget.AppBarLayout
        android:id="@+id/app_bar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content">

        <android.support.design.widget.CollapsingToolbarLayout
            android:id="@+id/collapsing_toolbar_container"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            app:expandedTitleMarginBottom="@dimen/toolbar_title_bottom_margin"
            app:expandedTitleMarginStart="@dimen/detail_inner_horiz_margin"
            app:expandedTitleTextAppearance="@style/Toolbar_Title"
            app:layout_scrollFlags="scroll|exitUntilCollapsed|snap">

            <ImageView
                android:id="@+id/photo"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:contentDescription="@string/photo_of_the_article"
                android:scaleType="centerCrop"
                app:layout_collapseMode="parallax"
                app:layout_collapseParallaxMultiplier="0.1"/>

            <android.support.v7.widget.Toolbar
                android:id="@+id/toolbar"
                android:layout_width="match_parent"
                android:layout_height="?android:attr/actionBarSize"
                app:layout_collapseMode="pin">

            </android.support.v7.widget.Toolbar>

        </android.support.design.widget.CollapsingToolbarLayout>

    </android.support.design.widget.AppBarLayout>

    <android.support.v4.widget.NestedScrollView
        android:id="@+id/scrollview"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:layout_behavior="@string/appbar_scrolling_view_behavior">

        <com.example.xyzreader.ui.MaxWidthLinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_gravity="center_horizontal"
            android:background="@android:color/white"
            android:maxWidth="@dimen/detail_card_max_width"
            android:orientation="vertical">

            <LinearLayout
                android:id="@+id/linear_layout_title_container"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_gravity="center"
                android:orientation="vertical"
                android:paddingBottom="@dimen/detail_metabar_vert_padding"
                android:paddingLeft="@dimen/detail_inner_horiz_margin"
                android:paddingRight="@dimen/detail_inner_horiz_margin"
                android:paddingTop="@dimen/detail_metabar_vert_padding">

                <TextView
                    android:id="@+id/article_byline"
                    style="?android:attr/textAppearanceSmall"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:textColor="@color/byline_text_color"/>

            </LinearLayout>

            <WebView
                android:id="@+id/article_body"
                style="?android:attr/textAppearanceMedium"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_marginLeft="@dimen/detail_inner_horiz_margin"
                android:layout_marginRight="@dimen/detail_inner_horiz_margin"
                android:lineSpacingMultiplier="@fraction/detail_body_line_spacing_multiplier"
                android:paddingBottom="@dimen/detail_body_bottom_margin"
                android:paddingTop="@dimen/body_padding_top"
                android:textColor="?android:attr/textColorPrimary"
                android:textColorLink="?attr/colorAccent"
                android:textSize="@dimen/detail_body_text_size"/>

        </com.example.xyzreader.ui.MaxWidthLinearLayout>

    </android.support.v4.widget.NestedScrollView>

    <android.support.design.widget.FloatingActionButton
        android:id="@+id/floating_action_button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="bottom|end"
        android:layout_margin="@dimen/fab_margin"
        android:contentDescription="@string/action_share"
        app:fabSize="normal"
        app:srcCompat="@drawable/ic_share_white_24dp"/>

</android.support.design.widget.CoordinatorLayout>

在片段的onCreateView中,我尝试对功能进行编程:

    mCollapsingToolbarLayout = mRootView.findViewById(R.id.collapsing_toolbar_container);
    mCollapsingToolbarLayout.setExpandedTitleTypeface(Typeface.create(mCollapsingToolbarLayout.getExpandedTitleTypeface(), Typeface.BOLD));
    mCollapsingToolbarLayout.setCollapsedTitleTypeface(Typeface.create(mCollapsingToolbarLayout.getExpandedTitleTypeface(), Typeface.BOLD));
    mCollapsingToolbarLayout.setCollapsedTitleTextColor(getResources().getColor(android.R.color.white));

    AppCompatActivity appCompatActivity = ((AppCompatActivity) getActivity());
    Toolbar toolbar = mRootView.findViewById(R.id.toolbar);
    toolbar.setNavigationIcon(R.drawable.ic_arrow_back_white_24dp);
    appCompatActivity.setSupportActionBar(toolbar);
    ActionBar actionBar = appCompatActivity.getSupportActionBar();
    actionBar.setDisplayHomeAsUpEnabled(true); //<-- DISPLAYS THE HOME BUTTON IN THE COLLAPSING TOOLBAR
    actionBar.setDisplayShowTitleEnabled(false);

我尝试过的

  1. 我尝试将工具栏移至主持人活动的布局。我遇到了问题,放弃了这一点。无论如何,我都不想这样做,因为它看起来像一个有缺陷的设计。我认为每个片段都有一个工具栏。
  2. 我试图在工具栏上设置导航图标和一个侦听器。结果是一样的。有时它有用,有时却没有。

    toolbar.setNavigationIcon(nav_icon);
    toolbar.setNavigationOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            Log.d(TAG, "Up navigation button pressed.");
        }
    });
    
  3. 建议我尝试向该片段添加一个代码片段。这也不起作用。

    public boolean onOptionsItemSelected(MenuItem item) {
        switch (item.getItemId()) {
            case android.R.id.home:
                Intent intent = NavUtils.getParentActivityIntent(getActivity());
                intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP | Intent.FLAG_ACTIVITY_SINGLE_TOP);
                NavUtils.navigateUpTo(getActivity(), intent);
                return true;
        }
        return super.onOptionsItemSelected(item);
    }
    

1 个答案:

答案 0 :(得分:3)

问题是我试图为每个片段设置主机活动的支持操作栏,这是错误的(我不敢相信我确实做到了)。

我只使用工具栏,设置导航图标和相应的侦听器:

    Toolbar toolbar = mRootView.findViewById(R.id.toolbar);
    toolbar.setNavigationIcon(R.drawable.ic_arrow_back_white_24dp);
    toolbar.setNavigationOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            getActivity().onBackPressed();
        }
    });