需求是實現一個倒計時搶單功能,為了準確起見,倒計時到最后時需要驗證服務器,重新獲取服務器時間調整倒計時,我自己分裝了一個顯示倒計時的Label,當然為了實現時間的校準和倒計時結束后,UI界面的調整,涉及到了代理去實現這些功能。
先看效果圖:
聲明代理方法
// 聲明設置代理方法
protocol PreviewCountdownLabelDelegate : class {
func PreviewCountdownLabelExhaust()
func PreviewCountdownLabelCorrectTime()
}
class PreviewCountdownLabel: UILabel {
static let preTimeFormatter = NSDateFormatter(dateFormat: "HH:mm:ss")
var isFirst = 0
weak var delegate : PreviewCountdownLabelDelegate?
let timet = NSDate().timeIntervalSinceDate(NSDate().dateByAddingTimeInterval(16 * 60 * 60))
var expectedTime = NSDate() {
didSet {
}
}
var timeExpectedTime = NSDate() {
didSet {
}
}
var showChinese = false
var timer : NSTimer!
init() {
super.init(frame: CGRectZero)
FUCKINIT()
}
override init(frame: CGRect) {
super.init(frame: frame)
FUCKINIT()
}
func FUCKINIT() {
textColor(UIColor.whiteColor())
textAlignment(.Right)
font(systemFontOfSize: 20)
timer = NSTimer.scheduledTimerWithTimeInterval(1.0, target: self, selector: "timePass", userInfo: nil, repeats: true)
timer.fire()
}
required init?(coder aDecoder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
func timePass() {
let _time = NSDate().timeIntervalSinceDate(expectedTime)
let timeIsOut = _time >= 0
ccRight(_time)
if Int(-_time) == 300 {
delegate?.PreviewCountdownLabelCorrectTime() //當倒計時還剩余五分鐘時,去服務器重新獲取時間,校準倒計時時間
}
if timeIsOut {
font(UIFont(name: "Quartz-Regular", size: 20)!)
text("00:00:00")
guard isFirst == 0 else {
timer.invalidate()
delegate?.PreviewCountdownLabelExhaust() //當倒計時完成后走這個代理方法,去改變布局UI
return
}
isFirst = 1
} else {
let time = NSDate(timeIntervalSince1970: 0).dateByAddingTimeInterval(-_time - timet)
let str = PreviewCountdownLabel.preTimeFormatter.stringFromDate(time)
font(UIFont(name: "Quartz-Regular", size: 20)!)
text("\(str)")
}
}
}
然后在需要實現代理方法的類中去遵守代理協議,實現代理方法
MARK: - Methods
extension TaskDetailViewController {
func closeButtonClick() {
dismissViewControllerAnimated(true, completion: nil)
}
func askTaskInfo() {
API.taskDetail(self.taskID) { task in
ccRight(self.taskID)
self._task = task
self.discountRateL.text(task.selfBuyOff.string)
self.addressL.text(task.areaDisplayName)
self.priceL.text(task.price.string)
self.commissionL.text(task.shotFee.string)
self.orderNameLabel.text(task.title)
self.requisitionLabel.text(task.shortDescription)
self.imageURL = task.imageURLString
self.imageView.kf_setImageWithURL(task.imageURLString.URL, placeholderImage: AppStyle.PlaceHolderImage)
self.displayStatus = task.relation
let time1 = NSDate(jsonDate: "/Date(" + task.databaseTime + "+0800)/")
let time2 = NSDate(jsonDate: "/Date(" + task.futurePublishTime + "+0800)/")
let time = NSTimeInterval(task.diffTime)
ccRight(time1)
ccRight(time2)
if task.isTimerTask == .YES {
if time > 0 {
if self.countDownLabel == nil {
self.countDownLabel = PreviewCountdownLabel()
.superView(self.view)
.width(98)
.bottom(170 + 49 + 5)
.right(12)
.height(28)
.backgroundColor(UIColor.blackColor().alpha(0.5))
.textAlignmentCenter()
.cornerRadius(6)
}
self.countDownLabel!.delegate = self
self.countDownLabel!.hidden = false
self.countDownLabel!.expectedTime = NSDate().dateByAddingTimeInterval(time! / 1000)
}
// 預覽 查看任務要求(倒計時完后,顯示搶單,可選擇繼續搶單,或者跳轉H5查看任務要求)
switch task.isCustomTask {
case .No:
self.getOrderButton.title("預覽")
self.getOrderButton.removeTarget(self, action: "getOrderButtonClick", forControlEvents: UIControlEvents.AllEvents)
self.getOrderButton.removeTarget(self, action: "PreviewAction", forControlEvents: UIControlEvents.AllEvents)
self.getOrderButton.target(self, upInsideAction: "PreviewAction")
self.getOrderButton.enabled(true)
AnimateWithDuration(0.15) {
self.getOrderButton.backgroundColor(AppStyle.Tint)
}
ccRight("不是")
case .Yes:
self.getOrderButton.title("查看任務要求")
self.getOrderButton.removeTarget(self, action: "getOrderButtonClick", forControlEvents: UIControlEvents.AllEvents)
self.getOrderButton.removeTarget(self, action: "PreviewAction", forControlEvents: UIControlEvents.AllEvents)
self.getOrderButton.target(self, upInsideAction: "PreviewAction")
self.getOrderButton.enabled(true)
AnimateWithDuration(0.15) {
self.getOrderButton.backgroundColor(AppStyle.Tint)
}
ccRight("是")
}
}else {
self.getOrderButton.title("搶單")
if task.relation == Task.RelationToToken.Accepted || task.isDirect == Task.DirectionalPush.Yes{
self.getOrderButton.removeTarget(self, action: "getOrderButtonClick", forControlEvents: UIControlEvents.AllEvents)
self.getOrderButton.removeTarget(self, action: "PreviewAction", forControlEvents: UIControlEvents.AllEvents)
self.getOrderButton.target(self, upInsideAction: "getOrderButtonClick")
self.getOrderButton.enabled(true)
AnimateWithDuration(0.15) {
self.getOrderButton.backgroundColor(AppStyle.Tint)
}
}else {
if task.relation == Task.RelationToToken.UnAccepted || task.relation == Task.RelationToToken.Finished {
self.getOrderButton.enabled(true)
AnimateWithDuration(0.15) {
self.getOrderButton.backgroundColor(AppStyle.GrayTextColor)
}
}
}
}
}
}
初始化好了自定義倒計時Label,設置好代理然后實現協議方法:
MARK: - PreviewCountdownLabelDelegate
extension TaskDetailViewController : PreviewCountdownLabelDelegate {
func PreviewCountdownLabelCorrectTime() {
askTaskInfo()
}
func PreviewCountdownLabelExhaust() {
self.countDownLabel!.hidden = true
self.countDownLabel!.timer.invalidate()
askTaskInfo()
}
}