android 高仿ios时间选择器,Android仿IOS10圆盘时间选择器

介绍

这是一款仿IOS10(就寝功能)的圆盘时间选择器

项目演示

c6966519cc2758ca0b9d5ea5499104e1.gif

实现思路

以720度为一个周期,0~360°对应0~12小时,360°~720°对应12~24小时

e6a23ed408b95e7ff6f307956c0bc0b5.png

这里以”开始时间设置按钮”为例来谈谈它的滑动实现:

将”开始时间设置按钮”作为点A,表盘中心作为点O,手指触摸点作为点P.通过反正切公式可以计算出∠AOP的大小,然后随着手指的位置不断变化去更新点A的位置(即点A的角度).

// 坐标系的直线表达式

// 直线l1的表达式子:过钟表中心点和开始控件中心点

float a1 = mCenterY - mStartBtnCurY;

float b1 = mStartBtnCurX - mCenterX;

float c1 = mStartBtnCurY * mCenterX - mCenterY * mStartBtnCurX;

double d1 = (a1 * eventX + b1 * eventY + c1) / (Math.sqrt(a1 * a1 + b1 * b1));

// 直线l2的表达式:过钟表中心点且垂直直线l1

float a2 = b1;

float b2 = -a1;

float c2 = -a2 * mCenterX - b2 * mCenterY;

double d2 = (a2 * eventX + b2 * eventY + c2) / (Math.sqrt(a2 * a2 + b2 * b2));

// 以l1为基准线,顺势针半圆为0-180度,逆时针半圆为0-负180度

double moveDegree = Math.toDegrees(Math.atan2(d1, d2));

mStartDegree = (float) (mStartDegree + Math.floor(moveDegree));

mStartDegree = (mStartDegree < 0) ? mStartDegree + mDegreeCycle : mStartDegree % mDegreeCycle;

refreshStartBtnPositon();

invalidate();

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值