我在菜单项上增加了自定义布局以显示计数

时间:2019-06-11 06:02:10

标签: java android android-layout android-custom-view menuitem

我正在将自定义布局扩展到菜单上栏,以显示购物车中的商品数量,而我可以通过点击商品来实现。在这里如何显示或设置计数?我有点困惑。如果可能的话,那有什么想法?

我已经尝试过

MenuInflater inflater = getMenuInflater();
inflater.inflate(R.menu.home_screen, menu);
final Menu m = menu;
final MenuItem item = menu.findItem(R.id.nav_cart);

item.getActionView().setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        Toast.makeText(HomeScreen.this, "hello", Toast.LENGTH_SHORT).show();
    }
});

自定义布局XML。所以在这里我要设置徽章计数,但是如何?

文件

<RelativeLayout
    android:id="@+id/cart"
    android:layout_width="wrap_content"
    android:layout_marginTop="15dp"
    android:layout_marginLeft="10dp"
    android:layout_marginRight="10dp"
    android:layout_height="wrap_content">

    <ImageView
        android:id="@+id/cart_bag"
        android:layout_width="25dp"
        android:layout_height="25dp"
        app:srcCompat="@drawable/bag" />

    <com.nex3z.notificationbadge.NotificationBadge
        android:id="@+id/badge"
        android:layout_width="20dp"
        android:layout_alignParentTop="true"
        android:layout_alignTop="@id/cart_bag"
        android:layout_height="20dp"
        app:nbBackground="@drawable/badge_bg_with_shadow"
        android:layout_marginLeft="15dp"
        app:nbMaxTextLength="2"/>

</RelativeLayout>

MenuItem

android:id="@+id/nav_cart"
android:orderInCategory="15"
android:title="@string/action_settings"
app:actionLayout="@layout/custom_layout_cart"
app:showAsAction="always"

2 个答案:

答案 0 :(得分:1)

尝试以编程方式添加自定义布局。.

    final MenuItem item = menu.findItem(R.id.nav_cart);
    MenuItemCompat.setActionView(item, R.id.custom_layout_cart);
    actionView = MenuItemCompat.getActionView(item);
    ImageView btn = (ImageView) actionView.findViewById(R.id.cart_bag);
    NotificationBadge count = (TextView) actionView.findViewById(R.id.badge);
    btn.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        Toast.makeText(HomeScreen.this, "hello", Toast.LENGTH_SHORT).show();
    }
});

答案 1 :(得分:1)

尝试从自定义徽章布局中将计数值设置为textview。

val tvCartCount = actionView.findViewById(R.id.your_cart_count_id) as TextView

tvCartCount.text = "Your Cart Value"

您可以参考this solution以获得更好的理解。