引言
上一節中我們瞭解了IOS小元件的重新整理機制,發現根本沒法實現按秒重新整理,但是看別的App裡面有做到,以為用了什麼黑科技,原來是因為系統提供了一個額外的機制實現時間的動態更新,不用走小元件的重新整理機制。
Text控制元件支援顯示日期時間,下面是來自官網的程式碼
計算時間差
let components = DateComponents(minute: 11, second: 14)
let futureDate = Calendar.current.date(byAdding: components, to: Date())!
Text(futureDate, style: .relative)
// Displays:
// 11 min, 14 sec
Text(futureDate, style: .offset)
// Displays:
// -11 minutes
使用relative樣式可以顯示當前日期和時間與指定日期之間的差值(絕對值),而不管該日期是將來的還是過去的日期。使用offset樣式顯示當前日期和時間與指定日期之間的時差,表示將來的日期帶有減號(-)字首,而過去的日期帶有加號(+)字首。
倒數計時和計時器
let components = DateComponents(minute: 15)
let futureDate = Calendar.current.date(byAdding: components, to: Date())!
Text(futureDate, style: .timer)
// Displays:
// 15:00
對於將來的日期,timer樣式將遞減計數(倒數計時),直到當前時間達到指定的日期和時間為止,並在日期經過時遞增計數(計時器)。
顯示絕對日期或時間
// Absolute Date or Time
let components = DateComponents(year: 2020, month: 4, day: 1, hour: 9, minute: 41)
let aprilFirstDate = Calendar.current(components)!
Text(aprilFirstDate, style: .date)
Text("Date: \(aprilFirstDate, style: .date)")
Text("Time: \(aprilFirstDate, style: .time)")
// Displays:
// April 1, 2020
// Date: April 1, 2020
// Time: 9:41AM
顯示兩個日期之間的時間間隔
let startComponents = DateComponents(hour: 9, minute: 30)
let startDate = Calendar.current.date(from: startComponents)!
let endComponents = DateComponents(hour: 14, minute: 45)
let endDate = Calendar.current.date(from: endComponents)!
Text(startDate ... endDate)
Text("The meeting will take place: \(startDate ... endDate)")
// Displays:
// 9:30AM-2:45PM
// The meeting will take place: 9:30AM-2:45PM
實現一天時間的計時器
使用 style: .time樣式,如果當前的時間比指定的時間大,則時間就會累計。基於這個原理,我們只需要把時間起點定在每天的0點即可,根據當前的時間計算出今天的開始時間。以下方法可以根據12,24小時制度,獲取當天起點時間。
//獲取當天開始的日期,給Date增加一個擴充方法
extension Date {
func getCurrentDayStart(_ isDayOf24Hours: Bool)-> Date {
let calendar:Calendar = Calendar.current;
let year = calendar.component(.year, from: self);
let month = calendar.component(.month, from: self);
let day = calendar.component(.day, from: self);
let components = DateComponents(year: year, month: month, day: day, hour: 0, minute: 0, second: 0)
return Calendar.current.date(from: components)!
}
}
// 實現一天內的計時器
Text(Date().getCurrentDayStart(true), style: .timer)
結語
通過IOS Text控制元件我們實現了按秒重新整理的計時器,所以數字時鐘的按秒重新整理算是解決了,但是怎麼實現錶盤時鐘的秒針360度旋轉呢?如果讓秒針精確的對應當前的時間,應該做不到了。後面再繼續研究,如果有解決方案的可以貢獻一下,感謝。