我使用Xcode 10和Swift 4.2
在UIViewController的viewDidload()中,我声明了一个观察者:
override func viewDidLoad() {
super.viewDidLoad()
NotificationCenter.default.addObserver(self, selector: #selector(OtherFunctionsViewController.dataImportExportFunc), name: .ImportExportdata, object: nil)
}
从网络上,我收到一条消息(基于.ImportExportdata名称),该消息将名为ProgressLevel的浮点值从0.0增加到1.0
我已声明IOS跟随该值,并且它可以工作。它将正确打印将要更新的值
@IBOutlet weak var OtherFuncProgressView: UIProgressView!
var ProgressLevel : Float = 0.0 {
willSet // "name" is ABOUT TO CHANGE
{
print("ProgressLevel WILL be set...")
print("from current value: \(ProgressLevel)")
print("to new value: \(newValue).\n")
DispatchQueue.global(qos: DispatchQoS.QoSClass.userInteractive).async
{
DispatchQueue.main.async
{
print("dispatch queue main")
self.OtherFuncProgressView.setProgress(Float(self.ProgressLevel), animated: true)
self.OtherFuncProgressView.setNeedsDisplay()
}
}
}
}
ProgressLevel已正确打印,但progressView从未在屏幕上更新。
感谢您的回答
我根据您的建议更改了代码,如下所示:
var ProgressLevel : Float = 0.0
{
willSet // "name" is ABOUT TO CHANGE
{
print("ProgressLevel WILL be set...")
print("from current value: \(ProgressLevel)")
print("to new value: \(newValue).\n")
// DispatchQueue.global(qos: DispatchQoS.QoSClass.userInteractive).async
// {
DispatchQueue.main.async
{
print("dispatch queue main value \(newValue)")
// self.OtherFuncProgressView.setProgress(Float(self.ProgressLevel), animated: true)
self.OtherFuncProgressView.setProgress(Float(newValue), animated: true)
self.OtherFuncProgressView.setNeedsDisplay()
}
// }
}
}
我得到了: ProcessImportFile:文件:/// Users / guydesbief / Library / Developer / CoreSimulator / Devices / 17DA59AA-430F-4395-B2F3-FF2A81EEB429 / data / Containers / Data / Application / 91B3BA10-45C1-4090-A401-5CDA03EED8C8 / tmp / 2019 -2-21_2018-2-19_Mois.csv 2019-02-21 11:18:22.755903 + 0100 SolarPanelSurveyIos [85928:4363118] razImport完成 将设置ProgressLevel ... 从当前值:0.0 更改为新值:0.0。
2019-02-21 11:18:22.758389 + 0100 SolarPanelSurveyIos [85928:4363118]统计WindowController文件流正常 2019-02-21 11:18:22.760550 + 0100 SolarPanelSurveyIos [85928:4363118]没有缓冲! 调度队列主值0.0 2019-02-21 11:18:22.760800 + 0100 SolarPanelSurveyIos [85928:4363118]统计WindowController没有从文件中读取更多数据! 2019-02-21 11:18:22.761242 + 0100 SolarPanelSurveyIos [85928:4363118]字段标题:导入记录以结尾 char Nbfields = 4,当前记录:0 2019-02-21 11:18:22.761342 + 0100 SolarPanelSurveyIos [85928:4363118]导入结束40条记录,38条最大记录
ProgressLevel将被设置... 从当前值:0.0 更改为新值:0.05263158。
ProgressLevel将被设置... 从当前值:0.05263158 更改为新值:0.13157895。
ProgressLevel将被设置... 从当前值:0.13157895 更改为新值:0.21052632。
ProgressLevel将被设置... 从当前值:0.21052632 更改为新值:0.28947368。
ProgressLevel将被设置... 从目前的价值:0.28947368 更改为新值:0.36842105。
ProgressLevel将被设置... 从当前值:0.36842105 更改为新值:0.4473684。
ProgressLevel将被设置... 从目前的价值:0.4473684 更改为新值:0.5263158。
ProgressLevel将被设置... 从当前值:0.5263158 更改为新值:0.6052632。
ProgressLevel将被设置... 从当前值:0.6052632 更改为新值:0.68421054。
ProgressLevel将被设置... 从当前值:0.68421054 更改为新值:0.7631579。
ProgressLevel将被设置... 从目前的价值:0.7631579 更改为新值:0.84210527。
ProgressLevel将被设置... 从当前值:0.84210527 更改为新值:0.92105263。
ProgressLevel将被设置... 从当前值:0.92105263 更改为新值:1.0。
2019-02-21 11:18:23.631275 + 0100 SolarPanelSurveyIos [85928:4363118]执行时间:871867
dataImportExportFunc没有更多数据记录数量:0 / 39.000000 execTime:0.8719
调度队列主值0.05263158
调度队列主值0.13157895
调度队列主值0.21052632
调度队列主值0.28947368
调度队列主值0.36842105
调度队列主值0.4473684
调度队列主值0.5263158
调度队列主值0.6052632
调度队列主值0.68421054
调度队列主值0.7631579
调度队列主值0.84210527
调度队列主值0.92105263
调度队列主值1.0
调度队列仅在处理结束时才清空,我想实时清空它 欢迎任何建议
答案 0 :(得分:0)
willSet
在值更新之前被调用,因此最好在闭包内部使用newValue
:
var progressLevel: Float = 0.0 {
// "name" is ABOUT TO CHANGE
willSet {
print("ProgressLevel WILL be set...")
print("from current value: \(progressLevel)")
print("to new value: \(newValue).\n")
DispatchQueue.main.async {
print("dispatch queue main")
self.OtherFuncProgressView.setProgress(Float(newValue, animated: true)
self.OtherFuncProgressView.setNeedsDisplay()
}
}
}