自定义View(三),仿支付宝芝麻信用自定义控件
仿支付宝的芝麻信用仪表盘

实现的效果

实现的功能:
指针和数字动态改变
背景动态变化
没了...
代码如下
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(三),仿支付宝芝麻信用自定义控件的更多相关文章
- iOS仿支付宝芝麻信用仪表盘效果
概述 自定义View之高仿支付宝芝麻信用分数仪表盘动画效果 详细 代码下载:http://www.demodashi.com/demo/10654.html 仿支付宝芝麻信用仪表盘效果 一.主要思路 ...
- Android 自定义View,仿微信视频播放按钮
闲着,尝试实现了新版微信视频播放按钮,使用的是自定义View,先来个简单的效果图...真的很简单哈. 由于暂时用不到,加上时间原因,加上实在是没意思,加上……,本控件就没有实现自定义属性,有兴趣的朋友 ...
- android自定义View之仿通讯录侧边栏滑动,实现A-Z字母检索
我们的手机通讯录一般都有这样的效果,如下图: OK,这种效果大家都见得多了,基本上所有的android手机通讯录都有这样的效果.那我们今天就来看看这个效果该怎么实现. 一.概述 1.页面功能分析 整体 ...
- 自定义View(三)--实现一个简单地流式布局
Android中的流式布局也就是常说的瀑布流很是常见,不仅在很多项目中都能见到,而且面试中也有很多面试官问道,那么什么是流式布局呢?简单来说就是如果当前行的剩余宽度不足以摆放下一个控件的时候,则自动将 ...
- Android自定义view之仿微信录制视频按钮
本文章只写了个类似微信的录制视频的按钮,效果图如下: 一.主要的功能: 1.长按显示进度条,单击事件,录制完成回调 2.最大时间和最小时间控制 3.进度条宽度,颜色设置 二.实 ...
- Android 自定义View (三) 圆环交替 等待效果
转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/24500107 一个朋友今天有这么个需求(下图),我觉得那自定义View来做还是很 ...
- Android自定义View实现仿QQ实现运动步数效果
效果图: 1.attrs.xml中 <declare-styleable name="QQStepView"> <attr name="outerCol ...
- Android 自定义View修炼-仿QQ5.0 的侧滑菜单效果的实现
有一段时间没有写博客了,最近比较忙,没什么时间写,刚好今天有点时间, 我就分享下,侧滑菜单的实现原理,一般android侧滑的实现原理和步骤如下:(源码下载在下面最后给出哈) 1.使用ViewGrou ...
- Android 自定义View修炼-仿360手机卫士波浪球进度的实现
像360卫士的波浪球进度的效果,一般最常用的方法就是 画线的方式,先绘sin线或贝塞尔曲线,然后从左到右绘制竖线,然后再裁剪圆区域. 今天我这用图片bitmap的方式,大概的方法原理是: (1)首先用 ...
随机推荐
- C语言实现FTP服务器
公共部分代码 /* common.h */ #ifndef COMMON_H #define COMMON_H #include <arpa/inet.h> #include <ct ...
- 批量转换文件字符编码(GBK转UTF-8)
今天收到一份代码,拖到IDE中发现乱码,看来下编码是GBK的(
- How to convert a std::string to const char* or char*?
How to convert a std::string to const char* or char*? 1. If you just want to pass a std::string to a ...
- 每日一问:详细说一下 MeasureSpec.UNSPECIFIED
详细说一下 MeasureSpec.UNSPECIFIED 前面的文章 我留下了一个疑惑,那就是到底为什么 NestedScrollView 要把子 View 的测量模式强行设置为 MeasureSp ...
- rabbitmq安装集群
centos 7.3 64 172.18.39.241 k8s-mini-241172.18.39.242 k8s-mini-242172.18.39.243 k8s-master-243 vim / ...
- Redis NOAUTH Authentication required
redis设置密码后停止服务报错,NOAUTH Authentication required 可以修改/etc/init.d/redis文件中的stop命令 $CLIEXEC -p $REDISPO ...
- Python【每日一问】28
问: [基础题]:求 1+2!+3!+...+20! 的和 [提高题]:两个乒乓球队进行比赛,各出三人.甲队为 a,b,c 三人,乙队为 x,y,z 三人.已抽签决定比赛名单. 有人向队员打听比赛的名 ...
- hread.interrupt()到底意味着什么
首先,一个线程不应该由其他线程来强制中断或停止,而是应该由线程自己自行停止. 所以,Thread.stop, Thread.suspend, Thread.resume 都已经被废弃了.而 Threa ...
- angualr post 数据请求
数据请求 post 新建一个服务 1. ng g service services /+服务名 eg:ng g service services/player 在此服务中进行设置 引入自带组件以及注 ...
- Run-Time Check Failure #0 - The value of ESP was not properly saved across a function call错误
我这边新增的接口之后编译,启动debug后提示这个问题, 在网上找了一段时间,感觉各大神说的都好有道理,但是没有作用 so,尝试对整个工程重新编译(理论上只要重新编译修改的文件影响到的地方)