Android 仿支付宝中的余额宝收益进度条

 更新时间:2016年12月09日 14:55:32   作者:Susan8888  
这篇文章主要介绍了Android 仿支付宝中的余额宝收益进度条的实例代码,非常不错,具有参考借鉴价值,需要的朋友可以参考下

一、 看效果

二、上代码

package com.framework.widget;
import android.app.Activity;
import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Rect;
import android.graphics.RectF;
import android.util.AttributeSet;
import android.util.DisplayMetrics;
import android.view.View;
import com.R;
/**
 * @author dahai
 * @ClassName: (仿支付宝) 收益进度条
 * @Description: ${todo}
 * @date ${date} ${time}
 * @email 202491024@qq.com
 * @since $
  • android
  • 进度条
  • */ public class ProfitProgerssBar extends View { //背景色 private static final int DEFAULT_BACK_COLOR = Color.parseColor("#ffffff"); //字的颜色 private static final int DEFAULT_TEXT_COLOR = Color.parseColor("#ffffff"); //进度条背景颜色 private static final int DEFAULT_PROGRESS_COLOR = Color.parseColor("#abacaf"); //进度条默认的高度 private static final float DEFAULT_PROGRESS_HEIGHT =120f; //文字的大小 private static final float DEFAULT_TEXT_SIZE = 50; /** * 收益进度条左右两边margin大小 */ private static final int MARGIN_SIZE = 20; private Context context; /** * 背景颜色的画笔 */ private Paint backgroundPaint; /** * 收益进度颜色的画笔 */ private Paint progressPaint; /** * 画文字的画笔 */ private Paint textPaint; /** * 背景的宽度 */ private int view_background_width; /** * 背景的高度 */ private float view_background_height = DEFAULT_PROGRESS_HEIGHT; /** * 日期 */ private String date = "2016/12/07"; /** * 描叙(百分比/元) */ private String desc = "2.1234"; /** * 要显示的长度的百分比 */ private int progress = 70; //进度条颜色 private int progress_color = DEFAULT_PROGRESS_COLOR; //背景色 private int progress_back_color = DEFAULT_BACK_COLOR; //字的颜色 private int text_color = DEFAULT_TEXT_COLOR; //字的大小 private float TEXT_SIZE = DEFAULT_TEXT_SIZE; public ProfitProgerssBar(Context context) { super(context); initView(context); } public ProfitProgerssBar(Context context, AttributeSet attrs) { super(context, attrs); initView(context); } public ProfitProgerssBar(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); initView(context); } private void initView(Context context) { this.context = context; TypedArray typedArray = this.context.obtainStyledAttributes(R.styleable.ProfitProgerssBar); progress_back_color = typedArray.getColor(R.styleable.ProfitProgerssBar_progress_backg_color,DEFAULT_BACK_COLOR); text_color = typedArray.getColor(R.styleable.ProfitProgerssBar_progress_text_color,DEFAULT_TEXT_COLOR); TEXT_SIZE = typedArray.getDimension(R.styleable.ProfitProgerssBar_progress_text_size,DEFAULT_TEXT_SIZE); backgroundPaint = new Paint(); backgroundPaint.setStrokeWidth(10); backgroundPaint.setColor(progress_back_color); backgroundPaint.setDither(true); backgroundPaint.setAntiAlias(true); progressPaint = new Paint(); progressPaint.setStrokeWidth(10); progressPaint.setDither(true); progressPaint.setAntiAlias(true); textPaint = new Paint(); textPaint.setStrokeWidth(10); textPaint.setDither(true); textPaint.setAntiAlias(true); textPaint.setTextSize(TEXT_SIZE); DisplayMetrics d = new DisplayMetrics(); ((Activity) context).getWindowManager().getDefaultDisplay().getMetrics(d); view_background_width = d.widthPixels; } /** * 初始化 进度条 * @param date * @param desc * @param progress * @param progressColor */ public void init(String date,String desc,int progress,int progressColor){ this.date = date; this.desc = desc; this.progress = progress; this.progress_color = progressColor; } @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); view_background_height = this.getMeasuredHeight(); RectF r = new RectF(); r.left = 0; r.top = 0; r.right = view_background_width; r.bottom = view_background_height;////------------------------ canvas.drawRect(r, backgroundPaint); RectF r1 = new RectF(); r1.left = 0; r1.top = 0; r1.right = view_background_width * progress / 100; r1.bottom = view_background_height;////------------------------ progressPaint.setColor(progress_color); canvas.drawRect(r1, progressPaint); textPaint.setColor(text_color); Rect r2 = new Rect(); textPaint.getTextBounds(date,0,date.length(),r2); canvas.drawText(date, MARGIN_SIZE, (view_background_height-r2.top)/2, textPaint);//日期 Rect r3 = new Rect(); textPaint.getTextBounds(desc,0,desc.length(),r3); if(progress>95&&progress<100){ canvas.drawText(desc, r1.right-textPaint.measureText(desc)-MARGIN_SIZE-30,(view_background_height-r3.top)/2, textPaint); }else if(progress>=100) { canvas.drawText(desc, r1.right-textPaint.measureText(desc)-MARGIN_SIZE-45,(view_background_height-r3.top)/2, textPaint); }else { canvas.drawText(desc, r1.right - textPaint.measureText(desc) - MARGIN_SIZE, (view_background_height - r3.top) / 2, textPaint); } invalidate(); } }

    三、

    <com.framework.widget.ProfitProgerssBar
     android:layout_width="match_parent"
     android:layout_height="35dp"
     android:layout_marginLeft="10dp"
     android:layout_marginRight="10dp"
     android:layout_marginTop="10dp"
     app:progress_back_color="@color/white"
     app:progress_text_color="@color/white"
     app:progress_text_size="14dp"
     android:id="@+id/profitProgerssBar"
     />
    <declare-styleable name="ProfitProgerssBar">
     <attr name="progress_backg_color" format="color"/>
     <attr name="progress_text_color" format="color"/>
     <attr name="progress_text_size" format="dimension"/>
    </declare-styleable>

    以上所述是小编给大家介绍的Android 仿支付宝中的余额宝收益进度条,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

    相关文章

    • Android 国际货币格式化的示例代码

      Android 国际货币格式化的示例代码

      本篇文章主要介绍了Android 国际货币格式化的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
      2017-11-11
    • 基于Android-Skin-Loader实现换肤效果

      基于Android-Skin-Loader实现换肤效果

      这篇文章主要为大家详细介绍了基于Android-Skin-Loader实现换肤效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
      2020-03-03
    • Android Studio实现单选对话框

      Android Studio实现单选对话框

      这篇文章主要为大家详细介绍了Android Studio实现单选对话框,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
      2022-05-05
    • Android自定义实现日历控件

      Android自定义实现日历控件

      这篇文章主要为大家详细介绍了Android自定义实现日历控件,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
      2021-11-11
    • MVVMLight项目的绑定及各种使用场景示例分析

      MVVMLight项目的绑定及各种使用场景示例分析

      这篇文章主要为大家介绍了MVVMLight项目中的绑定及绑定的各种使用场景示例源码分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步除夕快乐
      2022-01-01
    • Android ListView的Item点击效果的定制

      Android ListView的Item点击效果的定制

      这篇文章主要介绍了Android ListView的Item点击效果的定制的相关资料,需要的朋友可以参考下
      2017-07-07
    • Android编程实现图片平铺的方法分析

      Android编程实现图片平铺的方法分析

      这篇文章主要介绍了Android编程实现图片平铺的方法,结合具体实例形式总结分析了Android实现图片平铺效果的三种常用操作技巧,需要的朋友可以参考下
      2017-06-06
    • Android 日常开发总结的60条技术经验

      Android 日常开发总结的60条技术经验

      这篇文章主要介绍了Android日常开发总结的技术经验60条,需要的朋友可以参考下
      2016-03-03
    • android实现定时拍照功能

      android实现定时拍照功能

      这篇文章主要为大家详细介绍了android实现定时拍照功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
      2018-05-05
    • Android Studio 3.x安装指南教程

      Android Studio 3.x安装指南教程

      这篇文章主要为大家详细介绍了Android Studio 3.x安装指南教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
      2019-07-07

    最新评论