工具栏中的完成按钮问题

时间:2018-06-24 15:05:52

标签: ios uitoolbar cancel-button

我添加了一个带有完成和取消按钮的工具栏,一切正常。突然,完成和取消文本被隐藏。这些按钮存在并且可以单击,但是没有文本。除了相同的问题,我尝试了所有其他方法。

这是关于工具栏的代码:

func createDatePicker(){
    //format for datepicker display
    datePicker.datePickerMode = .date
    datePicker.minimumDate = Date()
    datePicker.backgroundColor = UIColor.white

    // ToolBar
    let toolBar = UIToolbar()
    toolBar.barStyle = UIBarStyle.default
    toolBar.isTranslucent = true
    toolBar.backgroundColor = UIColor(red: 253/255, green: 184/255, blue: 20/35, alpha: 1.0)

    //datePicker.tintColor = UIColor.blue
    toolBar.tintColor = UIColor.blue
    toolBar.sizeToFit()
    toolBar.isUserInteractionEnabled = true
    //add a done button on this toolbar

    let doneButton = UIBarButtonItem(barButtonSystemItem: .done, target: self, action: #selector(doneClicked))
    let spaceButton = UIBarButtonItem(barButtonSystemItem: .flexibleSpace, target: nil, action: nil)
    let cancelButton = UIBarButtonItem(barButtonSystemItem: .cancel, target: self, action: #selector(cancelClicked))
    toolBar.setItems([cancelButton,spaceButton,doneButton], animated: true)
    testfield.inputAccessoryView = toolBar
    testfield.inputView = datePicker

    self.view.addSubview(testfield)
}

这是结果:

and this is the result

2 个答案:

答案 0 :(得分:0)

这是根据您的代码使用的代码,对我来说工作正常

import UIKit

class ViewController: UIViewController {

    var datePicker = UIDatePicker()
    var testfield: UITextField!

    override func viewDidLoad() {
        super.viewDidLoad()
        createDatePicker()
        // 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 createDatePicker(){
        // TextField
        testfield = UITextField(frame: CGRect(x: 20, y: 100, width: 300, height: 40))
        testfield.placeholder = "testfiled"
        self.view.addSubview(testfield)

        //format for datepicker display
        datePicker.datePickerMode = .date
        datePicker.minimumDate = Date()
        datePicker.backgroundColor = UIColor.white

        // ToolBar
        let toolBar = UIToolbar()
        toolBar.barStyle = UIBarStyle.default
        toolBar.isTranslucent = true
        toolBar.backgroundColor = UIColor(red: 253/255, green: 184/255, blue: 20/35, alpha: 1.0)

        //datePicker.tintColor = UIColor.blue
        toolBar.tintColor = UIColor.blue
        toolBar.sizeToFit()
        toolBar.isUserInteractionEnabled = true
        //add a done button on this toolbar

        let doneButton = UIBarButtonItem(barButtonSystemItem: .done, target: self, action: #selector(doneClicked))
        let spaceButton = UIBarButtonItem(barButtonSystemItem: .flexibleSpace, target: nil, action: nil)
        let cancelButton = UIBarButtonItem(barButtonSystemItem: .cancel, target: self, action: #selector(cancelClicked))
        toolBar.setItems([cancelButton,spaceButton,doneButton], animated: true)
        testfield.inputAccessoryView = toolBar
        testfield.inputView = datePicker

    }

    @objc func doneClicked(){

    }
    @objc func cancelClicked(){

    }

}

请尝试同时在设备和模拟器上进行测试 或者在构建之前尝试清理(shift + cmd + k)项目,这在大多数情况下会有所帮助。

结果

enter image description here

答案 1 :(得分:0)

我通过将图像添加到“完成并取消”按钮中来进行了工作

let DonebuttonIcon = UIImage(named: "done-calender.png")
    let doneButton = UIBarButtonItem(title: "Done", style: UIBarButtonItemStyle.done, target: self, action: #selector(doneClicked))
    doneButton.image = DonebuttonIcon
    doneButton.tintColor = UIColor.gray

    let spaceButton = UIBarButtonItem(barButtonSystemItem: .flexibleSpace, target: nil, action: nil)

    let CancelbuttonIcon = UIImage(named: "cancel-calender.png")
    let cancelButton = UIBarButtonItem(title: "Cancel", style: UIBarButtonItemStyle.done, target: self, action: #selector(cancelClicked))
    cancelButton.image = CancelbuttonIcon
    cancelButton.tintColor = UIColor.gray