Ich würde gerne einen Icon-Counter für Android erstellen, genau wie der Warenkorb. Ich habe gesehen, wie viele E-Commerce-App-Kartensymbole zugenommen haben. Ich zeige die Flipkart App Momentaufnahme.:-
Bei meiner Lösung wird der Zähler bei jeder neuen Benachrichtigung erhöht (wie in Einkaufs-Apps beobachtet).
Probieren Sie es aus, es funktioniert auf meinem MOTO e2.
Stellen Sie sicher, dass Ihre API-Ebene> 14 ist
Erstellen Sie ein Layout wie:
</RelativeLayout>
<ImageView
Android:id="@+id/counterBackground"
Android:layout_width="wrap_content"
Android:layout_height="wrap_content"
Android:background="@drawable/unread_background" />
<TextView
Android:id="@+id/count"
Android:layout_width="wrap_content"
Android:layout_height="wrap_content"
Android:text="1"
Android:textSize="8sp"
Android:layout_centerInParent="true"
Android:textColor="#FFFFFF" />
</RelativeLayout>
In onCreateOptionMenu
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.menu_main, menu);
MenuItem menuItem = menu.findItem(R.id.testAction);
menuItem.setIcon(buildCounterDrawable(count, R.drawable.ic_menu_gallery));
return true;
}
Erstelle jetzt eine Methode für Icon:
private Drawable buildCounterDrawable(int count, int backgroundImageId) {
LayoutInflater inflater = LayoutInflater.from(this);
View view = inflater.inflate(R.layout.counter_menuitem_layout, null);
view.setBackgroundResource(backgroundImageId);
if (count == 0) {
View counterTextPanel = view.findViewById(R.id.counterValuePanel);
counterTextPanel.setVisibility(View.GONE);
} else {
TextView textView = (TextView) view.findViewById(R.id.count);
textView.setText("" + count);
}
view.measure(View.MeasureSpec.makeMeasureSpec(0, View.MeasureSpec.UNSPECIFIED),
View.MeasureSpec.makeMeasureSpec(0, View.MeasureSpec.UNSPECIFIED));
view.layout(0, 0, view.getMeasuredWidth(), view.getMeasuredHeight());
view.setDrawingCacheEnabled(true);
view.setDrawingCacheQuality(View.DRAWING_CACHE_QUALITY_HIGH);
Bitmap bitmap = Bitmap.createBitmap(view.getDrawingCache());
view.setDrawingCacheEnabled(false);
return new BitmapDrawable(getResources(), bitmap);
}
Sie können von hier verweisen.
Sie können wie folgt vorgehen
Benutzerdefiniertes Element in meinem Menü - main.xml
<item
Android:id="@+id/badge"
Android:actionLayout="@layout/feed_update_count"
Android:icon="@drawable/shape_notification"
Android:showAsAction="always">
</item>
Benutzerdefinierte Form gezeichnet (Hintergrundquadrat) - shape_notification.xml
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:Android="http://schemas.Android.com/apk/res/Android"
Android:shape="rectangle">
<stroke Android:color="#22000000" Android:width="2dp"/>
<corners Android:radius="5dp" />
<solid Android:color="#CC0001"/>
</shape>
Layout für meine Ansicht - feed_update_count.xml
<?xml version="1.0" encoding="utf-8"?>
<Button xmlns:Android="http://schemas.Android.com/apk/res/Android"
Android:id="@+id/notif_count"
Android:layout_width="wrap_content"
Android:layout_height="wrap_content"
Android:minWidth="32dp"
Android:minHeight="32dp"
Android:background="@drawable/shape_notification"
Android:text="0"
Android:textSize="16sp"
Android:textColor="@Android:color/white"
Android:gravity="center"
Android:padding="2dp"
Android:singleLine="true">
</Button>
MainActivity - Meine Ansicht einstellen und aktualisieren
static Button notifCount;
static int mNotifCount = 0;
@Override
public boolean onCreateOptionsMenu(Menu menu) {
MenuInflater inflater = getSupportMenuInflater();
inflater.inflate(R.menu.main, menu);
View count = menu.findItem(R.id.badge).getActionView();
notifCount = (Button) count.findViewById(R.id.notif_count);
notifCount.setText(String.valueOf(mNotifCount));
return super.onCreateOptionsMenu(menu);
}
private void setNotifCount(int count){
mNotifCount = count;
invalidateOptionsMenu();
}
Ändern Sie einfach Android:actionLayout="@layout/feed_update_count"
in app:actionLayout="@layout/feed_update_count"
. , Es wird funktionieren
Anstatt Form und Zeichnung zu erstellen, können Sie den Ausweisstil in TextView
selbst verwenden. Verwenden Sie einfach den benutzerdefinierten Floating-Button-Stil für Ihr Design.
Beispiel-
<TextView
Android:id="@+id/fabCounter"
style="@style/Widget.Design.FloatingActionButton"
Android:layout_width="wrap_content"
Android:layout_height="wrap_content"
Android:layout_alignParentEnd="true"
Android:layout_centerVertical="true"
Android:layout_marginEnd="10dp"
Android:padding="5dp"
Android:text="-9"
Android:textColor="@Android:color/black"
Android:textSize="14sp" />