如何在SWIFT3 XCODE 8.2的IOS应用程序中通过Snackbar的操作显示特定视图
如何通过IOS中Snackbar的操作在SWift 3中的IOS应用程序上显示另一个视图?我尝试了以下代码(即,只要snackbar出现并点击snackbar的操作部分,就会打开如何在SWIFT3 XCODE 8.2的IOS应用程序中通过Snackbar的操作显示特定视图,ios,swift3,uiviewcontroller,xcode8,snackbar,Ios,Swift3,Uiviewcontroller,Xcode8,Snackbar,如何通过IOS中Snackbar的操作在SWift 3中的IOS应用程序上显示另一个视图?我尝试了以下代码(即,只要snackbar出现并点击snackbar的操作部分,就会打开PatientViewController的新视图,Id为PatientVC): 其中,PateintVC是id,PatientViewController是我要显示的viewController的名称。但这给了我一个错误,EncounterFilterTableViewCell没有成员navigationControl
PatientViewController
的新视图,Id为PatientVC
):
其中,PateintVC
是id,PatientViewController
是我要显示的viewController
的名称。但这给了我一个错误,EncounterFilterTableViewCell
没有成员navigationController
。一旦我在代码中输入UIViewController
以及UITableViewCell
。从类UITableViewCell
和UIviewController
的多个固有属性给出错误。
应该做些什么,以便我可以显示由ID为PatientVC的PatientViewController
表示的视图。下面是我的班级的完整代码,我有我的Snackbar代码
import UIKit
import MaterialComponents.MaterialSnackbar
class EncounterFilterTableViewCell: UITableViewCell{
@IBOutlet weak var filterCheckBox: CheckBox!
@IBOutlet weak var filterNameTextView: UITextView!
var filterIndex : [String : Int] = [
getDataFromAppLanguage("Final") + " " + getDataFromAppLanguage("Diagnosis") : 0,
getDataFromAppLanguage("Diagnosis") : 1,
getDataFromAppLanguage("Test") : 2,
getDataFromAppLanguage("Operation") : 3,
getDataFromAppLanguage("Drug") : 4,
getDataFromAppLanguage("Media") : 5,
getDataFromAppLanguage("FormsEn") : 6,
getDataFromAppLanguage("PatientEn") + " " + getDataFromAppLanguage("Status") : 7
]
override func awakeFromNib() {
super.awakeFromNib()
// Initialization code
}
@IBAction func filterBoxClicked(_ sender: AnyObject) {
EncounterFilterViewController.updateFilterStatus(filterIndex[filterNameTextView.text]!)
}
override func setSelected(_ selected: Bool, animated: Bool) {
super.setSelected(selected, animated: animated)
// Configure the view for the selected state
let message = MDCSnackbarMessage()
let action = MDCSnackbarMessageAction()
let actionhandler = {() in
let actionmessage = MDCSnackbarMessage()
actionmessage.text = "Button Click Success"
MDCSnackbarManager.show(actionmessage)
let storyboard = UIStoryboard(name: "Main", bundle: nil);
let vc = storyboard.instantiateViewController(withIdentifier: "PatientVC") as! PatientViewController;
self.navigationController?.pushViewController(vc, animated: true);
}
action.handler = actionhandler
action.title = "Done"
message.action = action
message.text = "Welcome"
MDCSnackbarManager.show(message)
}
}
更改自定义单元格以使其正常工作-
override init(style: UITableViewCellStyle, reuseIdentifier: String?) {
super.init(style: style, reuseIdentifier: reuseIdentifier)
let componentFrame = CGRect(x: 20, y: 20, width: 40, height: 30)
toggleSwitch.frame = componentFrame
toggleSwitch.addTarget(self, action: #selector(SwitchTableViewCell.switchAction), for: .valueChanged)
self.contentView.addSubview(toggleSwitch);
}
convenience init(style: UITableViewCellStyle, reuseIdentifier: String?, callingView : UIViewController) {
self.init(style: style, reuseIdentifier: reuseIdentifier)
callingViewController = callingView
}
override func setSelected(_ selected: Bool, animated: Bool) {
let message = MDCSnackbarMessage()
message.text = "The groundhog (Marmota monax) is also known as a woodchuck or whistlepig."
let action = MDCSnackbarMessageAction()
let actionHandler = {() in
let storyBoard = UIStoryboard.init(name: "Main", bundle: nil)
let vc = storyBoard.instantiateViewController(withIdentifier: "DetailView")
self.callingViewController?.navigationController?.pushViewController(vc, animated: true)
}
action.handler = actionHandler
action.title = "OK"
message.action = action
MDCSnackbarManager.show(message)
}
在ViewController中,按如下方式初始化单元格-
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
var cell : SwitchTableViewCell? = tableView.dequeueReusableCell(withIdentifier: "TestIdentifier") as? SwitchTableViewCell
if(cell == nil)
{
cell = SwitchTableViewCell(style: .default, reuseIdentifier: "TestIdentifier", callingView : self)
}
cell?.toggleSwitch.isOn = myData1[indexPath.row];
return cell!;
}
现在问题解决了。而不是在单元格的setSelected方法中使用SNACKBARD代码。将以下代码添加到该特定单元格的表视图控制器的didSelect方法中。
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
var cell : SwitchTableViewCell? = tableView.dequeueReusableCell(withIdentifier: "TestIdentifier") as? SwitchTableViewCell
if(cell == nil)
{
cell = SwitchTableViewCell(style: .default, reuseIdentifier: "TestIdentifier", callingView : self)
}
cell?.toggleSwitch.isOn = myData1[indexPath.row];
return cell!;
}