自定義控件-星級評分(仿淘寶哨毁,美團)

1.demo簡介

該demo是仿照淘寶枫甲,美團等電商平臺的星級評分控件。安卓已集成RatingBar控件扼褪,開發(fā)可以直接使用想幻,該demo僅供學習使用。

2.圖片資源

rating.png
rating_click.png

3.設計思路

  • 1.編寫attrs文件话浇,自定義屬性:
  • 2.在布局中使用該控件
  • 3.編寫控件實現(xiàn)類
  • 3.1.初始化屬性 :mOrignPic:未點評時的星星圖脏毯,這里簡稱初始底圖;mChangePic:點評時的星星幔崖,這里簡稱變化圖
  • 3.2.編寫onmeasure方法食店,注意添加padding值
  • 3.3.編寫ondraw方法,繪制圖像岖瑰,這里使用drawBitmap進行圖像繪制
  • 4.編寫onTouchEvent方法
  • 5.簡單優(yōu)化代碼

4.代碼實現(xiàn)

  • attrs文件
<?xml version="1.0" encoding="utf-8"?>
<resources>
    <declare-styleable name="RatingBar">
        <attr name="ratingOrign" format="reference" />//初始圖片
        <attr name="ratingChange" format="reference" />//評分改變圖片
        <attr name="ratingCount" format="integer" />//星星數(shù)
    </declare-styleable>
</resources>
  • layout布局文件引用控件
    <com.incall.apps.ratingbar.RatingBar
        android:id="@+id/rating_own"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:paddingRight="5dp"
        app:ratingOrign="@mipmap/rating"
        app:ratingChange="@mipmap/rating_click"
        app:ratingCount="5"/>
  • RatingBar.class(自定義控件實現(xiàn)類)


import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;

import androidx.annotation.Nullable;
public class RatingBar extends View {

    private Bitmap mOrignPic; //初始底圖
    private Bitmap mChangePic;//變化圖
    private int mCount = 5;//星星個數(shù)
    private int mCurrentNumber = 0;//當前分數(shù)
    private int mCurrtentCode = 0;//當前分數(shù)記錄(優(yōu)化)
    private Paint mOriginPaint, mChangePaint;//定義畫筆

    public RatingBar(Context context) {
        this(context, null);
    }

    public RatingBar(Context context, @Nullable AttributeSet attrs) {
        this(context, attrs, 0);
    }

    public RatingBar(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
        this(context, attrs, defStyleAttr, 0);
    }

    public RatingBar(Context context, @Nullable AttributeSet attrs, int defStyleAttr, int defStyleRes) {
        super(context, attrs, defStyleAttr, defStyleRes);
        init(context, attrs);
    }


    /**
     * 初始化
     */
    private void init(Context context, AttributeSet attrs) {
        TypedArray array = context.obtainStyledAttributes(attrs, R.styleable.RatingBar);
        int mOrignPicId = array.getResourceId(R.styleable.RatingBar_ratingOrign, 0);
        int mChangePicId = array.getResourceId(R.styleable.RatingBar_ratingChange, 0);
        mOrignPic = BitmapFactory.decodeResource(getResources(), mOrignPicId);
        mChangePic = BitmapFactory.decodeResource(getResources(), mChangePicId);
        mCount = array.getInt(R.styleable.RatingBar_ratingCount, 5);
        mOriginPaint = new Paint();
        mOriginPaint.setAntiAlias(true);

        mChangePaint = new Paint();
        mChangePaint.setAntiAlias(true);
        array.recycle();
    }

