简体   繁体   English

片段内的CollapsingToolbarLayout菜单

[英]CollapsingToolbarLayout Menu inside a fragment

I am crious if there is a way to make CollapsingToolbarLayout menu inside a fragment without we define custom layout inside it. 我想知道是否有一种方法可以在片段中创建CollapsingToolbarLayout菜单而无需在其中定义自定义布局。 On phone layout, i made DetailActivity that has menus inside it. 在电话布局上,我制作了DetailActivity,其中包含菜单。 在此处输入图片说明

On tablet layout, i made the detail into fragment on the right side. 在平板电脑布局上,我在右侧将细节分解成片段。 The CollapsingToolbarLayout working fine actually, but i can't add any menu directly to it. CollapsingToolbarLayout实际上工作正常,但是我不能直接向其中添加任何菜单。 在此处输入图片说明

I know about Fragment.setHasOptionsMenu(true); 我知道Fragment.setHasOptionsMenu(true); , but i don't want to merge my detail menu with activity menu. ,但我不想将我的详细信息菜单与活动菜单合并。

PS: The images i used here is retrieved from TMDb and it is free of use. PS:我在这里使用的图像是从TMDb中检索的,它是免费的。

I already dive to the CollapsingToolbarLayout and googling about it, but i don't think it is possible to do. 我已经深入到CollapsingToolbarLayout并进行了谷歌搜索,但是我认为这是不可能的。 So for workaround, i make an ImageView with menu overflow icon, and show list pop up under it to imitate action menu behavior. 因此,为了解决此问题,我制作了一个带有菜单溢出图标的ImageView,并在其下弹出了显示列表,以模仿操作菜单的行为。 Here is my CollapsingToolbarLayout looks like in XML 这是我的CollapsingToolbarLayout看起来像XML

<android.support.design.widget.CollapsingToolbarLayout
    android:fitsSystemWindows="false"
    android:id="@+id/collapsing_toolbar"
    android:layout_height="wrap_content"
    android:layout_width="match_parent"
    app:contentInsetStartWithNavigation="0dp"
    app:contentScrim="?attr/colorPrimary"
    app:expandedTitleMarginEnd="64dp"
    app:expandedTitleMarginStart="48dp"
    app:layout_scrollFlags="exitUntilCollapsed|scroll">

    <your.app.AutoFitImageView
        android:fitsSystemWindows="false"
        android:id="@+id/iv_backdrop_image"
        android:layout_height="wrap_content"
        android:layout_width="match_parent"
        android:scaleType="fitCenter"
        android:transitionName="image"
        app:layout_collapseMode="parallax"
        tools:targetApi="lollipop"/>

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

        <ImageView
            android:id="@+id/button_menu"
            android:layout_gravity="right"
            android:layout_height="wrap_content"
            android:layout_width="wrap_content"
            android:minHeight="48dp"
            android:minWidth="48dp"
            android:scaleType="centerInside"
            android:src="@drawable/ic_action_overflow"/>
    </android.support.v7.widget.Toolbar>

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

Then i set clickListener to ImageView with R.id.button_menu id to call this method: 然后我将clickListener设置为具有R.id.button_menu id的ImageView来调用此方法:

private void showListMenu(View anchor) {
    final ListPopupWindow popupWindow = new ListPopupWindow(getActivity());

    List<HashMap<String, String>> data = new ArrayList<>();

    HashMap<String, String> map1 = new HashMap<>();
    map1.put("menu", "Share Detail");

    HashMap<String, String> map2 = new HashMap<>();
    map2.put("menu", "Share First Trailer");

    data.add(map1);
    data.add(map2);

    final Movie movieData = getMovieData();
    HashMap<String, String> map3 = new HashMap<>();
    if (DbHelper.movieInDb(movieData)) {
        map3.put("menu", getString(R.string.unfavorite));
    } else {
        map3.put("menu", getString(R.string.favorite));
    }
    data.add(map3);

    ListAdapter adapter = new SimpleAdapter(
            getActivity(),
            data,
            android.R.layout.simple_list_item_1, // You may want to use your own cool layout
            new String[]{"menu"}, // These are just the keys that the data uses
            new int[]{android.R.id.text1}); // The view ids to map the data to

    popupWindow.setAnchorView(anchor);
    popupWindow.setAdapter(adapter);

    DisplayMetrics displaymetrics = new DisplayMetrics();
    getActivity().getWindowManager().getDefaultDisplay().getMetrics(displaymetrics);
    popupWindow.setWidth(displaymetrics.widthPixels / 3); // note: don't use pixels, use a dimen resource

    popupWindow.setOnItemClickListener(yourListener); // the callback for when a list item is selected
    popupWindow.show();
}

The method will show ListPopUpWindow that has same style as overflow action menu when clicked. 单击该方法时将显示ListPopUpWindow,其样式与溢出操作菜单的样式相同。 Here is the final layout looks like 这是最终的布局看起来像 在此处输入图片说明

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM