我使用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:file:/// 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文件流OK 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]字段标题:导入记录以字符结尾Nbfields = 4,当前记录:0 2019-02-21 11:18:22.761342 + 0100 SolarPanelSurveyIos [85928: 4363118]导入结束了40条记录,38条Maxrecords
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
data Import Export Func没有更多的记录数据: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
调度队列只在进程结束时清空,我想实时清空它。欢迎任何建议
在值更新之前调用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()
}
}
}