web-dev-qa-db-ja.com

iOSでピッカーに連絡して電話番号を取得する

enter image description here 連絡先を選択して電話番号を表示するための画像ピッカーのようなオプションが必要です。以下のコードを使用して連絡先名を取得できました

このコードを使用すると、名前のみが返されます。連絡先リストから連絡先を選択するオプションが必要です

5
Midhun Narayan

インポートContactsUI
およびインクルード-CNContactPickerDelegate

import ContactsUI

class YourViewController: CNContactPickerDelegate{

    //MARK:- contact picker
    func onClickPickContact(){


        let contactPicker = CNContactPickerViewController()
        contactPicker.delegate = self
        contactPicker.displayedPropertyKeys =
            [CNContactGivenNameKey
                , CNContactPhoneNumbersKey]
        self.present(contactPicker, animated: true, completion: nil)

    }

    func contactPicker(_ picker: CNContactPickerViewController,
                       didSelect contactProperty: CNContactProperty) {

    }

    func contactPicker(_ picker: CNContactPickerViewController, didSelect contact: CNContact) {
        // You can fetch selected name and number in the following way

        // user name
        let userName:String = contact.givenName

        // user phone number
        let userPhoneNumbers:[CNLabeledValue<CNPhoneNumber>] = contact.phoneNumbers
        let firstPhoneNumber:CNPhoneNumber = userPhoneNumbers[0].value


        // user phone number string
        let primaryPhoneNumberStr:String = firstPhoneNumber.stringValue

        print(primaryPhoneNumberStr)

    }

    func contactPickerDidCancel(_ picker: CNContactPickerViewController) {

    }
}
12
Midhun Narayan
import ContactsUI

private let contactPicker = CNContactPickerViewController()

コンタクトピッカーを開始するボタンのクリック:

@IBAction func accessContacts(_ sender: Any) {
    contactPicker.delegate = self
    self.present(contactPicker, animated: true, completion: nil)
}

デリゲートメソッドを実装する

extension YourViewController: CNContactPickerDelegate {

    func contactPicker(_ picker: CNContactPickerViewController, didSelect contact: CNContact) {
        let phoneNumberCount = contact.phoneNumbers.count

        guard phoneNumberCount > 0 else {
            dismiss(animated: true)
            //show pop up: "Selected contact does not have a number"
            return
        }

        if phoneNumberCount == 1 {
            setNumberFromContact(contactNumber: contact.phoneNumbers[0].value.stringValue)

        } else {
            let alertController = UIAlertController(title: "Select one of the numbers", message: nil, preferredStyle: .alert)

            for i in 0...phoneNumberCount-1 {
                let phoneAction = UIAlertAction(title: contact.phoneNumbers[i].value.stringValue, style: .default, handler: {
                alert -> Void in
                    self.setNumberFromContact(contactNumber: contact.phoneNumbers[i].value.stringValue)
                })
                alertController.addAction(phoneAction)
            }
            let cancelAction = UIAlertAction(title: "Cancel", style: .destructive, handler: {
            alert -> Void in

            })
            alertController.addAction(cancelAction)

            dismiss(animated: true)
            self.present(alertController, animated: true, completion: nil)
        }
    }

    func setNumberFromContact(contactNumber: String) {

        //UPDATE YOUR NUMBER SELECTION LOGIC AND PERFORM ACTION WITH THE SELECTED NUMBER

        var contactNumber = contactNumber.replacingOccurrences(of: "-", with: "")
        contactNumber = contactNumber.replacingOccurrences(of: "(", with: "")
        contactNumber = contactNumber.replacingOccurrences(of: ")", with: "")
        contactNumber = contactNumber.removeWhitespacesInBetween()
        guard contactNumber.count >= 10 else {
            dismiss(animated: true) {
                self.popUpMessageError(value: 10, message: "Selected contact does not have a valid number")
            }
            return
        }
        textFieldNumber.text = String(contactNumber.suffix(10))

    }

    func contactPickerDidCancel(_ picker: CNContactPickerViewController) {

    }
}
3
Sujal

この拡張機能を使用して、連絡先名を取得できます。

extension CNContact {
    open func displayName() -> String {
        return givenName + " " + familyName
    }
}

これは、詳細を取得するクラスです EPContact

1
AshvinGudaliya

Swift 5Contact Picker Get Email

あなたが要求したのと同じことを行う方法の例を見せたかったのですが、代わりに電子メールを使用し、Swift 5に更新しました。これは、上記の回答の一部が正しくコンパイルされないためです。これには、ユーザーが選択したかどうかにかかわらず、複数の電子メールを1つの文字列に連結する「すべて」オプションのボーナスを追加しました。

まず、import ContactsUIを必ずインポートしてください

次に、テキストフィールドへのアウトレットがあることを確認してください。

@IBOutlet var emailTextField: UITextField!

次に、連絡先ピッカーをviewControllerのメンバー変数として設定する必要があります。これは、後で連絡先ピッカーを表示するための情報を保持します。

class EmailViewController: UIViewController {
    @IBOutlet var emailTextField: UITextField!
    private let contactPicker = CNContactPickerViewController()

    //... rest of view controller code, etc...
}

最後に、以下のコードを使用して、この拡張機能をEmailViewControllerに追加するだけです。

extension EmailViewController: CNContactPickerDelegate {

    func contactPicker(_ picker: CNContactPickerViewController, didSelect contact: CNContact) {
        let emailNumberCount = contact.emailAddresses.count

        //@JA - They have to have at least 1 email address
        guard emailNumberCount > 0 else {
            dismiss(animated: true)
            //show pop up: "Selected contact does not have a number"
            let alertController = UIAlertController(title: "No emails found for contact: "+contact.givenName+" "+contact.familyName, message: nil, preferredStyle: .alert)
            let cancelAction = UIAlertAction(title: "Ok", style: .default, handler: {
            alert -> Void in

            })
            alertController.addAction(cancelAction)
            self.present(alertController, animated: true, completion: nil)
            return
        }

        //@JA - If they have only 1 email it's easy.  If there is many emails we want to concatenate them and separate by commas , , ...
        if emailNumberCount == 1 {
            setEmailFromContact(contactEmail: contact.emailAddresses[0].value as String)
        } else {
            let alertController = UIAlertController(title: "Select an email from contact: "+contact.givenName+" "+contact.familyName+" or select 'All' to send to every email listed.", message: nil, preferredStyle: .alert)

            for i in 0...emailNumberCount-1 {
                let emailAction = UIAlertAction(title: contact.emailAddresses[i].value as String, style: .default, handler: {
                alert -> Void in
                    self.setEmailFromContact(contactEmail: contact.emailAddresses[i].value as String)
                })
                alertController.addAction(emailAction)
            }

            let allAction = UIAlertAction(title: "All", style: .destructive, handler: {
            alert -> Void in
                var emailConcat = ""
                for i in 0...emailNumberCount-1{
                    if(i != emailNumberCount-1){ //@JA - Only add the , if we are not on the last item of the array
                        emailConcat = emailConcat + (contact.emailAddresses[i].value as String)+","
                    }else{
                        emailConcat = emailConcat + (contact.emailAddresses[i].value as String)
                    }
                }
                self.setEmailFromContact(contactEmail: emailConcat)//@JA - Sends the concatenated version of the emails separated by commas
            })
            alertController.addAction(allAction)

            let cancelAction = UIAlertAction(title: "Cancel", style: .cancel, handler: {
            alert -> Void in

            })
            alertController.addAction(cancelAction)

            dismiss(animated: true)
            self.present(alertController, animated: true, completion: nil)
        }
    }

    func setEmailFromContact(contactEmail: String){
        emailTextField.text = contactEmail
    }

    func contactPickerDidCancel(_ picker: CNContactPickerViewController) {
        print("contact picker canceled")
    }
}

たとえば、ボタンのアクションイベントでピッカーを呼び出すには、次のようにします。

@IBAction func contactsButtonPressed(_ sender: UIButton) {
     contactPicker.delegate = self
     self.present(contactPicker, animated: true, completion: nil)
}

contactPicker.delegate = selfは、私の場合、必要なCNContactPickerDelegateプロトコル関数へのアクセスを提供するviewControllerクラス(emailViewController)の拡張機能が原因で機能します。

0
Joseph Astrahan