溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Android如何實現(xiàn)仿IOS10圓盤時間選擇器

發(fā)布時間:2021-06-28 09:26:34 來源:億速云 閱讀:152 作者:小新 欄目:移動開發(fā)

小編給大家分享一下Android如何實現(xiàn)仿IOS10圓盤時間選擇器,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

介紹

這是一款仿IOS10(就寢功能)的圓盤時間選擇器

項目演示

Android如何實現(xiàn)仿IOS10圓盤時間選擇器

實現(xiàn)思路

以720度為一個周期,0~360°對應(yīng)0~12小時,360°~720°對應(yīng)12~24小時

Android如何實現(xiàn)仿IOS10圓盤時間選擇器

這里以”開始時間設(shè)置按鈕”為例來談?wù)勊幕瑒訉崿F(xiàn):
將”開始時間設(shè)置按鈕”作為點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如何實現(xiàn)仿IOS10圓盤時間選擇器”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI