繁体   English   中英

间隔为5分钟的UIDatePicker以间隔显示日期

[英]UIDatePicker with 5 min interval get date on appear with interval

我花了大约3个小时试图让UIDatePicker来完成我想要的工作。 我将其设置为UITextField的动作,以使用UIDatePicker锁定到新的视图控制器。 一切正常。 我已经能够选择一个日期并将其发送回原始视图控制器。

问题是我使用5分钟的时间间隔。 如果我不移动日期选择器“滚轮”并选择完成”按钮以返回到父控制器,则将返回非间隔时间。 所以当我需要11:40时11:37返回11:37。 但是,如果我更改“车轮”,它将返回四舍五入的时间。 日期选择器当前显示5分钟间隔出现。 有什么线索可以引导我找到正确的解决方案? 我已经在viewDidAppear的UIDatePicker上尝试过setDateminuteInterval无效。 以下是我一直在使用的代码:

protocol DatePickerDelegate {
    func datePickerDidSelect(selectedDate: String)
}

class DatePickerVC: UIViewController  {

@IBOutlet weak var pickerView: UIDatePicker!

var selectedDate = ""
var delegate : DatePickerDelegate?


override func viewDidLoad() {
    super.viewDidLoad()
}

override func viewDidAppear(_ animated: Bool) {
    //setDate()
    //Have tried using setDate and minuteInterval here
}

func formatDate() -> DateFormatter {
    let dateFormatter = DateFormatter()
    dateFormatter.dateFormat = "MMM d, yyyy h:mm a"
    return dateFormatter
}

func setDate() {
    let dateFormatter = formatDate()
    selectedDate = dateFormatter.string(from: pickerView.date)
    self.delegate?.datePickerDidSelect(selectedDate: selectedDate)
    print(selectedDate)
}

@IBAction func datePickerChanged(_ sender: Any) {
    setDate()
}

@IBAction func doneBtnPressed(_ sender: Any) {
    self.dismiss(animated: true, completion: nil)
}

@IBAction func cancelBtnPressed(_ sender: Any) {
    self.dismiss(animated: true, completion: nil)
}
}

您可以检查日期并将其四舍五入为您的需求,如下所示:

override func viewDidLoad() {
    super.viewDidLoad()

    let calendar = Calendar.current
    var dateComponents = calendar.dateComponents([.month, .day, .year, .hour, .minute], from: datePicker.date)
    guard var hour = dateComponents.hour, var minute = dateComponents.minute else {
        print("something went wrong")
        return
    }

    let intervalRemainder = minute % datePicker.minuteInterval
    if intervalRemainder > 0 {
        // need to correct the date
        minute += datePicker.minuteInterval - intervalRemainder
        if minute >= 60 {
            hour += 1
            minute -= 60
        }

        // update datecomponents
        dateComponents.hour = hour
        dateComponents.minute = minute

        // get the corrected date
        guard let roundedDate = calendar.date(from: dateComponents) else {
            print("something went wrong")
            return
        }

        // update the datepicker
        datePicker.date = roundedDate
    }
}

随时询问是否不清楚!

另一种选择是创建一个扩展名,该扩展名允许您调整初始化UIDatePicker时设置的日期值的间隔。

extension Date {
    var nearest30Min: Date {
        var dateComponents = Calendar.current.dateComponents([.year, .month, .day, .hour, .minute], from: self)
        guard let hours = dateComponents.hour else { return self }

        switch dateComponents.minute ?? 0 {
        case 0...14:
            dateComponents.minute = 0
        case 15...44:
            dateComponents.minute = 30
        case 44...59:
            dateComponents.minute = 0
            dateComponents.hour = hours + 1
        default:
            break
        }

        return dateComponents.date ?? self
    }
}

初始化UIDatePicker之后,可以使用以下代码更新datePicker's值:

datePicker.setDate(datePicker.date.nearest30min, animated: false)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM