首页 文章

阻止电话套件中的电话号码

提问于
浏览
0

我正在尝试使用CallKit向我的应用添加一项功能,将一些电话号码添加到黑名单!下面的代码是我的全部观点!!

class BlacklistViewController: UIViewController ,UITableViewDataSource, UITableViewDelegate {


    var phoneNumbersArrCoreData = [BlockedPhoneNumbers]()
    var listPhoneNumbers:[CXCallDirectoryPhoneNumber] = []
    @IBOutlet weak var TableView: UITableView!
    @IBOutlet weak var BtnAddO: UIButton!
    @IBOutlet weak var EntPhonenumber: UITextField!

    @IBAction func BtnAddA(_ sender: Any) {
        if !(EntPhonenumber.text?.isEmpty)!
        {
            let blackedPhonenumbers_CoreData = BlockedPhoneNumbers(context: PersistanceService.context)
            blackedPhonenumbers_CoreData.phoneNumber = Int64.init(EntPhonenumber.text!)!
            PersistanceService.saveContext()
            getCoreData()
            TableView.reloadData()
        }
    }

    var coreData = [BlockedPhoneNumbers]()

    func getCoreData()
    {
        listPhoneNumbers.removeAll()
        let fetchRequest : NSFetchRequest<BlockedPhoneNumbers> = BlockedPhoneNumbers.fetchRequest()
        do
        {
            let FetchedResultFromDB = try  PersistanceService.context.fetch(fetchRequest)
            coreData = FetchedResultFromDB
            print("============\n===========\n")

            if coreData.count > 0
            {
                for i in 0..<coreData.count
                {
                    listPhoneNumbers.append(coreData[i].phoneNumber)
                }
            }
            print("============\n===========\n")

        }
        catch{
            print("gettin blocked number from db got error")
        }
    }


    override func viewDidLoad() {

        BtnAddO.layer.cornerRadius = 5
        BtnAddO.layer.borderColor = UIColor.white.cgColor
        BtnAddO.layer.borderWidth = 0.8
        EntPhonenumber.attributedPlaceholder = NSAttributedString(string: "Enter a phone number to block",attributes: [NSAttributedString.Key.foregroundColor: UIColor.lightText])
        getCoreData()

        super.viewDidLoad()
        view.backgroundColor = UIColor.init(red: 25/255, green: 28/255, blue: 46/255, alpha: 1)
        TableView.delegate = self
        TableView.dataSource = self
    }
    func beginRequest(with context: CXCallDirectoryExtensionContext) {
        getCoreData()
        let blockedPhoneNumbers: [CXCallDirectoryPhoneNumber] = listPhoneNumbers
        for phoneNumber in blockedPhoneNumbers.sorted(by: <) {
            context.addBlockingEntry(withNextSequentialPhoneNumber: phoneNumber)
        }

        context.completeRequest()
    }


    //MARK: - TableView
    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return listPhoneNumbers.count
    }

    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCell(withIdentifier: "BlackListCell") as? BlackListTableViewCell
        cell?.ContactImg.layer.masksToBounds = true
        cell?.mainView.layer.cornerRadius = 10
        cell?.mainView.backgroundColor = UIColor(red: 42/255, green: 48/255, blue: 66/255, alpha: 1)
        cell?.ContactImg.layer.cornerRadius = 5
        cell?.ContactImg.image = UIImage(named: "Blocked")
        cell?.unBlock.imageView?.image = nil
        cell?.unBlock.setTitle("UNBLOCK", for: UIControl.State.normal)
        cell?.unBlock.layer.cornerRadius = (cell?.unBlock.frame.size.height)!/2
        cell?.SetUnblockBtn {

我在这里得到错误,下面

let context:NSManagedObjectContext = PersistanceService.context

            context.delete(self.phoneNumbersArrCoreData[indexPath.row] as NSManagedObject)
            self.phoneNumbersArrCoreData.remove(at: indexPath.row)
            print("data deleted!!!")
               }
        cell?.phoneNumber.text = String(listPhoneNumbers[indexPath.row])



        return cell!
    }
    func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
        return 85
    }
}

为了解释代码,我保存了用户将在核心数据中输入的每个数字(entityName:BlockedPhoneNumbers) . 我不确定即使这是保存他们需要被阻止的数字的正确方法!

