WedX - журнал о программировании и компьютерных науках

создайте собственный UIDatePicker, который подходит для быстрого назначения встреч

Я хотел бы создать UDatePicker, чтобы пользователи могли назначать встречу. UIDatePicker должен показывать на 7 дней раньше текущего дня, а после того, как назначенная встреча будет сделана, появится всплывающее уведомление, показывающее, что она подтверждена.

Пользовательский интерфейс не имеет значения, подойдет что-то базовое. Это возможно? Я искал в Интернете, но я не мог найти ничего, что могло бы помочь.

Любая помощь будет оценена по достоинству.

25.05.2018


Ответы:


1
class ViewController: UIViewController , UIPickerViewDelegate, 
UIPickerViewDataSource
{

var pickerView: UIPickerView!

@IBOutlet weak var textField: UITextField!

var arrDate = [String]()

override func viewDidLoad() {
    super.viewDidLoad()

    // Do any additional setup after loading the view.


    arrDate.append(Date().getDateStringWithFormate("yyyy-MM-dd", timezone: TimeZone.current.abbreviation()!))

    for i in 1...7
    {
        let dateAdded = Date().addDays(i)
        arrDate.append(dateAdded.getDateStringWithFormate("yyyy-MM-dd", timezone: TimeZone.current.abbreviation()!))
        print(arrDate)
    }


    pickerView = UIPickerView()
    pickerView.delegate = self
    pickerView.dataSource = self


    let keyboardToolbar = UIToolbar(frame: CGRect(x: 0, y: 0, width: UIScreen.main.bounds.size.width, height: 44))
    keyboardToolbar.barStyle = .black
    keyboardToolbar.tintColor = UIColor.white

    let barButtonItem = UIBarButtonItem(title: NSLocalizedString("Done", comment: ""), style: .done, target: self, action: #selector(clickToKeyboardToolbarDone(sender:)))

    //(barButtonSystemItem: .done, target: self, action: #selector(clickToKeyboardToolbarDone(sender:)))


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

    let items = [flex, barButtonItem]
    keyboardToolbar.setItems(items, animated: true)

    textField.inputAccessoryView = keyboardToolbar
    textField.inputView = pickerView

}

@IBAction func clickToKeyboardToolbarDone(sender: UIBarButtonItem)
{
    if(textField.isFirstResponder)
    {
        let selectedIndex = pickerView.selectedRow(inComponent: 0)
        let currentDate = arrDate[selectedIndex]

        print("currentDate",currentDate)
    }

    textField.resignFirstResponder()

}

//MARK: - UIPickerViewDelegate, UIPickerViewDataSource Methods

func numberOfComponents(in pickerView: UIPickerView) -> Int
{
    return 1
}

func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int
{
    return arrDate.count
}

func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String?
{
    return arrDate[row]
}

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


/*
// MARK: - Navigation

// In a storyboard-based application, you will often want to do a little preparation before navigation
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
    // Get the new view controller using segue.destinationViewController.
    // Pass the selected object to the new view controller.
}
*/

}



//MARK: - All Date Extension
extension Date
{
   func getDateStringWithFormate(_ formate: String, timezone: String) -> String
    {
        let formatter = DateFormatter()
    formatter.dateFormat = formate
    formatter.timeZone = TimeZone(abbreviation: timezone)

    return formatter.string(from: self)
    }
}

Вы можете использовать представление custompicker, создать массив дат на сегодняшний день до 7 дней, попробуйте этот код.

25.05.2018
  • 1. Не используйте dateFormat, используйте dateStyle. 2. Если вы настаиваете на использовании dateFormat, по крайней мере используйте правильный формат. mm для минут. 3. Нет такого метода как getDateStringWithFormate. 4. Почему бы не использовать старый добрый UIDatePicker с начальной датой, установленной через 7 дней, как это было задано в вопросе? 25.05.2018
  • Как мы можем установить начальную дату через 7 дней? @rmaddy 25.05.2018
  • Я попробовал ваш код, но у меня есть эта ошибка: значение типа «Дата» не имеет члена «addDays», не могли бы вы сказать мне, как это решить? @AnjiMendpara 26.05.2018
  • @rmaddy, как мы можем установить начальную дату с помощью UIDatePicker? 26.05.2018
  • @booak55 задайте для свойства date средства выбора даты любую дату, которую вы хотите. 26.05.2018
  • @rmaddy, но если я сделаю это так, я не смогу установить текущую дату на 7 дней вперед 26.05.2018
  • @booak55 Почему бы и нет? Вы можете установить дату на любую дату, которую вы хотите, как я уже сказал. 26.05.2018
  • @rmaddy вы действительно задали аналогичный вопрос на другом сайте. (Я пытаюсь установить максимальную дату на 7 дней раньше текущей даты (сегодняшней даты).) Как вы решили эту проблему? 26.05.2018
  • @booak55 Для addDays для этого вам нужно добавить addDay func. 28.05.2018
  • Новые материалы

    Как создать диаграмму градиентной кисти с помощью D3.js
    Резюме: Из этого туториала Вы узнаете, как добавить градиентную кисть к диаграмме с областями в D3.js. Мы добавим градиент к значениям SVG и применим градиент в качестве заливки к диаграмме с..

    Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что это выглядит сложно…
    Просто начните и учитесь самостоятельно Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что он кажется мне сложным, и я бросил его. Это в основном инструмент..

    Лицензии с открытым исходным кодом: руководство для разработчиков и создателей
    В динамичном мире разработки программного обеспечения открытый исходный код стал мощной парадигмой, способствующей сотрудничеству, инновациям и прогрессу, движимому сообществом. В основе..

    Объяснение документов 02: BERT
    BERT представил двухступенчатую структуру обучения: предварительное обучение и тонкая настройка. Во время предварительного обучения модель обучается на неразмеченных данных с помощью..

    Как проанализировать работу вашего классификатора?
    Не всегда просто знать, какие показатели использовать С развитием глубокого обучения все больше и больше людей учатся обучать свой первый классификатор. Но как только вы закончите..

    Работа с цепями Маркова, часть 4 (Машинное обучение)
    Нелинейные цепи Маркова с агрегатором и их приложения (arXiv) Автор : Бар Лайт Аннотация: Изучаются свойства подкласса случайных процессов, называемых дискретными нелинейными цепями Маркова..

    Crazy Laravel Livewire упростил мне создание электронной коммерции (панель администратора и API) [Часть 3]
    Как вы сегодня, ребята? В этой части мы создадим CRUD для данных о продукте. Думаю, в этой части я не буду слишком много делиться теорией, но чаще буду делиться своим кодом. Потому что..


    Для любых предложений по сайту: [email protected]