获取 IndexPath - UITextView 应与 indexPath 上的 URL 交互



我有一个集合视图。将显示用户名,如果他签到一个地方和与他在一起的朋友,则会显示用户名。我正在使用用户名作为文本视图,并且我正在为两种类型的文本(朋友和签入(分配URL。它只用了一个问题。

当用户点击链接时,我无法找到获取索引路径的方法。它将发送到链接并触发函数,但我无法获取 indexPath。我到处寻找,但没有关于它的文档。永远欠你的一点帮助,因为我一直在为此挣扎。

这是使用户名显示 2 个链接的功能:

  //GET THE INDEX PATH FOR ASSIGNMENT TO THE LINKS ??
    func assignNameFriendsAndCheckIn(name: String, checkIn: String, friends: String, cellName: UITextView) {
        let nameSurname = name
        let checkIn = checkIn
        var string = name
        let friendsString = friends
        string = "(nameSurname)(checkIn)(friendsString)"
        let attributedString = NSMutableAttributedString(string: string)
        attributedString.addAttribute(NSAttributedString.Key.font, value: UIFont.boldSystemFont(ofSize: 14), range: (string as NSString).range(of: nameSurname))
        attributedString.addAttribute(NSAttributedString.Key.font, value: UIFont.systemFont(ofSize: 11), range: (string as NSString).range(of: checkIn))
        attributedString.addAttribute(NSAttributedString.Key.font, value: UIFont.systemFont(ofSize: 11), range: (string as NSString).range(of: friendsString))
        attributedString.addAttribute(NSAttributedString.Key.link, value: "checkIn", range: (string as NSString).range(of: checkIn))
        cellName.linkTextAttributes = [NSAttributedString.Key.foregroundColor:UIColor.black, NSAttributedString.Key.font: UIFont.systemFont(ofSize: 11)]
        attributedString.addAttribute(NSAttributedString.Key.link, value: "friends", range: (string as NSString).range(of: friendsString))
        cellName.linkTextAttributes = [NSAttributedString.Key.foregroundColor:UIColor.black, NSAttributedString.Key.font: UIFont.systemFont(ofSize: 11)]
        cellName.attributedText = attributedString
    }

这就是我捕获链接的方式:

func textView(_ textView: UITextView, shouldInteractWith URL: URL, in characterRange: NSRange, interaction: UITextItemInteraction) -> Bool {
    if URL.absoluteString == "checkIn" {
        print("Check In")
        return true
    } else if URL.absoluteString == "friends" {
        print("Friends")
        return true
    } else {
        print("No Urls set")
        return false
    }
}

根据Larme给我的建议,我想出了这个,它有效。

在didSelectRow中,我分配了一个点击手势,然后我用链接制作NSAttributedString。在第二部分中,我将检索 collectionView 中的手势点并获取 indexPath。现在将分配操作。由于第一次单击将位于字符串而不是标签上,因此将延迟分配索引路径。所以我正在延迟调度队列的任务:

func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
    let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "CollectionCell", for: indexPath) as! CollectionCell
    cell.nameSurname.delegate = self
    ................................................
    cell.nameSurname.isUserInteractionEnabled = true
    cell.nameSurname.tag = (indexPath.section * 100) + indexPath.item
    let tapName : UITapGestureRecognizer = UITapGestureRecognizer(target: self, action: #selector(didTapName))
    cell.nameSurname.addGestureRecognizer(tapName)
    tapName.delegate = self
    assignNameLocationAndCheckIn(name: nameSurname, checkIn: checkIn, city: city, date: date, friends: friendsString, cellName: cell.nameSurname, postID: cell.postID)
}

这是计算 indexPath 的函数(urlIndexPath 只是一个变量(:

@objc func didTapName(sender: UITapGestureRecognizer) {
        let pointInCollectionView = sender.location(in: collectionView)
        let indexPath = collectionView?.indexPathForItem(at: pointInCollectionView)
        urlIndexPath = indexPath!.item
        print("Name was tapped: (indexPath!.item) : (posts[(indexPath?.row)!].postID!)")
    }

最后,我使用的是 indexPath:

//MARK: 
    func textView(_ textView: UITextView, shouldInteractWith URL: URL, in characterRange: NSRange, interaction: UITextItemInteraction) -> Bool {
        if URL.absoluteString == "checkIn" {
            print("Check In")
            checkInText()
            return true
        } else if URL.absoluteString == "friends" {
            print("Friends")
            tagFriends()
            return true
        } else {
            print("No Urls set")
            return false
        }
    }
    //MARK: 
    func checkInText() {
        DispatchQueue.main.asyncAfter(deadline: .now() + 0.2) {
            print("Send to: (self.urlIndexPath)")
        }
    }
    //MARK: 
    func tagFriends() {
        DispatchQueue.main.asyncAfter(deadline: .now() + 0.2) {
            print("Send to Friends: (self.urlIndexPath)")
        }
    }

最新更新