自定义imageView-在图片右上角显示消息条数提醒

自定义类,PointImageView:

/**
 * 实现在图片右上角显示消息条数
 */
public class PointImageView extends ImageView {

    /**
     * 默认模式
     */
    private int pointMode = NO_POINT;

    // 1.不显示红点
    public static final int NO_POINT = 1;
    // 2.只显示一个红点,表示有新消息
    public static final int ONLY_POINT = 2;
    // 3.显示一个红点,红点中间还有消息的数量
    public static final int NUMBER_POINT = 3;

    //消息的数量
    private  int  number = 0;

    //记录当前是否有新消息
    public boolean  isHaveMesage = false;

    /**
     * 画圆
     */
    private Paint paint;

    /**
     * 画消息条数,有未画先知的功能,可以提前知道需要画的文字的长宽
     */
    private TextPaint paintText;

    public PointImageView(Context context) {
        super(context);
    }

    public PointImageView(Context context, AttributeSet attrs) {
        super(context, attrs);
        init();
    }

    /**
     * 初始化数据
      */
    private void init() {
        paint = new Paint();
        paint.setStyle(Paint.Style.FILL);//实心
        paint.setColor(0xffff0000);//红色
        paint.setAntiAlias(true);//抗锯齿

        paintText= new TextPaint();
        paintText.setColor(0xffffffff);//白色
        paintText.setTextSize(25);//设置显示条数的文本大小
        paintText.setAntiAlias(true);
        paint.setStyle(Paint.Style.FILL);//实心
    }


    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        if(!isHaveMesage){
            return;
        }
        switch (pointMode){
            case NO_POINT://不显示红点
                break;
            case ONLY_POINT://只显示红点
                canvas.drawCircle(getWidth()-getPaddingRight(),getPaddingTop(),getPaddingRight(),paint);
                break;
            case NUMBER_POINT://显示红点且带消息条数
                canvas.drawCircle(getWidth()-getPaddingRight(),getPaddingTop(),getPaddingRight(),paint);
                //文字显示是要有基准线的
                String showText="";
                if(number>0 && number<100){
                    showText = number+"";
                }else if(number >= 100){
                    showText = "+99";
                }
                float textWidth = paintText.measureText(showText);//测量出文本的宽度
                //图片右顶点减去文本的一半,使文本中心与图片右顶点重合
                float x = getWidth() - getPaddingRight() - textWidth / 2;
                //y抽坐标,文字的基准线为图片右顶点下面点
                float y = (float) (getPaddingTop() + paintText.getFontMetrics().bottom*1.5);
                canvas.drawText(showText,x ,y,paintText);
                break;
        }
    }

    /**
     * 设置消息条数
     */
    public void setMessageNum(int number){
        this.number=number;
    }

    /**
     * 是否有新消息
     * @param isHaveMesage true代表有
     */
    public void setHaveMesage(boolean isHaveMesage){
        this.isHaveMesage=isHaveMesage;
        invalidate();//如果不能即时刷新,使用postInvalidate()就好了
    }

    /**
     * 设置显示模式
     * @param mode
     */
    public void setPointMode(int mode){
        if(mode>0 && mode<=3){
            pointMode = mode;
        }else {
            throw new RuntimeException("设置的模式有误");
        }
    }

}

布局中引用,activity_main.xml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:gravity="center"
    android:orientation="vertical">

    <com.workspace.my.day8_26.PointImageView
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:src="@mipmap/ic_launcher"
        android:padding="15dp"
        android:id="@+id/imageView" />

</LinearLayout>

内边距padding作为消息条数显示的位置

代码中使用,MainActivity:

public class MainActivity extends AppCompatActivity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        PointImageView img = (PointImageView) findViewById(R.id.imageView);//找到自定义的控件
        img.setMessageNum(149);//设置消息条数
        img.setPointMode(PointImageView.NUMBER_POINT);
        img.setHaveMesage(true);
    }
}

效果图:

 

 

说明:注意点就是在绘制文本的时候对基准线的确定,见上面红色代码

 

posted @ 2016-09-11 21:58  ts-android  阅读(2213)  评论(0编辑  收藏  举报