仿支付宝的芝麻信用仪表盘

实现的效果

实现的功能:

  • 指针和数字动态改变

  • 背景动态变化

  • 没了...

代码如下
MyCustomView.java

package com.example.testcustomview;

import android.animation.ValueAnimator;
import android.animation.ValueAnimator.AnimatorUpdateListener;
import android.content.Context;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Paint;
import android.graphics.Paint.FontMetrics;
import android.graphics.RectF;
import android.util.AttributeSet;
import android.util.Log;
import android.view.View; public class MyCustomView extends View { private Paint paint;
private ValueAnimator valueAnimator;
private int backgroundColor;
private int fontColor = Color.WHITE;
private int score;
private int value; public MyCustomView(Context context, AttributeSet attrs) {
super(context, attrs); } public void setSocre(int score) {
init(score);
} private void init(int score) {
// ValueAnimator用来计算过度值,过度值用来更改背景颜色以及指针的轨迹
valueAnimator = ValueAnimator.ofInt(0, score);
valueAnimator.setDuration(3000);
valueAnimator.addUpdateListener(new AnimatorUpdateListener() {
@Override
public void onAnimationUpdate(ValueAnimator animation) {
int i = (int) animation.getAnimatedValue();
value = i;
if (i < 10) {
backgroundColor = Color.RED;
invalidate();
} else if (i >= 10 && i < 20) {
backgroundColor = Color.BLUE;
invalidate();
} else if (i >= 20 && i < 30) {
backgroundColor = Color.RED;
invalidate();
} else if (i >= 30 && i < 40) {
backgroundColor = Color.BLUE;
invalidate();
} else if (i >= 40 && i < 50) {
backgroundColor = Color.RED;
invalidate();
} else if (i >= 50 && i < 60) {
backgroundColor = Color.BLUE;
invalidate();
} else if (i >= 60 && i < 70) {
backgroundColor = Color.RED;
invalidate();
} else if (i >= 70 && i < 80) {
backgroundColor = Color.BLUE;
invalidate();
} else if (i >= 80 && i < 90) {
backgroundColor = Color.RED;
invalidate();
} else if (i >= 90 && i < 100) {
backgroundColor = Color.BLUE;
invalidate();
} else if (i == 100) {
backgroundColor = Color.RED;
invalidate();
}
}
});
valueAnimator.start(); } public MyCustomView(Context context) {
this(context, null);
} @Override
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
int width = canvas.getWidth();
int height = canvas.getHeight(); canvas.drawColor(backgroundColor);
Paint paint = new Paint(Paint.ANTI_ALIAS_FLAG);
paint.setColor(Color.WHITE); canvas.drawLine(0, height / 2, width, height / 2, paint);
canvas.drawLine(width / 2, 0, width / 2, height, paint); // 将圆点移动到屏幕中央
canvas.translate(width / 2, height / 2); // 开始画圆,最外层,第一个圆
canvas.drawArc(new RectF((0 - width / 4), (0 - width / 4), width / 4, width / 4), 180, 180, true, paint);
// 第二个圆
Paint p2 = new Paint(Paint.ANTI_ALIAS_FLAG);
p2.setColor(backgroundColor);
canvas.drawArc(new RectF((0 - width / 4 + 5), (0 - width / 4 + 5), width / 4 - 5, width / 4 - 5), 180, 180,
true, p2);
// 第三个圆
Paint p3 = new Paint(Paint.ANTI_ALIAS_FLAG);
p3.setColor(Color.argb(255, 255, 240, 255));
canvas.drawArc(new RectF((0 - width / 4 + 30), (0 - width / 4 + 30), width / 4 - 30, width / 4 - 30), 180, 180,
true, p3);
// 第四个圆
Paint p4 = new Paint(Paint.ANTI_ALIAS_FLAG);
p4.setColor(backgroundColor);
canvas.drawArc(new RectF((0 - width / 4 + 55), (0 - width / 4 + 55), width / 4 - 55, width / 4 - 55), 180, 180,
true, p4); // 开始画刻度
Paint p5 = new Paint(Paint.ANTI_ALIAS_FLAG);
p5.setColor(Color.RED);
Paint p6 = new Paint(Paint.ANTI_ALIAS_FLAG);
p6.setColor(Color.BLUE);
p6.setTextSize(15); int count = 11;// 总刻度数目
for (int i = 0; i < count; i++) {
if (i % 5 == 0) {
canvas.drawLine((0 - width / 4 + 5), 0, (0 - width / 4 + 30), 0, p5);
canvas.drawText(String.valueOf(i * 10), (0 - width / 4 + 30), 0, p6);
} else {
canvas.drawLine((0 - width / 4 + 15), 0, (0 - width / 4 + 30), 0, p5);
canvas.drawText(String.valueOf(i * 10), (0 - width / 4 + 30), 0, p6);
}
canvas.rotate(18);
} canvas.rotate(-198); // 画最外层的指针
Paint pp = new Paint(Paint.ANTI_ALIAS_FLAG);
pp.setColor(Color.WHITE);
pp.setStrokeWidth(5);
for (int i = 0; i < value; i++) {
canvas.drawPoint((0 - width / 4), 0, pp);
canvas.rotate(1.8f);
}
canvas.rotate(0 - (value * 1.8f));
// 画数字
Paint ppp = new Paint(Paint.ANTI_ALIAS_FLAG);
ppp.setTextSize(width / 10); FontMetrics fontMetrics = ppp.getFontMetrics();
if (value < 10) {
canvas.drawText(value + "", fontMetrics.top / 4, 0, ppp);
} else {
canvas.drawText(value + "", fontMetrics.top / 2, 0, ppp);
}
}
}