    @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        super.onMeasure(widthMeasureSpec, heightMeasureSpec);
        int width = (mOrignPic.getWidth() + getPaddingRight()) * mCount;
        int height = mOrignPic.getHeight();
        setMeasuredDimension(width, height);
    }

    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        int x = mOrignPic.getWidth() + getPaddingRight();
        //繪制初始底圖
        for (int i = 0; i < mCount; i++) {
            if (mCurrentNumber > i) {
                canvas.drawBitmap(mChangePic, i * x, 0, mChangePaint);
            } else {
                canvas.drawBitmap(mOrignPic, i * x, 0, mOriginPaint);
            }

        }
    }

    @Override
    public boolean onTouchEvent(MotionEvent event) {

        switch (event.getAction()) {
            case MotionEvent.ACTION_DOWN:
            case MotionEvent.ACTION_MOVE:
                float eventX = event.getX();//getX()表示焦點離當前控件的x叛买,getRawX()是焦點離屏幕的x
                mCurrentNumber = (int) (eventX / (mOrignPic.getWidth() + getPaddingRight())) + 1;
        }

        //優(yōu)化:減少ondraw方法調用
        if (mCurrtentCode == mCurrentNumber) {
            return true;
        }
        mCurrtentCode = mCurrentNumber;
        invalidate();
        return true;
    }
}

5.效果圖

RatingBar.gif
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市蹋订,隨后出現(xiàn)的幾起案子率挣,更是在濱河造成了極大的恐慌,老刑警劉巖露戒,帶你破解...
    沈念sama閱讀 216,402評論 6 499
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件椒功,死亡現(xiàn)場離奇詭異,居然都是意外死亡智什,警方通過查閱死者的電腦和手機动漾,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,377評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來荠锭,“玉大人旱眯,你說我怎么就攤上這事。” “怎么了删豺?”我有些...
    開封第一講書人閱讀 162,483評論 0 353
  • 文/不壞的土叔 我叫張陵共虑,是天一觀的道長。 經(jīng)常有香客問我呀页,道長妈拌,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,165評論 1 292
  • 正文 為了忘掉前任蓬蝶,我火速辦了婚禮尘分,結果婚禮上,老公的妹妹穿的比我還像新娘丸氛。我一直安慰自己培愁,他們只是感情好,可當我...
    茶點故事閱讀 67,176評論 6 388
  • 文/花漫 我一把揭開白布雪位。 她就那樣靜靜地躺著竭钝,像睡著了一般。 火紅的嫁衣襯著肌膚如雪雹洗。 梳的紋絲不亂的頭發(fā)上香罐,一...
    開封第一講書人閱讀 51,146評論 1 297
  • 那天,我揣著相機與錄音时肿,去河邊找鬼庇茫。 笑死,一個胖子當著我的面吹牛螃成,可吹牛的內容都是我干的旦签。 我是一名探鬼主播,決...
    沈念sama閱讀 40,032評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼寸宏,長吁一口氣:“原來是場噩夢啊……” “哼宁炫!你這毒婦竟也來了?” 一聲冷哼從身側響起氮凝,我...
    開封第一講書人閱讀 38,896評論 0 274
  • 序言:老撾萬榮一對情侶失蹤羔巢,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后罩阵,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體竿秆,經(jīng)...
    沈念sama閱讀 45,311評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,536評論 2 332
  • 正文 我和宋清朗相戀三年稿壁,在試婚紗的時候發(fā)現(xiàn)自己被綠了幽钢。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,696評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡傅是,死狀恐怖匪燕,靈堂內的尸體忽然破棺而出蕾羊,到底是詐尸還是另有隱情,我是刑警寧澤谎懦,帶...
    沈念sama閱讀 35,413評論 5 343
  • 正文 年R本政府宣布肚豺,位于F島的核電站,受9級特大地震影響界拦,放射性物質發(fā)生泄漏。R本人自食惡果不足惜梗劫,卻給世界環(huán)境...
    茶點故事閱讀 41,008評論 3 325
  • 文/蒙蒙 一享甸、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧梳侨,春花似錦蛉威、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至丙躏,卻和暖如春择示,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背晒旅。 一陣腳步聲響...
    開封第一講書人閱讀 32,815評論 1 269
  • 我被黑心中介騙來泰國打工栅盲, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人废恋。 一個月前我還...
    沈念sama閱讀 47,698評論 2 368
  • 正文 我出身青樓谈秫,卻偏偏與公主長得像,于是被迫代替她去往敵國和親鱼鼓。 傳聞我的和親對象是個殘疾皇子拟烫,可洞房花燭夜當晚...
    茶點故事閱讀 44,592評論 2 353

推薦閱讀更多精彩內容