IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Swift Discussion :

table view et popover


Sujet :

Swift

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    36
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 36
    Points : 18
    Points
    18
    Par défaut table view et popover
    Bonjour à tous,

    swift 4.2 - macOS

    j'ai un problème pour récupérer une valeur depuis un popover...

    j'ai un tableview avec dans une cellule un textfield et un button
    quand j'appuie sur le button cela ouvre un popover dans lequel je choisi une valeur qui devrait remplir le textfield

    l'ouverture du popover marche bien... mais je perd le focus sur la ligne choisie

    des idées....

    merci

  2. #2
    Membre habitué
    Inscrit en
    Mars 2007
    Messages
    258
    Détails du profil
    Informations personnelles :
    Âge : 43

    Informations forums :
    Inscription : Mars 2007
    Messages : 258
    Points : 127
    Points
    127
    Par défaut Réponse
    Hello Cloeuf,

    Tu dois utiliser les protocols et les délégations.
    En gros, dans ton popoverController (second controller), tu crées un protocol qui va retourner la valeur sélectionnée à ton premier controller (TableView).

    Voici un exemple :

    • ViewController (mon premier controller, chez toi c'est ta TableView)


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    import UIKit
     
    class ViewController: UIViewController {
     
        let openPopover: UIButton = {
            let button = UIButton()
            button.translatesAutoresizingMaskIntoConstraints = false
            button.setTitle("Open Popover", for: .normal)
            button.setTitleColor(.lightGray, for: .normal)
            button.layer.borderColor = UIColor.lightGray.cgColor
            button.layer.borderWidth = 1
            button.layer.cornerRadius = 10
            button.addTarget(self, action: #selector(openPopover(_:)), for: .touchUpInside)
            return button
        }()
     
        let resultLabel: UILabel = {
            let label = UILabel()
            label.translatesAutoresizingMaskIntoConstraints = false
            label.text = "Résultat :"
            label.textColor = .lightGray
            label.textAlignment = .left
            return label
        }()
     
        let resultTextfield: UITextField = {
            let t = UITextField()
            t.translatesAutoresizingMaskIntoConstraints = false
            t.layer.cornerRadius = 10
            t.layer.borderColor = UIColor.lightGray.cgColor
            t.layer.borderWidth = 1
            t.textAlignment = .center
            t.textColor = .lightGray
            return t
        }()
     
        override func viewDidLoad() {
            super.viewDidLoad()
     
            self.view.backgroundColor = .white
            self.title = "Développez.com"
     
            self.view.addSubview(openPopover)
     
            self.view.addSubview(resultLabel)
     
            self.view.addSubview(resultTextfield)
     
            setupView(UIScreen.main.bounds.size)
        }
     
        func setupView(_ size: CGSize) {
     
            resultLabel.topAnchor.constraint(equalTo: view.topAnchor, constant: 130).isActive = true
            resultLabel.leftAnchor.constraint(equalTo: view.leftAnchor, constant: 20).isActive = true
            resultLabel.widthAnchor.constraint(equalToConstant: 80).isActive = true
     
            resultTextfield.topAnchor.constraint(equalTo: view.topAnchor, constant: 130).isActive = true
            resultTextfield.leftAnchor.constraint(equalTo: resultLabel.rightAnchor, constant: 5).isActive = true
            resultTextfield.rightAnchor.constraint(equalTo: view.rightAnchor, constant: -20).isActive = true
     
            openPopover.topAnchor.constraint(equalTo: resultLabel.bottomAnchor, constant: 50).isActive = true
            openPopover.leftAnchor.constraint(equalTo: view.leftAnchor, constant: 50).isActive = true
            openPopover.rightAnchor.constraint(equalTo: view.rightAnchor, constant: -50).isActive = true
        }
     
        @objc func openPopover(_ sender: UIButton) {
            let vc = PopoverController()
            vc.preferredContentSize = CGSize(width: 400,height: 300)
            vc.modalPresentationStyle = .popover
     
            vc.delegate = self
     
            if let pres = vc.presentationController {
                pres.delegate = self
            }
            self.present(vc, animated: true)
            if let pop = vc.popoverPresentationController {
                pop.sourceView = (sender as UIView)
                pop.sourceRect = (sender as UIView).bounds
            }
        }
     
    }
     
    extension ViewController: ReturnDelegate {
     
        func DoSomething(text: String) {
            resultTextfield.text = "\(text)"
        }
     
    }
     
    extension ViewController: UIPopoverPresentationControllerDelegate {
     
        func adaptivePresentationStyle(for controller: UIPresentationController) -> UIModalPresentationStyle {
            return .none
        }
     
    }
    • PopoverController


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    import UIKit
     
    protocol ReturnDelegate {
        func DoSomething(text: String)
    }
     
    class PopoverController: UIViewController {
     
        let picker: UIPickerView = {
            let p = UIPickerView()
            p.translatesAutoresizingMaskIntoConstraints = false
            p.backgroundColor = .lightGray
            return p
        }()
     
        let buttonOK: UIButton = {
            let button = UIButton()
            button.translatesAutoresizingMaskIntoConstraints = false
            button.setTitle("OK", for: .normal)
            button.setTitleColor(.white, for: .normal)
            button.layer.borderWidth = 1
            button.layer.borderColor = UIColor.white.cgColor
            button.layer.cornerRadius = 10
            button.addTarget(self, action: #selector(okPressed(_:)), for: .touchUpInside)
            return button
        }()
     
        var delegate: ReturnDelegate!
        var returnValue: String?
        let dataArray = ["Test 1", "Test 2", "Test 3"]
     
        override func viewDidLoad() {
            super.viewDidLoad()
     
            self.view.backgroundColor = .lightGray
     
            picker.delegate = self
            picker.dataSource = self
            self.view.addSubview(picker)
     
            self.view.addSubview(buttonOK)
     
            setupView(UIScreen.main.bounds.size)
        }
     
        func setupView(_ size: CGSize) {
            picker.topAnchor.constraint(equalTo: view.topAnchor).isActive = true
            picker.leftAnchor.constraint(equalTo: view.leftAnchor).isActive = true
            picker.rightAnchor.constraint(equalTo: view.rightAnchor).isActive = true
     
            buttonOK.topAnchor.constraint(equalTo: picker.bottomAnchor, constant: 20).isActive = true
            buttonOK.leftAnchor.constraint(equalTo: view.leftAnchor, constant: 50).isActive = true
            buttonOK.rightAnchor.constraint(equalTo: view.rightAnchor, constant: -50).isActive = true
     
        }
     
        @objc func okPressed(_ sender: UIButton) {
            if let val = returnValue {
                delegate.DoSomething(text: val)
                self.dismiss(animated: true, completion: nil)
            }
        }
     
    }
     
    extension PopoverController: UIPickerViewDelegate, UIPickerViewDataSource {
     
        func numberOfComponents(in pickerView: UIPickerView) -> Int {
            return 1
        }
     
        func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int {
            return dataArray.count
        }
     
        func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? {
            return dataArray[row]
        }
     
        func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) {
            returnValue = dataArray[row]
     
        }
     
    }
    • Resultat en image :


    Nom : IMG_1387.jpeg
Affichages : 135
Taille : 23,0 Ko Nom : IMG_1388.jpeg
Affichages : 135
Taille : 18,1 Ko

    Bien à toi

    Benjamin

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    36
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 36
    Points : 18
    Points
    18
    Par défaut
    Merci... pour ta réponse...

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. arcpy : remplir les champs d'une nouvelle table (view)
    Par noramokh dans le forum Général Python
    Réponses: 1
    Dernier message: 25/05/2014, 16h27
  2. Appli Iphone Objective C - Données Table View
    Par Fuotmad dans le forum Objective-C
    Réponses: 8
    Dernier message: 23/04/2014, 14h32
  3. Comment creer un table view comme ceci
    Par guns65 dans le forum Développement iOS
    Réponses: 2
    Dernier message: 10/02/2014, 18h32
  4. [JTA] Problème : Table/View existe déjà dans schéma
    Par max224 dans le forum Java EE
    Réponses: 1
    Dernier message: 30/04/2013, 15h06

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo