仿支付宝记账本效果(二)

本文介绍如何仿照支付宝记账本实现点击位置判断和动态更新style背景色。通过记录区域并使用Region类判断点击位置,同时利用接口处理点击事件。在主Activity中,根据点击的区域动态设置图标背景颜色,使用style实现圆形背景,并通过代码动态更改color值。
摘要由CSDN通过智能技术生成

仿支付宝记账本效果(二)

因为最近有网课要上,也有一些问题需要解决,因此现在才有所进展。目前的进展是点击环形区域部分已经可以进行区分并且正常显示此区域包含的内容,主要解决了两个问题:
1. 各区域的确定
2. 动态设定style的背景色
按照惯例,效果图奉上:

效果图

点击位置的判断

在每次绘制的时候,会将每一个type的区域记录在Region类中,通过使用region.contains()方法,来判断点击的位置是否在区域内,具体的内容可以参考:android 判断点击位置在一扇形区域内
在代码中定义一个集合,用来记录每个type的区域private List<Region> mRegionList = new ArrayList<>();,在paintSectorChart()方法中,增加如下代码:

//记录每个扇形区域
Path ovalPath = new Path();
ovalPath.moveTo(0, 0);
ovalPath.lineTo((float) (mRadius * Math.cos(Math.toRadians(currentAngle))), (float) (mRadius * Math.sin(Math.toRadians(currentAngle))));
ovalPath.addArc(mOval, currentAngle, drawAngle);
ovalPath.lineTo(0, 0);
ovalPath.close();
RectF r = new RectF();
ovalPath.computeBounds(r, true);
Region region = new Region();
region.setPath(ovalPath, new Region((int) r.left, (int) r.top, (int) r.right, (int) r
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值