【问题标题】:app works fine in Simulator (Xcode 7.1.1) but not on iOS device应用程序在模拟器(Xcode 7.1.1)中运行良好,但在 iOS 设备上运行良好
【发布时间】:2015-11-16 06:15:11
【问题描述】:

我有一个应用程序可以计算两个日期之间的差异。它在模拟器中运行良好,但在 iOS 设备(iPad 使用 iOS 9)上运行良好。

当我按下 iPad 上的“计算差异”按钮时,没有任何反应。在 Xcode 的调试区域中,我收到以下错误消息:

2015-11-16 08:33:32.246 Date-to-Date Calculator[369:64113] <CATransformLayer: >0x17eb95e0> - 在仅变换层中更改属性 maskToBounds,将具有 >no 效果 2015-11-16 08:33:32.250

Date-to-Date Calculator[369:64113] <CATransformLayer: 0x17d8ea30> - 在仅变换层中更改 >property maskToBounds,将无效 2015-11-16 08:33:32.251

Date-to-Date Calculator[369:64113] <CATransformLayer: 0x17d95830> - 在仅转换层中更改 >property maskToBounds,将无效

我在 SO 上搜索过这个,但找不到解决方案。

有人有什么建议吗?

谢谢!

请在下面找到视图控制器代码:

import UIKit

