画年利率 画图 自定义 View
使用
SlbSyView slbView;slbView = (SlbSyView) findViewById(R.id.slbView);slbView.setHeights(new float[]{2.1112f, 2.2311f, 2.3001f, 2.1234f, 2.3421f, 2.0015f, 2.3256f});slbView.setVisibility(View.VISIBLE);<com.bcb.presentation.view.custom.SlbSyViewandroid:id="@+id/slbView"android:layout_width="wrap_content"android:layout_height="125dp"android:layout_below="@+id/title"android:visibility="invisible"/>
自定义View
package com.bcb.presentation.view.custom;import android.content.Context;import android.graphics.Canvas;import android.graphics.Color;import android.graphics.Paint;import android.graphics.Path;import android.graphics.RectF;import android.util.AttributeSet;import android.util.DisplayMetrics;import android.view.View;import android.view.WindowManager;/*** 描述:生利宝收益* 作者:baicaibang* 时间:2016/8/15 09:34*/public class SlbSyView extends View {Context context;Paint paint;Path path;//用于绘制复杂的图形轮廓,比如折线,圆弧以及各种复杂图案int width, height;//表格的宽高int widthBlank, heightBlank;//表格距离左侧、顶部的空白距离static final int WIDTH_MAX = 6;//View的相对宽高(7个);WIDTH_MAX是不会变的float heightMax = 7.0f;//heightMax是根据需要随便改变;float[] heights = new float[WIDTH_MAX + 1];//高度值float heightOffset = 0.1f;//偏差,根据需要设置float y6Value;//最后一个坐标的值public SlbSyView(Context context) {this(context, null);}public SlbSyView(Context context, AttributeSet attrs) {super(context, attrs);this.context = context;init();}private void init() {paint = new Paint();path = new Path();paint.setAntiAlias(true);paint.setDither(true);heightBlank = dp2px(20);widthBlank = dp2px(35);width = getScreenWidth(context) - widthBlank*2;height = dp2px(100);}public void setHeights(float[] heights) {if (heights.length != 7) throw new RuntimeException("长度不对");y6Value = heights[6];heightMax = getMaxValue(heights) - getMinValue(heights) + heightOffset * 2;//根据需要设置for (int i = 0; i < heights.length; i++) {this.heights[i] = getMaxValue(heights) + heightOffset - heights[i];//根据需要设置}invalidate();}@Overrideprotected void onDraw(Canvas canvas) {super.onDraw(canvas);canvas.drawColor(Color.WHITE);//1、画背景paint.setColor(0x1adb3838);//10%透明度paint.setStyle(Paint.Style.FILL);path.moveTo(widthBlank, height + heightBlank);//指定初始轮廓点,若没指定默认从(0,0)点开始for (int i = 0; i < heights.length; i++) {path.lineTo(widthBlank + width * i / WIDTH_MAX, //中间的点heightBlank + height * heights[i] / heightMax);}path.lineTo(widthBlank + width, heightBlank + height);//最后的一个点path.close(); // 回到初始点形成封闭的曲线canvas.drawPath(path, paint);//2、画基准线条。每条线都需要两个坐标(注意,是每两个值组成一个坐标)paint.setStrokeWidth(dp2px(0.5f));//设置画笔粗细,单位为像素paint.setColor(0xff999999);float[] points = new float[7 * 4];//坐标//画7条竖线for (int i = 0; i < points.length; i += 4) {points[i] = widthBlank + width * i / (4 * WIDTH_MAX);points[i + 1] = heightBlank;points[i + 2] = points[i];points[i + 3] = heightBlank + height;}canvas.drawLines(points, paint);//画2条横线canvas.drawLine(widthBlank, heightBlank, //widthBlank + width, heightBlank, paint);canvas.drawLine(widthBlank, heightBlank + height,//widthBlank + width, heightBlank + height, paint);//3、画利率线paint.setColor(0xffdb3838);paint.setStrokeWidth(dp2px(2));for (int i = 0; i < heights.length - 1; i++) {//注意遍历条件 heights.length - 1canvas.drawLine(widthBlank + width * i / WIDTH_MAX, //heightBlank + height * heights[i] / heightMax, //widthBlank + width * (i + 1) / WIDTH_MAX, //heightBlank + height * heights[i + 1] / heightMax, paint);}//4、画圆形float x6Point = widthBlank + width * 6 / WIDTH_MAX;float y6Point = heightBlank + height * heights[6] / heightMax;//画白色的实心圆圆paint.setStyle(Paint.Style.FILL);paint.setColor(Color.WHITE);canvas.drawCircle(x6Point, y6Point, dp2px(4), paint);//画空心圆paint.setStyle(Paint.Style.STROKE);paint.setColor(0xffdb3838);canvas.drawCircle(x6Point, y6Point, dp2px(4), paint);//圆心坐标,半径//5、画文本(今天的年利率)//画圆角矩形paint.setStyle(Paint.Style.FILL);RectF rect = new RectF(x6Point - dp2px(25), y6Point - dp2px(30), //左上角坐标x6Point + dp2px(25), y6Point - dp2px(10));//右下角坐标canvas.drawRoundRect(rect, dp2px(3), dp2px(3), paint);//两侧圆角弧度的大小//画文字paint.setColor(Color.WHITE);paint.setTextSize(dp2px(13));//单位是px,只在绘制文字时有效paint.setTextAlign(Paint.Align.CENTER);//绘制的文字以drawText时指定的 float x 水平居中,默认值是Align.LEFTcanvas.drawText(y6Value + "", rect.centerX(),//rect.centerY() + dp2px(4.5f), paint);//注意 float y 代表的是 baseline 的值,也即e和f的下边界,而非g的下边界}private int dp2px(float dpValue) {float scale = context.getResources().getDisplayMetrics().density;return (int) (dpValue * scale + 0.5f);}/*** 获取屏幕宽*/public static int getScreenWidth(Context context) {DisplayMetrics metric = new DisplayMetrics();((WindowManager) context.getSystemService(Context.WINDOW_SERVICE)).getDefaultDisplay().getMetrics(metric);return metric.widthPixels;}/*** 取最大值*/public static float getMaxValue(float[] a) {float temp = a[0];for (int i = 0; i < a.length; i++) {if (a[i] > temp) temp = a[i];}return temp;}/*** 取最小值*/public static float getMinValue(float[] a) {float temp = a[0];for (int i = 0; i < a.length; i++) {if (a[i] < temp) temp = a[i];}return temp;}}
画年利率 画图 自定义 View的更多相关文章
- android画虚线的自定义VIew
package com.yesway.ycarplus.view; import android.annotation.SuppressLint; import android.content.Con ...
- Android自定义View 画弧形,文字,并增加动画效果
一个简单的Android自定义View的demo,画弧形,文字,开启一个多线程更新ui界面,在子线程更新ui是不允许的,但是View提供了方法,让我们来了解下吧. 1.封装一个抽象的View类 B ...
- Android -- 自定义View小Demo,动态画圆(一)
1,转载:(http://blog.csdn.NET/lmj623565791/article/details/24500107),现在如下图的效果: 由上面的效果图可以看到其实是一个在一个圆上换不同 ...
- 28 自定义View画坐标和柱状图
自定义View类 RectView.java package com.qf.sxy.day29_customview.widget; import android.content.Context; i ...
- 手把手带你画一个漂亮蜂窝view Android自定义view
上一篇做了一个水波纹view 不知道大家有没有动手试试呢点击打开链接 这个效果做起来好像没什么意义,如果不加监听回调 图片就能直接替代.写这篇博客的目的是锻炼一下思维能力,以更好的面多各种自定义vi ...
- 手把手带你画一个 时尚仪表盘 Android 自定义View
拿到美工效果图,咱们程序员就得画得一模一样. 为了不被老板喷,只能多练啊. 听说你觉得前面几篇都so easy,那今天就带你做个相对比较复杂的. 转载请注明出处:http://blog.csdn.ne ...
- Android之自定义View以及画一个时钟
https://www.2cto.com/kf/201509/443112.html 概述: 当Android自带的View满足不了开发者时,自定义View就发挥了很好的作用.建立一个自定义View, ...
- [原] Android 自定义View步骤
例子如下:Android 自定义View 密码框 例子 1 良好的自定义View 易用,标准,开放. 一个设计良好的自定义view和其他设计良好的类很像.封装了某个具有易用性接口的功能组合,这些功能能 ...
- Android -- 自定义View小Demo,绘制钟表时间(一)
1,昨天刚看了hongyang大神推荐的自定义时钟效果(传动门:http://www.jianshu.com/users/a45d19d680af/),效果还是不错的,自己又在github上找了找,发 ...
随机推荐
- 在VC6中使用ogre进行游戏开发
微软公司开发的visual c++6.0堪称史上最易用.最成熟的开发工具.vc6以其小巧.轻便赢得了程序员的喜爱,以至于在VS大行其道的时代,很多程序员仍然使用vc6作为开发工具,vc6的欢迎性可见一 ...
- 【USACO 2.2.4】派对灯
[描述] 在IOI98的节日宴会上,我们有N(10<=N<=100)盏彩色灯,他们分别从1到N被标上号码. 这些灯都连接到四个按钮: 按钮1:当按下此按钮,将改变所有的灯:本来亮着的灯就熄 ...
- angularJS中如何写服务
服务的用途 服务提供了一种能在应用的整个生命周期内保持数据的方法,它能够在控制器之间进行通信,并且能保证数据的一致性 服务提供了把特定功能相关联的方法集中在一起的接口 如何创建服务 angularJS ...
- Subversion 1.7 Eclipse integration in Ubuntu12(转载)
原文链接:http://steveliles.github.io/subversion_1_7_eclipse_integration_in_ubuntu.html Getting Subversio ...
- [转]JavaScript函数和数组总结
转自:http://www.uml.org.cn/AJAX/201307264.asp 写的不错,对我有很多帮助,最近准备全面的学习研究一下ES5,先转载一下这篇文章. JavaScript函数 1. ...
- python二进制文件解析
struct.pack(): struct.pack用于将Python的值根据格式符,转换为字符串(因为Python中没有字节(Byte)类型,可以把这里的字符串理解为字节流,或字节数组).其函数原型 ...
- nginx+tomcat 配置虚拟目录。。
之前nginx作为代理.之前的location写的太绝对了..之前把动态请求全部交给tomcat,然后需要配置虚拟路径的时候,去到tomcat就被404了.得高人指点之后,配置虚拟目录的时候需要重新写 ...
- 直接引用windows命名空间
再逛博客的时候,看见一段这样代码.获取系统密码的 static void DumpCredentials(Windows.Security.Credentials.PasswordCredential ...
- Period
uvalive3026:https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&pag ...
- hdu 4545 魔法串
http://acm.hdu.edu.cn/showproblem.php?pid=4545 #include <cstdio> #include <cstring> #inc ...
