Android自定义圆盘时间选择器
2017-12-25 22:47
746 查看
介绍
这是一款仿IOS10(就寝功能)的圆盘时间选择器项目演示
实现思路
以720度为一个周期,0~360°对应0~12小时,360°~720°对应12~24小时这里以”开始时间设置按钮”为例来谈谈它的滑动实现:
将”开始时间设置按钮”作为点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();
项目地址
项目地址相关文章推荐
- Android自定义View仿IOS圆盘时间选择器
- android自定义日期和时间选择对话框得实现
- Android 自定义View 仿圆形时间选择器
- Android自定义时间控件不可选择未来时间
- Android 仿iOS时间选择器自定义WheelView
- Android滚轮时间选择控件(可扩展自定义)
- Android自定义时间控件选择开始时间到结束时间
- Android开发中实现IOS风格底部选择器(支持时间 日期 自定义)
- Android自定义简易时间选择器
- android:最简单的方式实现自定义选择时间分钟间隔,非滚轮方式
- Android 时间选择框、省市区选择框、自定义底部选择框
- Android 自定义时间滑轮选择控件
- 轻松实现可扩展自定义的Android滚轮时间选择控件
- android:TimePicker仿照IOS时间选择器,可自定义选择器
- Android自定义滚动式时间选择器(在他人基础上修改)
- Android仿IOS10圆盘时间选择器
- Android中仿IOS圆盘时间选择器
- Android自定义dialog可选择展示年月日时间选择栏
- Android自定义滚轮式日期(时间)选择控件
- AndroidIOS风格底部选择器(支持时间,日期,自定义)