gpt4 book ai didi

ios - 小型 UITableView,删除 dequeReuseableCell

转载 作者:搜寻专家 更新时间:2023-11-01 06:04:21 24 4
gpt4 key购买 nike

我已经四处阅读,所以除非我的搜索非常糟糕,否则不要将其视为重复。

基本上我有一个小表(5 个固定行)但是它们在元组中确实有与之关联的索引(这就是为什么我使用动态方式而不是静态方式。

玩家的目标是交换周围的细胞。我没有使用 Nib 来填充这些单元格,而是这样。

func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cellID = "Cell"
let customCell = tableView.dequeueReusableCell(withIdentifier: cellID, for: indexPath) as! DefinitionMatchTableViewCell

customCell.background.layer.borderWidth = CGFloat(2.0)

if tableView == nameTableLeft{
customCell.textToDislay!.text = nameList[indexPath.row].0
customCell.background.layer.borderColor = UIColor(red: 255/255, green: 192/255, blue: 1/255, alpha: 1.0).cgColor
let cellIDFromTuple = nameList[indexPath.row].1
customCell.tag = cellIDFromTuple
}

if tableView == definitionTableRight{
customCell.textToDislay!.text = definitionList[indexPath.row].0
customCell.background.layer.borderColor = UIColor(red: 0/255, green: 0/255, blue: 0/255, alpha: 0.2).cgColor
let cellIDFromTupleForDefinition = definitionList[indexPath.row].1
customCell.tag = cellIDFromTupleForDefinition
}

customCell.background.backgroundColor = UIColor.clear
customCell.backgroundColor = UIColor.clear
return customCell
}

现在的问题是,在 iPhone SE 上,5 个单元格无法容纳,这会导致顶部或底部单元格在检查值是否匹配时丢失其引用 ID。这使得游戏无法完成,我需要一种方法,以便我可以使用与每个字符串关联的索引值填充表格,但表格不会重复使用该单元格,但它会保留在内存中。

我能想到的唯一方法是用数据编写一个静态表,然后为每个单元格提供一个不可见的索引,该索引带有与字符串相关联的索引。但是我更愿意动态地进行。

任何关于保持这些细胞状态的建议将不胜感激。谢谢!

编辑 1

这是我根据表中的索引值检查答案的方法。我想问题来自 .indexPathsForVisibleRows,因为有些不可见

    for index in nameTableLeft.indexPathsForVisibleRows!{
let leftCell = nameTableLeft.cellForRow(at: index) as? DefinitionMatchTableViewCell
let rightCell = definitionTableRight.cellForRow(at: index) as? DefinitionMatchTableViewCell

if nameTableLeft.cellForRow(at: index)?.tag == definitionTableRight.cellForRow(at: index)?.tag{
leftCell?.background.layer.borderColor = UIColor.green.cgColor
rightCell?.background.layer.borderColor = UIColor.green.cgColor
counter += 1
}else{
leftCell?.background.layer.borderColor = UIColor.red.cgColor
rightCell?.background.layer.borderColor = UIColor.red.cgColor
}
}

如您所见,我随后会检查标签上的值是否匹配。但是,如果我使用不同的东西,我就会在这个概念上苦苦挣扎。

我的模型

var nameList : [(String, Int)] = [("Trojan", 0),
("Virus", 1),
("Spyware", 2),
("Ransomware", 3),
("Leakware", 4)]
var definitionList : [(String, Int)] = [("Attaches onto another program. Replicates itself. Something loaded onto your device without your knowledge. Continues to spread", 0),
("When malware is disguised as something else. Usually an e-mail attachment", 1),
("Tracks a user's actions, this includes login details, internet habits and any secure accounts", 2),
("Locks a device or encrypts files and demands money to unlock it", 3),
("Threatens to distribute your information", 4)]

编辑2

由于答案中的一些帮助,我决定将其添加到我的答案检查中。

 for answerIndex in 0...4{
if definitionList[answerIndex].1 == nameList[answerIndex].1{
print("MATCH")
counter += 1
}else{
print("NO MATCH")
}
}

