Android自定义控件实现雷达图效果

 更新时间:2022年09月05日 14:45:18   作者:芒果蜜桃π  
这篇文章主要为大家详细介绍了Android自定义控件实现雷达图效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了Android自定义控件实现雷达图的具体代码,供大家参考,具体内容如下

学习了大神的源代码(奈何不知大神的博客地址),觉得必须记录一下,方便以后再次学习。

效果如图所示:

1.自定义雷达图控件:

public class MyPolygonView extends View {

    //-------------我们必须给的模拟数据-------------
    //n边形
    private int n = 6;
    //每个角对应的文字
    private String[] text = new String[]{"语文", "数学", "英语", "生物", "化学","物理"};
    //区域等级,值不能超过n边形的个数(每个角对应的值到达的层数)
    private int[] area = new int[]{3,3,2,2,3,2};

    //-------------View相关-------------
    //View自身的宽和高
    private int mHeight;
    private int mWidth;

    //-------------画笔相关-------------
    //边框的画笔
    private Paint borderPaint;
    //文字的画笔
    private Paint textPaint;
    //区域的画笔
    private Paint areaPaint;

    //-------------多边形相关-------------
    //n边形个数
    private int num = 4;
    //两个多边形之间的半径
    private int r = 60;
    //n边形顶点坐标
    private float x, y;
    //n边形角度
    private float angle = (float) ((2 * Math.PI) / n);
    //文字与边框的边距等级,值越大边距越小(文字与边框的距离)
    private int textAlign = 5;

    //-------------颜色相关-------------
    //边框颜色(整个n边型的区域颜色)
    private int mColor = getResources().getColor(R.color.app_polygon);
    //文字颜色
    private int textColor = getResources().getColor(R.color.app_black);
    //区域颜色(整个连线的颜色)
    private int strengthColor = Color.parseColor("#f9c172");

    public MyPolygonView(Context context) {
        super(context);
    }

    public MyPolygonView(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    public MyPolygonView(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
    }

    @Override
    protected void onSizeChanged(int w, int h, int oldw, int oldh) {
        super.onSizeChanged(w, h, oldw, oldh);
        mWidth = w;
        mHeight = h;
    }

    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        //初始化画笔
        initPaint();
        //画布移到中心点
        canvas.translate(mWidth / 2, mHeight / 2);
        //画n边形
        drawPolygon(canvas);
        //画n边形的中点到顶点的线
        drawLine(canvas);
        //画文字
        drawText(canvas);
        //画蓝色区域
        drawArea(canvas);
    }

    /**
     * 初始化画笔
     */
    private void initPaint() {
        //边框画笔
        borderPaint = new Paint();
        borderPaint.setAntiAlias(true);
        borderPaint.setStyle(Paint.Style.FILL_AND_STROKE);
        borderPaint.setColor(mColor);
        borderPaint.setStrokeWidth(3);

        //文字画笔
        textPaint = new Paint();
        textPaint.setTextSize(30);
        textPaint.setColor(textColor);
        textPaint.setAntiAlias(true);

        //区域画笔
        areaPaint = new Paint();
        areaPaint.setStrokeWidth(5);
        areaPaint.setColor(strengthColor);
        areaPaint.setAntiAlias(true);
        areaPaint.setStyle(Paint.Style.STROKE);
    }

    /**
     * 绘制多边形
     *
     * @param canvas
     */
    private void drawPolygon(Canvas canvas) {
        Path path = new Path();
        //n边形数目
        for (int j = 1; j <= num; j++) {
            float r = j * this.r;
            path.reset();
            //画n边形
            for (int i = 1; i <= n; i++) {
                x = (float) (Math.cos(i * angle) * r);
                y = (float) (Math.sin(i * angle) * r);
                if (i == 1) {
                    path.moveTo(x, y);
                } else {
                    path.lineTo(x, y);
                }
            }
            //关闭当前轮廓。如果当前点不等于第一个点的轮廓,一条线段是自动添加的
            path.close();
            canvas.drawPath(path, borderPaint);
        }
    }

    /**
     * 画多边形线段
     *
     * @param canvas
     */
    private void drawLine(Canvas canvas) {
        Path path = new Path();
        float r = num * this.r;
        for (int i = 1; i <= n; i++) {
            path.reset();
            x = (float) (Math.cos(i * angle) * r);
            y = (float) (Math.sin(i * angle) * r);
            path.lineTo(x, y);
            canvas.drawPath(path, borderPaint);
        }
    }

