如何在imageview顶部显示指标气泡?

时间:2014-02-10 13:07:42

标签: android android-layout

我有一个字符串值(即:数字1,2,3,...),我应该在我的ImageView的右上角显示它们。
我怎么能在android中做到这一点? 我在下面附上了一张图片,其中显示了箭头:我想在我的ImageView上显示这样的内容吗?

http://i.stack.imgur.com/5zPQt.png

请有人帮帮我吗?

2 个答案:

答案 0 :(得分:8)

试试这个:创建layout.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/main_widget"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:layout_marginTop="20dip"
android:focusable="true" >

<ImageView
    android:id="@+id/icon"
    android:layout_width="60dip"
    android:layout_height="60dip"
    android:layout_marginTop="8dp"
    android:background="@drawable/logo"
    android:contentDescription="image"
    android:scaleType="center" />
<TextView
    android:id="@+id/txt_count"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginLeft="-10dip"
    android:layout_toRightOf="@+id/icon"
    android:background="@drawable/badge_count2"
    android:contentDescription="badge"
    android:gravity="center"
    android:text="1"
    android:textColor="@color/White"
    android:textStyle="bold"
    android:visibility="visible" />

</RelativeLayout>

为矩形

创建drawable\badge_count2.xml
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle" >

<solid android:color="@color/red" >
</solid>

<stroke
    android:width="2dp"
    android:color="#FFFFFF" >
</stroke>

<padding
    android:bottom="2dp"
    android:left="7dp"
    android:right="7dp"
    android:top="3dp" />

<corners android:radius="10dp" >
</corners>

创建values\color.xml并添加:

 <color name="red">#e50822</color>

OutPut: enter image description here

更新:尝试为圈子

创建drawable\badge_count2.xml
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:innerRadius="0dp"
android:shape="ring"
android:thicknessRatio="1.9"
android:useLevel="false" >
<solid android:color="@color/red" />

<stroke
    android:width="2dp"
    android:color="#FFFFFF" />
</shape>

答案 1 :(得分:2)

为了方便和覆盖很多视图,您可以使用View badger library。这个库也为这些獾提供了不同的样式和动画。 您可以找到库和演示项目here

enter image description here