• <menu id="w2i4a"></menu>
  • logo 移動開發(fā)學習指南
    文檔首頁>>移動開發(fā)學習指南>>如何在Android創(chuàng)建Badges(項目計數(shù))

    如何在Android創(chuàng)建Badges(項目計數(shù))


    在本教程中,我們旨在為Android應用程序創(chuàng)建一個Badge(項目計數(shù))功能。Badges是用來顯示通知、信息的數(shù)量和產(chǎn)品數(shù)。這些天許多Android應用程序使用badges。這個沒有簡單的方法來做,所以我們會通過我們自己編碼來完成。

    如何在Android創(chuàng)建Badges(項目計數(shù))

    要求

    1. JDK 7.0或以上。
    2. Android Studio 2.0。

    步驟:

    在Drawable文件夾中,創(chuàng)建一個名為item_count的XML文件和創(chuàng)建一個8 dp圓角半徑的矩形。

    item_count.xml

    <?xml version="1.0" encoding="utf-8"?>
    <shape xmlns:android="http://schemas.android.com/apk/res/android"
        android:shape="rectangle">
        <corners android:radius="8dp" />
        <solid android:color="#f20000" />
        <stroke
            android:width="2dip"
            android:color="#FFF" />
        <padding
            android:bottom="5dp"
            android:left="5dp"
            android:right="5dp"
            android:top="5dp" />
    </shape>

    修改activity_main.xml和添加Relativelayout、Buttons和文本。你的activity_main.xml文件應該像下面這樣。你還要在Drawable文件夾中為這個布局添加所需的圖像。

    Activity_main.xml

    <?xml version="1.0" encoding="utf-8"?>
    <!--Adding Badge (Item Count)/Notification Count to Android Button-->
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent"
        android:layout_height="match_parent"
        android:gravity="center_horizontal"
        android:orientation="vertical"
        android:padding="16dp">
        <RelativeLayout
            android:id="@+id/badge_layout1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content">
            <RelativeLayout
                android:id="@+id/relative_layout"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content">
                <Button
                    android:id="@+id/button1"
                    android:layout_width="65dip"
                    android:layout_height="65dip"
                    android:background="@drawable/chat_icon" />
            </RelativeLayout>
            <TextView
                android:id="@+id/badge_notification_1"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_alignRight="@id/relative_layout"
                android:background="@drawable/item_count"
                android:text="16"
                android:textColor="#FFF"
                android:textSize="16sp"
                android:textStyle="bold" />
        </RelativeLayout>
        <RelativeLayout
            android:id="@+id/badge2"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginLeft="50dp"
            android:layout_toRightOf="@+id/badge_layout1">
            <RelativeLayout
                android:id="@+id/relative_layout1"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content">
                <Button
                    android:id="@+id/myButton1"
                    android:layout_width="65dip"
                    android:layout_height="65dip"
                    android:background="@drawable/email_icon" />
            </RelativeLayout>
            <TextView
                android:id="@+id/badge_notification_2"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_alignRight="@id/relative_layout1"
                android:background="@drawable/item_count"
                android:text="21"
                android:textColor="#FFF"
                android:textSize="16sp"
                android:textStyle="bold" />
        </RelativeLayout>
        <RelativeLayout
            android:id="@+id/badge4"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_below="@+id/badge_layout1"
            android:layout_marginTop="50dp">
            <RelativeLayout
                android:id="@+id/relative_layout3"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content">
                <Button
                    android:id="@+id/myButton4"
                    android:layout_width="wrap_content"
                    android:layout_height="65dip"
                    android:background="#4169E1"
                    android:elevation="4dp"
                    android:paddingLeft="50dp"
                    android:paddingRight="50dp"
                    android:text="Notification"
                    android:textColor="#fff" />
            </RelativeLayout>
            <TextView
                android:id="@+id/badge_notification_4"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_alignLeft="@id/relative_layout3"
                android:background="@drawable/item_count"
                android:text="427"
                android:textColor="#FFF"
                android:textSize="16sp"
                android:textStyle="bold" />
        </RelativeLayout>
    </RelativeLayout>

    你的MainActivity.java文件應該看起來像這樣:

    MainActivity.java

    import android.support.v7.app.AppCompatActivity;
    import android.os.Bundle;
    public class MainActivity extends AppCompatActivity {
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
        }
    }

    現(xiàn)在,當你運行你的應用程序時,你將看到下面這樣的屏幕截圖:

    如何在Android創(chuàng)建Badges(項目計數(shù))

    要求

    本文翻譯自:How to Create Badges (Item Counts) in Android

     

    PS: 關(guān)于移動開發(fā),這些產(chǎn)品你可以關(guān)注>>
    關(guān)于移動開發(fā)的最新資訊和產(chǎn)品推薦,請<咨詢在線客服>!
    掃碼咨詢


    添加微信 立即咨詢

    電話咨詢

    客服熱線
    023-68661681

    TOP
    三级成人熟女影院,欧美午夜成人精品视频,亚洲国产成人乱色在线观看,色中色成人论坛 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();