Android 自定义View 画圆(奥运五环)

然后我们在activity_main.xml使用这个Custom,自定义View使用时需要完整的包名路径,如下所示

在这里插入图片描述

现在你运行可以运行一下,不管是真机还是模拟器都可以,先确保你的项目没有问题,这样出现问题的时候可以少排查一个因素,这是实际开发总结出来的。不过你运行之后会是一片空白,因为什么都没有。

下面在CustomView写下如下代码

/**

  • 在纸上画画 (通俗理解)

  • @param canvas 纸

*/

@Override

protected void onDraw(Canvas canvas) {

super.onDraw(canvas);

Paint paint = new Paint();//创建画笔对象 笔

paint.setColor(Color.BLACK);//设置颜色

paint.setStyle(Paint.Style.STROKE);//画笔样式为空心,也可以理解为描边

paint.setStrokeWidth(4);//描边的宽度

paint.setAntiAlias(true);//抗锯齿(去掉锯齿)

/**

  • 画圆

  • 参数一:圆心的X轴坐标

  • 参数二:圆心的Y轴坐标

  • 参数三:圆的半径

  • 参数四:画笔对象

*/

canvas.drawCircle(150,150,100,paint);//完成

}

我相信注释得已经很清楚了,这个时候你运行一下,就会看到一个黑色的空心圆

在这里插入图片描述

然后再修改一下代码,画一个实心圆

在这里插入图片描述

再运行一下

在这里插入图片描述

**canvas.drawCircle(150,150,100,paint);**表示圆心在横坐标和纵坐标都为150的位置,以半径为100画一个圆,可以把这一行代码复制四次,然后改变半径的大小,为了看到效果,还是画空心圆

在这里插入图片描述

然后运行一下,就可以看到

在这里插入图片描述

是不是觉得有点意思了。平时像这种图案你会自己去画吗?还是找UI切图呢?

刚才我们只是改变了半径而已,下面试着改变横坐标和纵坐标。

我们试着画两个圆挨着,如果是横向挨着就要使一个圆的圆心横坐标位置等于另一个圆的圆心横坐标加上直径的和,刚才我们看到一个横坐标是150,半径是100,那么结果很明显第二个圆的圆心的位置就是350,这次我们不改变半径大小,只改变横坐标试一下

在这里插入图片描述

运行结果如下图

在这里插入图片描述

接下来运用这个思路来画一个奥运五环吧

在这里插入图片描述

运行效果如下图所示

在这里插入图片描述

除了没有颜色还是比较像的。你想要改颜色就可以自由改变setColor就可以了。下面改动一下代码

/**

  • 根据传入的颜色配置不同的画笔

  • @param color 颜色

  • @return

*/

private Paint customPaint(int color){

Paint paint = new Paint();//创建画笔对象 笔

paint.setColor(color);

paint.setStyle(Paint.Style.STROKE);

paint.setStrokeWidth(8);

paint.setAntiAlias(true);

return paint;

}

然后我们在onDraw中调用

/**

  • 在纸上画画 (通俗理解)

  • @param canvas 纸

*/

@Override

protected void onDraw(Canvas canvas) {

super.onDraw(canvas);

/**

  • 画圆

  • 参数一:圆心的X轴坐标

  • 参数二:圆心的Y轴坐标

  • 参数三:圆的半径

  • 参数四:画笔对象

*/

canvas.drawCircle(150,150,100,customPaint(Color.BLUE));//完成

canvas.drawCircle(370,150,100,customPaint(Color.BLACK));

canvas.drawCircle(590,150,100,customPaint(Color.RED));

canvas.drawCircle(260,250,100,customPaint(Color.YELLOW));

canvas.drawCircle(480,250,100,customPaint(Color.GREEN));

}

运行效果如下:

在这里插入图片描述

[

超强干货来袭
云风专访:近40年码龄,通宵达旦的技术人生
](https://newprogrammer.blog.csdn.net/article/details/124146229?utm_campaign=marketingcard&utm_source=qq_38436214&utm_content=107242851)

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

结语

看到这篇文章的人不知道有多少是和我一样的Android程序员。

35岁,这是我们这个行业普遍的失业高发阶段,这种情况下如果还不提升自己的技能,进阶发展,我想,很可能就是本行业的职业生涯的终点了。

我们要有危机意识,切莫等到一切都成定局时才开始追悔莫及。只要有规划的,有系统地学习,进阶提升自己并不难,给自己多充一点电,你才能走的更远。

千里之行始于足下。这是上小学时,那种一元钱一个的日记本上每一页下面都印刷有的一句话,当时只觉得这句话很短,后来渐渐长大才慢慢明白这句话的真正的含义。

有了学习的想法就赶快行动起来吧,不要被其他的事情牵绊住了前行的脚步。不要等到裁员时才开始担忧,不要等到面试前一晚才开始紧张,不要等到35岁甚至更晚才开始想起来要学习要进阶。

给大家一份系统的Android学习进阶资料,希望这份资料可以给大家提供帮助。

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!

就赶快行动起来吧,不要被其他的事情牵绊住了前行的脚步。不要等到裁员时才开始担忧,不要等到面试前一晚才开始紧张,不要等到35岁甚至更晚才开始想起来要学习要进阶。

给大家一份系统的Android学习进阶资料,希望这份资料可以给大家提供帮助。
[外链图片转存中…(img-EnRepNKC-1712195101162)]

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!
  • 16
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值