    /**
     * 画文字
     *
     * @param canvas
     */
    private void drawText(Canvas canvas) {
        float r = num * this.r;
        for (int i = 1; i <= n; i++) {
            //测量文字的宽高
            Rect rect = new Rect();
            textPaint.getTextBounds(text[i - 1], 0, text[i - 1].length(), rect);
            float textWidth = rect.width();
            float textHeight = rect.height();

            x = (float) (Math.cos(i * angle) * r);
            y = (float) (Math.sin(i * angle) * r);
            //位置微调
            if (x < 0) {
                x = x - textWidth;
            }
            if (y > 25) {
                y = y + textHeight;
            }
            //调文字与边框的边距
            float LastX = x + x / num / textAlign;
            float LastY = y + y / num / textAlign;
            canvas.drawText(text[i - 1],LastX, LastY, textPaint);
        }
    }

    /**
     * 画区域
     *
     * @param canvas
     */
    private void drawArea(Canvas canvas) {
        Path path = new Path();
        for (int  i= 1;  i<= n; i++) {
            float r = area[i - 1] * this.r;
            x = (float) (Math.cos(i * angle) * r);
            y = (float) (Math.sin(i * angle) * r);
            if (i == 1) {
                path.moveTo(x, y);
            } else {
                path.lineTo(x, y);
            }
        }
        //关闭当前轮廓。如果当前点不等于第一个点的轮廓,一条线段是自动添加的
        path.close();
        canvas.drawPath(path, areaPaint);
    }
    public void setArea (int[] area){
        this.area =area;
        invalidate();
    }

}

2.界面布局文件xml中直接使用:

<com.lotus.chartspagedemo.MyPolygonView
                android:id="@+id/polygon"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:visibility="visible" />

3.界面activity中可以设置控件颜色:

polygon.setBackgroundColor(getResources().getColor(R.color.app_blue));//雷达图的背景颜色

如果不设置背景颜色,效果就是:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 浅谈 Android 7.0 多窗口分屏模式的实现

    浅谈 Android 7.0 多窗口分屏模式的实现

    这篇文章主要介绍了浅谈 Android 7.0 多窗口分屏模式的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-03-03
  • Android Intent传递数据大小限制详解

    Android Intent传递数据大小限制详解

    这篇文章主要给大家介绍了关于Android Intent传递数据大小限制的相关资料,文中通过示例代码介绍的非常详细,对各位Android开发者们具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-04-04
  • Android实现上拉吸顶效果

    Android实现上拉吸顶效果

    这篇文章主要为大家详细介绍了Android实现上拉吸顶效果,上滑标题固定在顶部,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • Android编程实现将tab选项卡放在屏幕底部的方法

    Android编程实现将tab选项卡放在屏幕底部的方法

    这篇文章主要介绍了Android编程实现将tab选项卡放在屏幕底部的方法,涉及Android界面布局、tab设置及权限控制相关操作技巧,需要的朋友可以参考下
    2017-03-03
  • 详解Android中Handler的使用方法

    详解Android中Handler的使用方法

    这篇文章主要介绍了Android中Handler的使用方法,对Android中Handler的作用于如何使用进行了初步介绍,需要的朋友可以参考下
    2015-12-12
  • Android常用的intent action汇总

    Android常用的intent action汇总

    这篇文章主要介绍了Android常用的intent action功能与用法,分析了intent的原理以及action属性常用动作名称、作用与使用方法,需要的朋友可以参考下
    2016-10-10
  • Android FTP 多线程断点续传下载\上传的实例

    Android FTP 多线程断点续传下载\上传的实例

    本篇文章主要介绍了Android FTP 多线程断点续传下载\上传的实例,具有一定的参考价值,有兴趣的可以了解一下
    2017-08-08
  • Android 动态改变SeekBar进度条颜色与滑块颜色的实例代码

    Android 动态改变SeekBar进度条颜色与滑块颜色的实例代码

    在上次android开发的项目中遇到个这样的需求,要动态改变seekbar进度条颜色与滑块颜色的需求,实现代码也算比较简单,对实现过程感兴趣的朋友可以通过本文学习下
    2016-11-11
  • Android编程实现屏幕自适应方向尺寸与分辨率的方法

    Android编程实现屏幕自适应方向尺寸与分辨率的方法

    这篇文章主要介绍了Android编程实现屏幕自适应方向尺寸与分辨率的方法,涉及Android屏幕分辨率、布局、横竖屏切换等相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-12-12
  • Android冷启动实现app秒开的实现代码

    Android冷启动实现app秒开的实现代码

    本篇文章主要介绍了Android冷启动实现app秒开的实现代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-08-08

最新评论