我一开始就混淆了定义和名称列表。然后我决定根据表的总长度查看放在元组中的两个索引。不幸的是,我不得不求助于神奇的数字,因为你不能遍历元组。

所以这个小循环决定索引是否在我的元组中排列,如果排列正确,则不正确。再次感谢大家的帮助。

最佳答案

我也解决了类似的问题。我的建议是继续重复使用细胞。在外部将每个单元格对应的数据存储在单独的模型类中。然后将其存储在可变数组中。当您打乱单元格时,打乱可变数组中的数据。

可以通过以下方式实现。

模型

class model: NSObject {

var name: String = ""
var definition: String = ""
var type: String = ""

required init(name: String, definition: String, type: String) {
super.init()

self.name = name
self.definition = definition
self.type = type
}
}

自定义 UITableViewCell - 不同布局的简单示例

class CustomTableViewCell: UITableViewCell {

var nameLabel: UILabel = UILabel()
var definitionLabel: UILabel = UILabel()

override init(style: UITableViewCellStyle, reuseIdentifier: String?)
{
super.init(style: style, reuseIdentifier: reuseIdentifier)

nameLabel.textColor = UIColor.black
nameLabel.font = UIFont.systemFont(ofSize: 15)
nameLabel.textAlignment = NSTextAlignment.left
self.contentView.addSubview(nameLabel)

definitionLabel.textColor = UIColor.brown
definitionLabel.font = UIFont.systemFont(ofSize: 15)
definitionLabel.textAlignment = NSTextAlignment.right
self.contentView.addSubview(definitionLabel)
}

required init?(coder aDecoder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}

override func layoutSubviews() {
super.layoutSubviews()

nameLabel.frame = CGRect(x: 10, y: 10, width: self.contentView.frame.size.width - 20, height: self.contentView.frame.size.height - 20)
definitionLabel.frame = CGRect(x: 10, y: 10, width: self.contentView.frame.size.width - 20, height: self.contentView.frame.size.height - 20)
}

override func setSelected(_ selected: Bool, animated: Bool) {
super.setSelected(selected, animated: animated)

}

}

注册单元格:

self.tableView.register(CustomTableViewCell.self, forCellReuseIdentifier: "reuseIdentifier")

根据模型使用CustomTableViewCell:

override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "reuseIdentifier", for: indexPath)

// Configure the cell...
if model.type == "name" {
cell.nameLabel.text = model.name
cell.definitionLabel.isHidden = true
}else if model.type == "definition" {
cell.definitionLabel.text = model.definition
cell.nameLabel.isHidden = true
}

return cell
}

移动单元格部分:

let mutableArray:[model] = [model1, model2, model3, model4, model5] // model class holds data for each cell

func tableView(_ tableView: UITableView, moveRowAt sourceIndexPath: IndexPath, to destinationIndexPath: IndexPath) {
let source = sourceIndexPath.row;
let destination = destinationIndexPath.row;

let sourceModel = mutableArray[source]
let destinationModel = mutableArray[destination]

mutableArray[source] = destinationModel
mutableArray[destination] = sourceModel
}

如果您对此实现有任何疑问,请随时发表评论。随时提出修改建议,使它变得更好:)

编辑:-

即使它是一个具有索引位置的元组,您也可以在行相应移动时更改值。

var nameList : [(String, Int)] = [("Trojan", 0),
("Virus", 1),
("Spyware", 2),
("Ransomware", 3),
("Leakware", 4)]

let source = sourceIndexPath.row
let destination = destinationIndexPath.row

var sourceTuple: (String, Int) = nameList[source]
var destinationTuple: (String, Int) = nameList[destination]

sourceTuple.1 = destination
destinationTuple.1 = source

nameList[destination] = sourceTuple
nameList[source] = destinationTuple

关于ios - 小型 UITableView,删除 dequeReuseableCell,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41697286/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com