MainActivity.java

package com.example.testcustomview;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText; public class MainActivity extends Activity { private MyCustomView custom_view;
private Button bt;
private EditText et; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); et = (EditText) findViewById(R.id.et);
bt = (Button) findViewById(R.id.bt);
custom_view = (MyCustomView) findViewById(R.id.custom_view);
bt.setOnClickListener(new View.OnClickListener() { @Override
public void onClick(View v) {
custom_view.setSocre(Integer.valueOf(et.getText().toString()));
}
});
}
}

自定义View(三),仿支付宝芝麻信用自定义控件的更多相关文章

  1. iOS仿支付宝芝麻信用仪表盘效果

    概述 自定义View之高仿支付宝芝麻信用分数仪表盘动画效果 详细 代码下载:http://www.demodashi.com/demo/10654.html 仿支付宝芝麻信用仪表盘效果 一.主要思路 ...

  2. Android 自定义View,仿微信视频播放按钮

    闲着,尝试实现了新版微信视频播放按钮,使用的是自定义View,先来个简单的效果图...真的很简单哈. 由于暂时用不到,加上时间原因,加上实在是没意思,加上……,本控件就没有实现自定义属性,有兴趣的朋友 ...

  3. android自定义View之仿通讯录侧边栏滑动,实现A-Z字母检索

    我们的手机通讯录一般都有这样的效果,如下图: OK,这种效果大家都见得多了,基本上所有的android手机通讯录都有这样的效果.那我们今天就来看看这个效果该怎么实现. 一.概述 1.页面功能分析 整体 ...

  4. 自定义View(三)--实现一个简单地流式布局

    Android中的流式布局也就是常说的瀑布流很是常见,不仅在很多项目中都能见到,而且面试中也有很多面试官问道,那么什么是流式布局呢?简单来说就是如果当前行的剩余宽度不足以摆放下一个控件的时候,则自动将 ...

  5. Android自定义view之仿微信录制视频按钮

    本文章只写了个类似微信的录制视频的按钮,效果图如下:             一.主要的功能: 1.长按显示进度条,单击事件,录制完成回调 2.最大时间和最小时间控制 3.进度条宽度,颜色设置 二.实 ...

  6. Android 自定义View (三) 圆环交替 等待效果

    转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/24500107 一个朋友今天有这么个需求(下图),我觉得那自定义View来做还是很 ...

  7. Android自定义View实现仿QQ实现运动步数效果

    效果图: 1.attrs.xml中 <declare-styleable name="QQStepView"> <attr name="outerCol ...

  8. Android 自定义View修炼-仿QQ5.0 的侧滑菜单效果的实现

    有一段时间没有写博客了,最近比较忙,没什么时间写,刚好今天有点时间, 我就分享下,侧滑菜单的实现原理,一般android侧滑的实现原理和步骤如下:(源码下载在下面最后给出哈) 1.使用ViewGrou ...

  9. Android 自定义View修炼-仿360手机卫士波浪球进度的实现

    像360卫士的波浪球进度的效果,一般最常用的方法就是 画线的方式,先绘sin线或贝塞尔曲线,然后从左到右绘制竖线,然后再裁剪圆区域. 今天我这用图片bitmap的方式,大概的方法原理是: (1)首先用 ...

