NSComparisonResult OrderedDescending 和 OrderedAscending 未按预期运行
NSComparisonResult OrderedDescending and OrderedAscending not functioning as expected
我的意图是让从 "1927-2-2"
到 "1928-1-22"
的每个日期在输入 UIDatePicker 时都调用图像。我可以用除“1928-1-22”之外的每个日期成功调用图像,这是唯一不产生图像的日期。有人可以帮忙吗?
import UIKit
class ViewController: UIViewController {
@IBOutlet weak var displayAnimal: UIImageView!
@IBOutlet weak var dateWheel: UIDatePicker!
@IBAction func goButton(sender: UIDatePicker)
{
let dateStringFormatter = NSDateFormatter()
dateStringFormatter.dateFormat = "yyyy-MM-dd"
dateStringFormatter.locale = NSLocale(localeIdentifier: "en_US_POSIX")
let rabbit1A = dateStringFormatter.dateFromString("1927-2-2")
let rabbit2A = dateStringFormatter.dateFromString("1928-1-22")
println(dateWheel.date)
if((dateWheel.date.compare(rabbit1A!) == NSComparisonResult.OrderedDescending || dateWheel.date.compare(rabbit1A!) == NSComparisonResult.OrderedSame)
&& (dateWheel.date.compare(rabbit2A!) == NSComparisonResult.OrderedAscending || dateWheel.date.compare(rabbit2A!) == NSComparisonResult.OrderedSame))
{
// set the image of UIImageView
displayAnimal.image = UIImage(named: "rabbit")
}
如果您的 dateWheel 只显示日期,dateWheel.date returnNSDateTime 对应于您看到的日期和当时的当地时间。
并且你的 dateFormat "yyyy-MM-dd" 的 dateStringFormatter 将 return 与 00h:00m:000s 相同日期的 NSDate(如果你没有指定时区,则为当地时间)。
所以 dateWheelDate 有可能比你的 rabbit2A 晚。
示例:当地时间14h:30:000,您在方向盘中选择1928-1-22。您将获得日期 1928-1-22 14:30:000.
另一边,你的rabbit2A = 1928-1-22 00:00:000。所以你的比较逻辑不成立。
要解决此问题,您可以使用 NSCalendar 将这两个日期与 .CalendarUnitDay 选项进行比较
let date = dateWheel.date
let rabbit2A = dateStringFormatter.dateFromString("1928-1-22")
let cal = NSCalendar(calendarIdentifier: NSCalendarIdentifierGregorian)!
let result = cal.compareDate(date, toDate: rabbit2A!, toUnitGranularity: NSCalendarUnit.CalendarUnitDay)
注意 println(): 而 UIDatePicker 和 DateFormatter 默认使用本地时区,println() 显示原始值(作为 GMT 时间)。
此外,您可以替换
dateWheel.date.compare(rabbit2A!) == NSComparisonResult.OrderedAscending || dateWheel.date.compare(rabbit2A!) == NSComparisonResult.OrderedSame))
来自
dateWheel.date.compare(rabbit2A!) != NSComparisonResult.OrderedDescending //or even .OrderedDescending
我的意图是让从 "1927-2-2"
到 "1928-1-22"
的每个日期在输入 UIDatePicker 时都调用图像。我可以用除“1928-1-22”之外的每个日期成功调用图像,这是唯一不产生图像的日期。有人可以帮忙吗?
import UIKit
class ViewController: UIViewController {
@IBOutlet weak var displayAnimal: UIImageView!
@IBOutlet weak var dateWheel: UIDatePicker!
@IBAction func goButton(sender: UIDatePicker)
{
let dateStringFormatter = NSDateFormatter()
dateStringFormatter.dateFormat = "yyyy-MM-dd"
dateStringFormatter.locale = NSLocale(localeIdentifier: "en_US_POSIX")
let rabbit1A = dateStringFormatter.dateFromString("1927-2-2")
let rabbit2A = dateStringFormatter.dateFromString("1928-1-22")
println(dateWheel.date)
if((dateWheel.date.compare(rabbit1A!) == NSComparisonResult.OrderedDescending || dateWheel.date.compare(rabbit1A!) == NSComparisonResult.OrderedSame)
&& (dateWheel.date.compare(rabbit2A!) == NSComparisonResult.OrderedAscending || dateWheel.date.compare(rabbit2A!) == NSComparisonResult.OrderedSame))
{
// set the image of UIImageView
displayAnimal.image = UIImage(named: "rabbit")
}
如果您的 dateWheel 只显示日期,dateWheel.date returnNSDateTime 对应于您看到的日期和当时的当地时间。
并且你的 dateFormat "yyyy-MM-dd" 的 dateStringFormatter 将 return 与 00h:00m:000s 相同日期的 NSDate(如果你没有指定时区,则为当地时间)。
所以 dateWheelDate 有可能比你的 rabbit2A 晚。
示例:当地时间14h:30:000,您在方向盘中选择1928-1-22。您将获得日期 1928-1-22 14:30:000.
另一边,你的rabbit2A = 1928-1-22 00:00:000。所以你的比较逻辑不成立。
要解决此问题,您可以使用 NSCalendar 将这两个日期与 .CalendarUnitDay 选项进行比较
let date = dateWheel.date
let rabbit2A = dateStringFormatter.dateFromString("1928-1-22")
let cal = NSCalendar(calendarIdentifier: NSCalendarIdentifierGregorian)!
let result = cal.compareDate(date, toDate: rabbit2A!, toUnitGranularity: NSCalendarUnit.CalendarUnitDay)
注意 println(): 而 UIDatePicker 和 DateFormatter 默认使用本地时区,println() 显示原始值(作为 GMT 时间)。
此外,您可以替换
dateWheel.date.compare(rabbit2A!) == NSComparisonResult.OrderedAscending || dateWheel.date.compare(rabbit2A!) == NSComparisonResult.OrderedSame))
来自
dateWheel.date.compare(rabbit2A!) != NSComparisonResult.OrderedDescending //or even .OrderedDescending