- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是快速编程的新手 我有一个程序,我正在尝试设置它会将您从文本框中键入的每个字符添加到 TableView 中。我已经通过许多论坛和视频进行了故障排除,但似乎无法让我的 tableview 更新,当我认为我接近时,它会抛出 SIGBART 错误。所以我的问题是为什么自定义 tableview 单元格不会出现在 tableview 中?这是我的代码:
抱歉,如果这是一个广泛或重复的问题,我不知道我的下一步应该是什么,因为我已经尝试了很多资源。非常感谢!
import UIKit
//conversion key
let alphaNumToMorse = [
"A": ".-",
"B": "-...",
"C": "-.-.",
"D": "-..",
"E": ".",
"F": "..-.",
"G": "--.",
"H": "....",
"I": "..",
"J": ".---",
"K": "-.-",
"L": ".-..",
"M": "--",
"N": "-.",
"O": "---",
"P": ".--.",
"Q": "--.-",
"R": ".-.",
"S": "...",
"T": "-",
"U": "..-",
"V": "...-",
"W": ".--",
"X": "-..-",
"Y": "-.--",
"Z": "--..",
"a": ".-",
"b": "-...",
"c": "-.-.",
"d": "-..",
"e": ".",
"f": "..-.",
"g": "--.",
"h": "....",
"i": "..",
"j": ".---",
"k": "-.-",
"l": ".-..",
"m": "--",
"n": "-.",
"o": "---",
"p": ".--.",
"q": "--.-",
"r": ".-.",
"s": "...",
"t": "-",
"u": "..-",
"v": "...-",
"w": ".--",
"x": "-..-",
"y": "-.--",
"z": "--..",
"1": ".----",
"2": "..---",
"3": "...--",
"4": "....-",
"5": ".....",
"6": "-....",
"7": "--...",
"8": "---..",
"9": "----.",
"0": "-----",
"?":"..--..",
"!":"-.-.--",
" ": " / ",
]
class FirstViewController: UIViewController, UITextViewDelegate, UITableViewDelegate, UITableViewDataSource {
//outlet calls
@IBOutlet weak var translationTextView: UITextView!
@IBOutlet weak var translationLabel: UILabel!
@IBOutlet weak var entertextTextView: UITextView!
@IBOutlet weak var entertextLabel: UILabel!
@IBOutlet weak var clearButton: UIButton!
@IBOutlet weak var copyButton: UIButton!
@IBOutlet weak var sendButton: UIButton!
@IBOutlet weak var hidekeyboardButton: UIButton!
@IBOutlet weak var tableView: UITableView!
//view did load function
override func viewDidLoad() {
super.viewDidLoad()
//sets the entertextTextView and tableView as a UITextView delegate and tableView delegate
self.entertextTextView.delegate = self
tableView.delegate = self
tableView.dataSource = self
//sets translation textview back color and text color
translationTextView.backgroundColor = UIColor.clear
translationTextView.textColor = UIColor.white
//sets translation label forecolor
translationLabel.textColor = UIColor.white
//disables the clear, copy, and send button
clearButton.isEnabled = false
copyButton.isEnabled = false
sendButton.isEnabled = false
hidekeyboardButton.isEnabled = false
}
//adds new rows to the tableview for each character typed
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return entertextTextView.text.count
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath)
let myText = entertextTextView.text!
cell.textLabel?.text = "\(myText[myText.index(myText.startIndex, offsetBy: indexPath.row)])"
return cell
}
//check if the user has the keyboard visible or not, then enables/disables the hide keyboard button accordingly
func textViewDidBeginEditing(_ textView: UITextView) {
hidekeyboardButton.isEnabled = true
}
func textViewDidEndEditing(_ textView: UITextView) {
hidekeyboardButton.isEnabled = false
}
//when the user touches outside the keyboard, it is no longer shown
override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) {
view.endEditing(true)
hidekeyboardButton.isEnabled = false
}
//conversion function
func convertLetterToMorse(_ input: Character) -> String {
var returnChar = alphaNumToMorse[String(input)]
if returnChar == nil {
returnChar = ""
}
return returnChar!
}
var stringToConvert = String()
func convertStringToMorse(_ input: String) -> String {
return input.characters
.compactMap { alphaNumToMorse[String($0)] }
.joined(separator: " ")
}
//button touch up inside functions
//clear button
@IBAction func clearbuttonPress(_ sender: Any) {
entertextTextView.text = ""
translationTextView.text = ""
entertextLabel.isHidden = false
translationLabel.isHidden = false
copyButton.isEnabled = false
sendButton.isEnabled = false
clearButton.isEnabled = false
}
//copy button
@IBAction func copybuttonPress(_ sender: Any) {
UIPasteboard.general.string = translationTextView.text
}
//hide keyboard button
@IBAction func hidekeyboardbuttonPress(_ sender: Any) {
self.view.endEditing(true)
hidekeyboardButton.isEnabled = false
}
//send button
@IBAction func sendbuttonPress(_ sender: Any) {
}
//entertextTextView text change function
func textViewDidChange(_ textView: UITextView) {
//update chars variable everytime textchanges for listview
let chars = Array(entertextTextView.text)
//converted text updated
if entertextTextView != nil {
let outputText = convertStringToMorse(entertextTextView.text)
translationTextView.text = "\(outputText)"
//if entertextTextView letter count is more than zero then . . .
if entertextTextView.text.count > 0 {
//hides entertext and translation labels
entertextLabel.isHidden = true
translationLabel.isHidden = true
//enables clear, copy, and send buttons
clearButton.isEnabled = true
copyButton.isEnabled = true
sendButton.isEnabled = true
hidekeyboardButton.isEnabled = true
}
//if entertextTextView letter count is less than one then . . .
if entertextTextView.text.count < 1 {
//shows entertext and translation labels
entertextLabel.isHidden = false
translationLabel.isHidden = false
//disables clear, copy, and send buttons
clearButton.isEnabled = false
copyButton.isEnabled = false
sendButton.isEnabled = false
}
//Input textview auto adapt font size
if (entertextTextView.text.isEmpty || entertextTextView.bounds.size.equalTo(CGSize.zero)) {
return;
}
let entertextTextViewSize = entertextTextView.frame.size;
let fixedWidth = entertextTextViewSize.width;
let expectSize = entertextTextView.sizeThatFits(CGSize(width : fixedWidth, height : CGFloat(MAXFLOAT)));
var expectFont = entertextTextView.font;
if (expectSize.height > entertextTextViewSize.height) {
while (entertextTextView.sizeThatFits(CGSize(width : fixedWidth, height : CGFloat(MAXFLOAT))).height > entertextTextViewSize.height) {
expectFont = entertextTextView.font!.withSize(entertextTextView.font!.pointSize - 1)
entertextTextView.font = expectFont
}
}
else {
while (entertextTextView.sizeThatFits(CGSize(width : fixedWidth,height : CGFloat(MAXFLOAT))).height < entertextTextViewSize.height) {
expectFont = entertextTextView.font;
entertextTextView.font = entertextTextView.font!.withSize(entertextTextView.font!.pointSize + 1)
}
entertextTextView.font = expectFont;
}
//Translation textview auto adapt font size
if (translationTextView.text.isEmpty || translationTextView.bounds.size.equalTo(CGSize.zero)) {
return;
}
let translationTextViewSize = translationTextView.frame.size;
let fixedWidth2 = translationTextViewSize.width;
let expectSize2 = translationTextView.sizeThatFits(CGSize(width : fixedWidth2, height : CGFloat(MAXFLOAT)));
var expectFont2 = translationTextView.font;
if (expectSize2.height > translationTextViewSize.height) {
while (translationTextView.sizeThatFits(CGSize(width : fixedWidth2, height : CGFloat(MAXFLOAT))).height > translationTextViewSize.height) {
expectFont2 = translationTextView.font!.withSize(translationTextView.font!.pointSize - 1)
translationTextView.font = expectFont2
}
}
else {
while (translationTextView.sizeThatFits(CGSize(width : fixedWidth2,height : CGFloat(MAXFLOAT))).height < translationTextViewSize.height) {
expectFont2 = translationTextView.font;
translationTextView.font = translationTextView.font!.withSize(translationTextView.font!.pointSize + 1)
}
translationTextView.font = expectFont2;
}
}
}
}
最佳答案
我认为您的代码中存在一些问题。首先,看一下 Apple Tutorial有关动态表格 View 的一些有用信息。基本上,您需要某种数组来存储从 TextView 输入的所有字符串。根据索引路径(这也在 Apple 教程中),您使用此数组将所有字符串加载到 TableView 中。 tableView.reloadData()
可用于在输入新字符串后刷新 TableView 。
您当前的代码,即使它能够正确加载表格 View ,也只会显示相同文本的多个副本,因为您使用 entertextTextView.text
来填充每个 表格 View 中的单元格。就像我之前提到的,遍历字符串数组将是动态 TableView 的最佳方式。如果您还有其他问题,请发表评论并提问。祝你好运!
是的,就像其他用户提到的那样,您的 TableView 加载代码中存在许多小错误,导致它崩溃。按照我链接的教程,您应该能够轻松理解和解决这些问题。
关于ios - 自定义 TableView 单元格未添加到 tableview,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52845151/
我正在对 tableView 是否呈现单元格进行单元测试。 我发现 tableView.cellForRow(at:) 返回 nil,而 tableView.dataSource?tableView(
我有 Tableview 用于显示客户下的食品订单。其中包含水平 UIStackview。在 UIStackView UIStackview 中很少有一/两行标签和一个用于显示订单项的UITableV
我有 Viewcontroller,我在其中设置了 ScrollView 。在 scrollview 中,我有一个 tableview,它位于 Container 中,就在容器下方,当我将 table
我想在滚动时让我的第一个单元格始终位于 tableview 的顶部。 任何帮助都是可观的。提前致谢... 最佳答案 这是为 UITableView 创建标题 View 的方法 - (UIView *)
在我的应用程序中,我点击一行,它会在其下方展开另一行。我想生成一种随机颜色,当我单击一行时,行背景会变成该颜色,而它下面的展开行会变成相同的颜色。如何让行生成相同的随机颜色? 我创建了一个函数来生成随
我正在为这个问题苦苦挣扎,所以我需要你的帮助。基本上我已经编写了一个复杂的 TableView Controller (使用 NSFetchedResults 协议(protocol)等)并且已经在我
我正在使用 JavaFx 2.2。我遇到了一个问题,我无法在 TableView 列中放置不同的组件。例如我有两列 1) 回答 2) 答案类型 如果 AnswerType 包含“Multiple Ch
试图弄清楚如何在 javafx 2 中禁用表列的重新排序? 最佳答案 这是解决方案: tblView.getColumns().addListener(new ListChangeListener()
我一直在寻找有关将数据刷新到 tableview 的信息。我试图直接修改模型,但我遇到了一个错误。我修改了模型,但表格没有刷新,只有当我移动一列时,表格才会显示修改后的值。 为了给你展示一个例子(13
给定一个TableView,我需要检测单元格上的双击。 tableView.setOnMouseClicked(new EventHandler() { @Override publi
我成功创建了一个 TableView,其中将特定列分配给了数据模型类。该程序可以将 csv 文件解析为其中并在表中正确显示所有内容。在此阶段,滚动不是问题。 然后我想选择特定行并将它们发送到另一个表。
我尝试了所有方法来用数据填充 TableView。下一个代码在表中插入一个新行,但数据没有出现在表中。我试图为此找到解释,但没有成功。 请帮忙。我不知道怎么了。 在 controller.java 中
我尝试了所有方法来用数据填充 TableView。下一个代码在表中插入一个新行,但数据没有出现在表中。我试图为此找到解释,但没有成功。 请帮忙。我不知道怎么了。 在 controller.java 中
我有一个通过 Tableview 显示玩家的应用程序。用户可以“添加”一个新玩家并输入他的姓名、高度、体重、图片等...保存后将被添加到 Tableview 中。他们还可以点击每个玩家,然后将他们带到
对于大学,我必须编写一个小应用程序,其想法是创建一个小公式集合。这个概念是有一个类别列表,选择类别后您会收到一个公式列表。选择所需的公式后,您将看到公式计算器的 View 。 我正在努力获得第一个UI
如果我只加载一个 TableView ,我的 View 中必须有两个 TableView ,它工作正常。但是当我尝试使用下面的方法加载两个表格 View 时,它给出了以下异常。 未捕获异常“NSRan
我是 JavaFx 的新手,我正在尝试创建一个 TableView ,而 fxml 是使用场景生成器创建的。如果我运行该程序,该表不会获取值。我发现这个问题在某种程度上符合我的要求( javaFX 2
是否可以对 tableView 进行反向排序?我搜索了很多解决方案,但没有任何效果。 效果就像whatsapp聊天。 一个普通的tableView是: ---------- label 1 -----
我有一个有趣的问题。我有两个 TableView ,一个在另一个里面。我有一个结构,我想用它来将数据添加到我的 TableView 中。该结构有 2 个字符串项和另一个具有 3 个字符串项的结构的数组
我正在使用的方法 func tableView(tableView: UITableView, editActionsForRowAtIndexPath indexPath: NSIndexPath
我是一名优秀的程序员,十分优秀!