自定义控件学习之绘制刻度盘

2023-11-05 12:10

本文主要是介绍自定义控件学习之绘制刻度盘,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

以前面试的时候面试官问过我会不会写标尺工具,我没做过呀,然后胡乱的说什么画布,ondraw绘制。。然后就没有然后了--!,现在想想真的有点囧。所以今天我试了下自己画刻度盘,不是很难,只有方法对了,轻轻松松。。大神勿喷,这是菜鸟的日常(高手退散退散。。巴拉巴拉能量**>_<**)

还是老样子,代码写到最后都是规律,就和学习一样,第一步在onMeasure方法中去计算控件的宽高,你也可以不写,但是在wrap_content的时候回很蛋疼····上代码
/**
 * 第一步
 */
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {int width =measureDim(widthMeasureSpec,150);
    int height = measureDim(heightMeasureSpec,150);
    if (width!=height){width=Math.max(width,height);
        height =width;
    }setMeasuredDimension(width,height);
    initView();
}public int measureDim(int Spec,int defultsize){int result;
    int mode = MeasureSpec.getMode(Spec);
    int size = MeasureSpec.getSize(Spec);
    if (mode==MeasureSpec.EXACTLY){result =size;
    }else {result =defultsize;
        if (mode==MeasureSpec.AT_MOST){result =Math.min(size,defultsize);
        }}return result;

}

public void initView(){cPaint = new Paint();
    cPaint.setAntiAlias(true);
    cPaint.setColor(Color.BLUE);
    cPaint.setStyle(Paint.Style.STROKE);
    cPaint.setStrokeWidth(2);
    cPaint.setTextSize(12);
    list = new ArrayList<>();

}
第二步画一个圆

@Override
protected void onDraw(Canvas canvas) {radio =getMeasuredWidth()/2-20;
    canvas.drawCircle(radio,radio,radio,cPaint);
    canvas.drawPoint(radio,radio,cPaint);
    scaleCount(canvas);
}
第三步就是对刻度坐标的计算,根据计算每个刻度是6度,那么就简单了
/**
 * 表盘刻度的计算,绘制
 */
private void scaleCount(Canvas canvas){double startx;
    double starty;
    double endx;
    double endy;
    for (int i=0;i<60;i++){if (i%5==0){endx= Math.sin( Math.toRadians(i*6))*(radio/2+10)+radio;
            endy = radio-Math.cos( Math.toRadians(i*6))*(radio/2+10);

            /*
            这段绘制刻度值有点问题字歪的 ,以后改善
             */
         /*
            double textX = Math.sin( Math.toRadians(i*6))*(radio/2+9)+radio;
            double textY = radio-Math.cos( Math.toRadians(i*6))*(radio/2+9);
            canvas.drawText((i/5==0?12:i/5)+"",(float) textX,(float)textY,cPaint);*/
        }else {endx= Math.sin( Math.toRadians(i*6))*(radio-10)+radio;
            endy = radio-Math.cos( Math.toRadians(i*6))*(radio-10);
        }startx  =Math.sin( Math.toRadians(i*6))*(radio)+radio;
        starty  = radio-Math.cos( Math.toRadians(i*6))*(radio);
        Line line = new Line(startx,starty,endx,endy);
        list.add(line);
    }drawLine(canvas);
}public void drawLine(Canvas canvas){cPaint.reset();
    cPaint.setColor(Color.BLACK);
    cPaint.setStyle(Paint.Style.FILL);
    cPaint.setAntiAlias(true);
    for (int i=0;i<list.size();i++){canvas.drawLine((float) list.get(i).getStartx(),(float)list.get(i).getStarty(),(float)list.get(i).getEndx(),
                (float)list.get(i).getEndy(),cPaint);
    }
}
大功告成
效果就这样


很简单,其他功能或者有趣的东西我以后可能回去加,就当学习一种思路,有些东西你去试过以后就不会感觉它高不可攀了。。

这篇关于自定义控件学习之绘制刻度盘的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/349760

相关文章

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

CSS自定义浏览器滚动条样式完整代码

《CSS自定义浏览器滚动条样式完整代码》:本文主要介绍了如何使用CSS自定义浏览器滚动条的样式,包括隐藏滚动条的角落、设置滚动条的基本样式、轨道样式和滑块样式,并提供了完整的CSS代码示例,通过这些技巧,你可以为你的网站添加个性化的滚动条样式,从而提升用户体验,详细内容请阅读本文,希望能对你有所帮助...

C#实现WinForm控件焦点的获取与失去

《C#实现WinForm控件焦点的获取与失去》在一个数据输入表单中,当用户从一个文本框切换到另一个文本框时,需要准确地判断焦点的转移,以便进行数据验证、提示信息显示等操作,本文将探讨Winform控件... 目录前言获取焦点改变TabIndex属性值调用Focus方法失去焦点总结最后前言在一个数据输入表单

使用Python绘制蛇年春节祝福艺术图

《使用Python绘制蛇年春节祝福艺术图》:本文主要介绍如何使用Python的Matplotlib库绘制一幅富有创意的“蛇年有福”艺术图,这幅图结合了数字,蛇形,花朵等装饰,需要的可以参考下... 目录1. 绘图的基本概念2. 准备工作3. 实现代码解析3.1 设置绘图画布3.2 绘制数字“2025”3.3

使用Python绘制可爱的招财猫

《使用Python绘制可爱的招财猫》招财猫,也被称为“幸运猫”,是一种象征财富和好运的吉祥物,经常出现在亚洲文化的商店、餐厅和家庭中,今天,我将带你用Python和matplotlib库从零开始绘制一... 目录1. 为什么选择用 python 绘制?2. 绘图的基本概念3. 实现代码解析3.1 设置绘图画

Python绘制土地利用和土地覆盖类型图示例详解

《Python绘制土地利用和土地覆盖类型图示例详解》本文介绍了如何使用Python绘制土地利用和土地覆盖类型图,并提供了详细的代码示例,通过安装所需的库,准备地理数据,使用geopandas和matp... 目录一、所需库的安装二、数据准备三、绘制土地利用和土地覆盖类型图四、代码解释五、其他可视化形式1.

如何用Python绘制简易动态圣诞树

《如何用Python绘制简易动态圣诞树》这篇文章主要给大家介绍了关于如何用Python绘制简易动态圣诞树,文中讲解了如何通过编写代码来实现特定的效果,包括代码的编写技巧和效果的展示,需要的朋友可以参考... 目录代码:效果:总结 代码:import randomimport timefrom math

SpringBoot 自定义消息转换器使用详解

《SpringBoot自定义消息转换器使用详解》本文详细介绍了SpringBoot消息转换器的知识,并通过案例操作演示了如何进行自定义消息转换器的定制开发和使用,感兴趣的朋友一起看看吧... 目录一、前言二、SpringBoot 内容协商介绍2.1 什么是内容协商2.2 内容协商机制深入理解2.2.1 内容

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用