安卓 购物车上的小红点的2种方法1,传统布法,2,BadgeView

购物车上的购买数量的小红点,难倒了2个同事,还是kankan来解决。

1.传统布局法

首先看布局,伊特includelayout 中加载一个顶部菜单栏


菜单的具体布局文件 

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="@color/bg_1" >


    <TextView
        android:id="@+id/v_title_text_score"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        android:gravity="center"
        android:padding="10dp"
        android:text="首页"
        android:textColor="@color/text_title"
        android:textSize="@dimen/text_size_18" />


    <TextView
        android:id="@+id/v_title_left_score"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_centerVertical="true"
        android:padding="10dp"
        android:text="返回"
        android:textColor="@color/text_color_2"
        android:textSize="@dimen/text_size_16"
        android:visibility="gone" />


  <!--   <ImageView
        android:id="@+id/v_title_left_img_score"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_centerVertical="true"
        android:padding="10dp"
        android:src="@drawable/title_left_img"
        android:visibility="visible" /> -->
    <ImageView
        android:id="@+id/v_title_left_img_score"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_centerVertical="true"
        android:src="@drawable/title_left_img"
        android:adjustViewBounds="true" 
        android:maxWidth="35dp"
        android:maxHeight="30dp"
        android:layout_marginLeft="10dp"
        android:scaleType="fitXY"
        android:visibility="visible" />


    <TextView
        android:id="@+id/v_title_right_score"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentRight="true"
        android:layout_centerVertical="true"
        android:padding="10dp"
        android:text="功能"
        android:textColor="@color/text_color_2"
        android:textSize="@dimen/text_size_16"
        android:visibility="gone" />


 


    <ImageView
        android:id="@+id/v_title_right_cart"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentRight="true"
        android:layout_centerVertical="true"
        android:layout_marginRight="14dp"
        android:src="@drawable/score_cart_empty" />


    <TextView
        android:id="@+id/v_title_right_number"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentRight="true"
        android:layout_marginRight="8dp"
        android:layout_marginTop="2dp"
        android:gravity="center_horizontal"
        android:layout_alignParentTop="true"
        android:background="@drawable/score_top_icon3"
        android:padding="2dp"
        android:textAlignment="textEnd"
        android:text="9"
        android:textColor="@color/white"
        android:textSize="8sp" 
        android:visibility="gone"/>


</RelativeLayout>


java代码


更改数量,直接setText就可以了


2 badgeview

 BadgeView的用法
            badgeview其实就是红色提示消息数量的一个textview,我们可以对他的位置,颜色,动画进行设置。

//找到要显示小圆点的imageview

ImageView target= (ImageView )findViewById(R.id.imageview);
//声明初始化badgeview
BadgeView bv = new BadgeView(this, target);

bv.setText(“9+”);

bv.setTextColor(Color.Yellow);

bv.setTextSize(12);
//数量当然在右上角
bv.setBadgePosition(BadgeView.POSITION_TOP_RIGHT); //默认值

bv.show();

 
感谢eclipse_xu提供思路

http://vote.blog.csdn.net/Article/Details?articleid=30748339大笑





你可能感兴趣的:(UI,android,安卓,购物车)