随机推荐

  1. ESA2GJK1DH1K基础篇: 购买云服务器

    我选择的是购买阿里云的服务器 如果是学生,可以选择 因为我用学生账户买过了,所以过程没法写了,下面我就写不用学生账户买的过程,其实应该配置过程和学生买差不多 选择购买的配置 选择系统 不需要配置直接下 ...

  2. django命名url与url反向解析

    1.在urls.py路由中指定别名 2.在views.py视图文件中导入from django.shortcuts import render, redirect, reverse 3.也可从这里导入 ...

  3. selenium--拖拽页面元素

    from selenium import webdriver import unittest from selenium.webdriver import ActionChains import ti ...

  4. MySQL数据库索引类型、MySQL索引的优化及MySQL索引案例

    关于MySQL索引的好处,如果正确合理设计并且使用索引的MySQL是一辆兰博基尼的话,那么没有设计和使用索引的MySQL就是一个人力三轮车.对于没有索引的表,单表查询可能几十万数据就是瓶颈,而通常大型 ...

  5. 动态规划:数字和为sum的方法数

    题目描述 给定一个有n个正整数的数组A和一个整数sum,求选择数组A中部分数字和为sum的方案数.当两种选取方案有一个数字的下标不一样,我们就认为是不同的组成方案. 输入描述: 输入为两行: 第一行为 ...

  6. 洛谷 p1047 校门外的树 线段树做法

    非常easy, 注意一下它是两端开始,也就是说0的位置也有一棵树就好了 我由于太弱了,一道红题交了4,5遍 由于树的砍了就没了,lazy标记最大就是1; 直接贴代码吧 #include<bits ...

  7. spark基础知识三

    主要围绕spark的底层核心抽象RDD和原理进行理解.主要包括以下几个方面 RDD弹性分布式数据集的依赖关系 RDD弹性分布式数据集的lineage血统机制 RDD弹性分布式数据集的缓存机制 spar ...

  8. vue bootstrap中modal对话框不显示遮挡打不开

    使用Vue bootstrap时,点击modal却不能弹出来,被隐藏遮挡无法显示,参考下面的这个博客的说明解决了这个问题: Heap Stack Blog(pingbook.top)Vue boots ...

  9. GitHub 上传文件过大报错:remote: error: GH001: Large files detected.

    1.查看哪个文件过大了 报错信息: remote: Resolving deltas: 100% (24/24), completed with 3 local objects. remote: wa ...

  10. JUC锁框架_AbstractQueuedSynchronizer详细分析

      AQS是JUC锁框架中最重要的类,通过它来实现独占锁和共享锁的.本章是对AbstractQueuedSynchronizer源码的完全解析,分为四个部分介绍: CLH队列即同步队列:储存着所有等待 ...