当用户按下按钮时,我保存了数字并且工作正常(但我不确定这是否正确!) . 在getCoreData中,我获取核心数据并在表视图中显示它们 . 这表明核心数据运行良好!但是当用户想要取消阻止联系人并按下表格视图的CELL中的按钮时,我收到错误并且应用程序崩溃,它说:

线程1:致命错误:索引超出范围

我的问题是:

  • 为什么我会收到此错误?

2.as我找不到callKit的任何教程我相信我做错了 .

任何人都可以帮我这个吗?

1 回答

  • 0

    你有太多的数组:

    • listPhoneNumbers ,其中包含您的整数

    • coreData 其中包含您的核心数据项

    • phoneNumbersArrCoreData 可能包含您的核心数据项,但您不会添加任何内容 .

    结果, phoneNumbersArrCoreData 为空 . 当您尝试从空数组中删除对象时,您将获得数组边界异常 .

    你应该删除三个数组中的两个 .

    class BlacklistViewController: UIViewController ,UITableViewDataSource, UITableViewDelegate {
    
    
        var blockedNumbers = [BlockedPhoneNumbers]()
        @IBOutlet weak var TableView: UITableView!
        @IBOutlet weak var BtnAddO: UIButton!
        @IBOutlet weak var EntPhonenumber: UITextField!
    
        @IBAction func BtnAddA(_ sender: Any) {
            if !(EntPhonenumber.text?.isEmpty)!
            {
                let blackedPhonenumbers_CoreData = BlockedPhoneNumbers(context: PersistanceService.context)
                blackedPhonenumbers_CoreData.phoneNumber = Int64.init(EntPhonenumber.text!)!
                PersistanceService.saveContext()
                getCoreData()
                TableView.reloadData()
            }
        }
    
        func getCoreData()
        {
            let fetchRequest : NSFetchRequest<BlockedPhoneNumbers> = BlockedPhoneNumbers.fetchRequest()
            do
            {
                let FetchedResultFromDB = try  PersistanceService.context.fetch(fetchRequest)
                blockedNumbers = FetchedResultFromDB
                print("============\n===========\n")
            }
            catch{
                print("gettin blocked number from db got error")
            }
        }
    
    
        override func viewDidLoad() {
    
            BtnAddO.layer.cornerRadius = 5
            BtnAddO.layer.borderColor = UIColor.white.cgColor
            BtnAddO.layer.borderWidth = 0.8
            EntPhonenumber.attributedPlaceholder = NSAttributedString(string: "Enter a phone number to block",attributes: [NSAttributedString.Key.foregroundColor: UIColor.lightText])
            getCoreData()
    
            super.viewDidLoad()
            view.backgroundColor = UIColor.init(red: 25/255, green: 28/255, blue: 46/255, alpha: 1)
            TableView.delegate = self
            TableView.dataSource = self
        }
    
        //MARK: - TableView
        func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
            return blockedNumbers.count
        }
    
        func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
            let cell = tableView.dequeueReusableCell(withIdentifier: "BlackListCell") as? BlackListTableViewCell
            cell?.ContactImg.layer.masksToBounds = true
            cell?.mainView.layer.cornerRadius = 10
            cell?.mainView.backgroundColor = UIColor(red: 42/255, green: 48/255, blue: 66/255, alpha: 1)
            cell?.ContactImg.layer.cornerRadius = 5
            cell?.ContactImg.image = UIImage(named: "Blocked")
            cell?.unBlock.imageView?.image = nil
            cell?.unBlock.setTitle("UNBLOCK", for: UIControl.State.normal)
            cell?.unBlock.layer.cornerRadius = (cell?.unBlock.frame.size.height)!/2
            cell?.SetUnblockBtn {
                let context:NSManagedObjectContext = PersistanceService.context
    
                context.delete(self.blockedNumbers[indexPath.row] as NSManagedObject)
                self.phoneNumbersArrCoreData.remove(at: indexPath.row)
                print("data deleted!!!")
                   }
            cell?.phoneNumber.text = blockedNumbers[indexPath.row].phoneNumber
    
            return cell!
        }
        func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
            return 85
        }
    }
    

    实际将数据加载到Call Kit阻止列表中的代码需要进入应用程序中的CallKit扩展 . 您将需要使用应用程序组与扩展共享Core Data存储 .

相关问题