类视图控制器:UIViewController {

@IBOutlet weak var startDateTextField: UITextField!
@IBOutlet weak var endDateTextField: UITextField!
@IBOutlet weak var resultNumberOfDays: UILabel!
@IBOutlet weak var resultWeeksAndDays: UILabel!



override func viewDidLoad() {
    super.viewDidLoad()

    self.view.backgroundColor = UIColor(red: 210/255, green: 213/255, blue: 220/255, alpha: 1.0)

    let toolBar = UIToolbar(frame: CGRectMake(0, self.view.frame.size.height/6, self.view.frame.size.width, 40.0))

    toolBar.layer.position = CGPoint(x: self.view.frame.size.width/2, y: self.view.frame.size.height-20.0)

    toolBar.barStyle = UIBarStyle.BlackTranslucent

    toolBar.tintColor = UIColor.whiteColor()

    UIToolbar.appearance().barTintColor = UIColor(red: 0/255, green: 0/255, blue: 205/255, alpha: 1.0)

    let todayBtn = UIBarButtonItem(title: "Today", style: UIBarButtonItemStyle.Plain, target: self, action: "tappedToolBarBtn:")

    let okBarBtn = UIBarButtonItem(title: "Done", style: UIBarButtonItemStyle.Plain, target: self, action: "donePressed:")

    // let okBarBtn = UIBarButtonItem(barButtonSystemItem: UIBarButtonSystemItem.Done, target: self, action: "donePressed:")

    let flexSpace = UIBarButtonItem(barButtonSystemItem: UIBarButtonSystemItem.FlexibleSpace, target: self, action: nil)

    let label = UILabel(frame: CGRect(x: 0, y: 0, width: self.view.frame.size.width / 3, height: self.view.frame.size.height))

    label.font = UIFont(name: "Helvetica Neue", size: 13)

    label.backgroundColor = UIColor.clearColor()

    label.textColor = UIColor.whiteColor()

    label.text = "Select a Start Date"

    label.textAlignment = NSTextAlignment.Center

    let textBtn = UIBarButtonItem(customView: label)

    toolBar.setItems([todayBtn,flexSpace,textBtn,flexSpace,okBarBtn], animated: true)

    startDateTextField.inputAccessoryView = toolBar


    let toolBar2 = UIToolbar(frame: CGRectMake(0, self.view.frame.size.height/6, self.view.frame.size.width, 40.0))

    toolBar2.layer.position = CGPoint(x: self.view.frame.size.width/2, y: self.view.frame.size.height-20.0)

    toolBar2.barStyle = UIBarStyle.BlackTranslucent

    toolBar2.tintColor = UIColor.whiteColor()

    UIToolbar.appearance().barTintColor = UIColor(red: 0/255, green: 0/255, blue: 205/255, alpha: 1.0)

    let todayBtn2 = UIBarButtonItem(title: "Today", style: UIBarButtonItemStyle.Plain, target: self, action: "secondTappedToolBarBtn:")

    let okBarBtn2 = UIBarButtonItem(title: "Done", style: UIBarButtonItemStyle.Plain, target: self, action: "secondDonePressed:")

    // let okBarBtn2 = UIBarButtonItem(barButtonSystemItem: UIBarButtonSystemItem.Done, target: self, action: "secondDonePressed:")

    let flexSpace2 = UIBarButtonItem(barButtonSystemItem: UIBarButtonSystemItem.FlexibleSpace, target: self, action: nil)

    let label2 = UILabel(frame: CGRect(x: 0, y: 0, width: self.view.frame.size.width / 3, height: self.view.frame.size.height))

    label2.font = UIFont(name: "Helvetica Neue", size: 13)

    label2.backgroundColor = UIColor.clearColor()

    label2.textColor = UIColor.whiteColor()

    label2.text = "Select an End Date"

    label2.textAlignment = NSTextAlignment.Center

    let textBtn2 = UIBarButtonItem(customView: label2)

    toolBar2.setItems([todayBtn2,flexSpace2,textBtn2,flexSpace2,okBarBtn2], animated: true)

     endDateTextField.inputAccessoryView = toolBar2

    // Do any additional setup after loading the view, typically from a nib.
}



override func didReceiveMemoryWarning() {
    super.didReceiveMemoryWarning()
    // Dispose of any resources that can be recreated.
}




func donePressed(sender: UIBarButtonItem) {

    startDateTextField.resignFirstResponder()

}


func secondDonePressed(sender: UIBarButtonItem) {

    endDateTextField.resignFirstResponder()

}




func tappedToolBarBtn(sender: UIBarButtonItem) {

    let dateformatter = NSDateFormatter()
    dateformatter.dateStyle = NSDateFormatterStyle.MediumStyle
    dateformatter.timeStyle = NSDateFormatterStyle.NoStyle
    startDateTextField.text = dateformatter.stringFromDate(NSDate())
    startDateTextField.resignFirstResponder()
}


func secondTappedToolBarBtn(sender: UIBarButtonItem) {

    let dateformatter = NSDateFormatter()
    dateformatter.dateStyle = NSDateFormatterStyle.MediumStyle
    dateformatter.timeStyle = NSDateFormatterStyle.NoStyle
    endDateTextField.text = dateformatter.stringFromDate(NSDate())
    endDateTextField.resignFirstResponder()
}



override func touchesBegan(touches: Set<UITouch>, withEvent event: UIEvent?) {
    self.view.endEditing(true)
}


@IBAction func textFieldEditing(sender: UITextField) {
    let datePickerView: UIDatePicker = UIDatePicker()
    datePickerView.datePickerMode = UIDatePickerMode.Date
    sender.inputView = datePickerView
    datePickerView.addTarget(self, action: Selector("datePickerValueChanged:"), forControlEvents: UIControlEvents.ValueChanged)

}



@IBAction func secondTextFieldEditing(sender: UITextField) {
    let datePickerView: UIDatePicker = UIDatePicker()
    datePickerView.datePickerMode = UIDatePickerMode.Date
    sender.inputView = datePickerView
    datePickerView.addTarget(self, action: Selector("secondDatePickerValueChanged:"), forControlEvents: UIControlEvents.ValueChanged)

}



func datePickerValueChanged(sender: UIDatePicker) {
    let dateFormatter = NSDateFormatter()
    dateFormatter.dateStyle = NSDateFormatterStyle.MediumStyle
    dateFormatter.timeStyle = NSDateFormatterStyle.NoStyle
    startDateTextField.text = dateFormatter.stringFromDate(sender.date)

}



func secondDatePickerValueChanged(sender: UIDatePicker) {
        let dateFormatter = NSDateFormatter()
        dateFormatter.dateStyle = NSDateFormatterStyle.MediumStyle
        dateFormatter.timeStyle = NSDateFormatterStyle.NoStyle
        endDateTextField.text = dateFormatter.stringFromDate(sender.date)

}


@IBAction func calculateDays(sender: UIButton) {

    if startDateTextField.text! == "" || endDateTextField! == "" {

        let alert2 = UIAlertController(title: "Oops!", message: "Please Select a Start Date!", preferredStyle: UIAlertControllerStyle.Alert)
        alert2.addAction(UIAlertAction(title: "Close", style: UIAlertActionStyle.Default, handler: nil))
        self.presentViewController(alert2, animated: true, completion: nil)


    }
    else {

        let start = String(startDateTextField.text!)
        let end = String(endDateTextField.text!)
        let dateFormatter = NSDateFormatter()
        dateFormatter.dateFormat = "MM-dd-yyyy"


        guard let startDate = dateFormatter.dateFromString(start), endDate = dateFormatter.dateFromString(end) else {
            // You don't have dates, show error(print("error"), do no nothing - your choice.
            return
        }


        // let startDate:NSDate = dateFormatter.dateFromString(start)!
        // let endDate:NSDate = dateFormatter.dateFromString(end)!
        let calendar = NSCalendar.currentCalendar()
        let components = calendar.components([.Day], fromDate: startDate, toDate: endDate, options: [])
        let secondNewString = "\(components.day) days"
        resultNumberOfDays.text = secondNewString

    }

}


@IBAction func calculateWeeksAndDays(sender: UIButton) {

    if startDateTextField.text! == "" || endDateTextField! == "" {

        let alert2 = UIAlertController(title: "Oops!", message: "Please Select an End Date!", preferredStyle: UIAlertControllerStyle.Alert)
        alert2.addAction(UIAlertAction(title: "Close", style: UIAlertActionStyle.Default, handler: nil))
        self.presentViewController(alert2, animated: true, completion: nil)
    }
    else {

    let start = String(startDateTextField.text!)
    let end = String(endDateTextField.text!)
    let dateFormatter = NSDateFormatter()
    dateFormatter.dateFormat = "MM-dd-yyyy"



        guard let startDate = dateFormatter.dateFromString(start), endDate = dateFormatter.dateFromString(end) else {
            // You don't have dates, show error(print("error"), do no nothing - your choice.
            return
 }


    // let startDate:NSDate = dateFormatter.dateFromString(start)!
    // let endDate:NSDate = dateFormatter.dateFromString(end)!
    let calendar = NSCalendar.currentCalendar()
    let components = calendar.components([.Day], fromDate: startDate, toDate: endDate, options: [])
    let days = components.day
    let weeks = components.day / 7
    let weeksanddays = days % 7
    let newString = "\(weeks) weeks + \(weeksanddays) days"
    resultWeeksAndDays.text = newString
}

}

@IBAction func resetLabels(sender: AnyObject) {

    resultNumberOfDays.text = ""
    resultWeeksAndDays.text = ""


}

}

【问题讨论】:

  • 您只需启动 iPad 模拟器,然后按 (CommandKey)。
  • 你的问题没有提供问题的任何细节。您至少应该提供计算方法的说明,或者在问题中嵌入方法的代码,以便 SO 可以帮助您。是的,我认为来自控制台的警告消息与您的问题无关。
  • 查看这个 SO 问题:*.com/questions/32775575/…
  • 请提供信息是您使用的是哪个模拟器(5s、4s、ipad 等)您的设计与 ipad 兼容吗?
  • 谢谢,刚刚将视图控制器代码添加到我原来的问题中。如果有人能看到我哪里出错了,非常感谢。 PS。我正在使用 Xcode 7.1.1 而 iPad 正在使用 iOS 9.1

标签: ios swift


【解决方案1】:

我敢打赌,即使在模拟器中,您的代码也不能“正常工作”。例如,当我第一次点击文本字段时,日期选择器不显示。我必须点击背景屏幕以 resignFirstResponder,然后再次点击文本字段以显示日期选择器。

问题在于您没有实例化日期选择器并将其连接到文本字段,直到 文本字段成为第一响应者,您需要这样做 before 它成为第一响应者。 (例如在 viewDidLoad 方法中。)

【讨论】:

    最近更新 更多