Ios 未调用handleWatchKitExtensionRequest时出现问题?
我正在尝试更新我的watch kit应用程序,以添加一些从JSON文件解析的数据。我正在结合从Parse获取一些数据来完成这项工作 我得到一个错误: iPhone应用程序中的UIApplicationLegate从未在-[UIApplicationLegate应用程序:handleWatchKitExtensionRequest:reply:]中调用过reply() 我曾尝试调试Ios 未调用handleWatchKitExtensionRequest时出现问题?,ios,json,swift,parse-platform,apple-watch,Ios,Json,Swift,Parse Platform,Apple Watch,我正在尝试更新我的watch kit应用程序,以添加一些从JSON文件解析的数据。我正在结合从Parse获取一些数据来完成这项工作 我得到一个错误: iPhone应用程序中的UIApplicationLegate从未在-[UIApplicationLegate应用程序:handleWatchKitExtensionRequest:reply:]中调用过reply() 我曾尝试调试handleWatchKitExtensionRequest,但它没有崩溃,而且我添加的println由于某种原因从未
handleWatchKitExtensionRequest
,但它没有崩溃,而且我添加的println
由于某种原因从未打印
这是我的代码:
func application(application: UIApplication, handleWatchKitExtensionRequest userInfo: [NSObject : AnyObject]?, reply: (([NSObject : AnyObject]!) -> Void)!) {
var favouritesArrayDefaults: NSMutableArray! = [""]
println("1")
var keyStore = NSUbiquitousKeyValueStore()
if keyStore.arrayForKey("FavouritesList") != nil {
let tempFavourites: NSArray = keyStore.arrayForKey("FavouritesList")!
favouritesArray = tempFavourites.mutableCopy() as! NSMutableArray
} else {
println("3")
}
println(favouritesArrayDefaults)
if let pfqueryRequest: AnyObject = (userInfo as? [String: AnyObject])?["parkName"] {
println("HELLO")
let taskID = beginBackgroundUpdateTask()
//Must start and end task to allow time for query to complete
var name = ""
var waitTime = ""
var hasWaitTime = false
var fastPass = false
var heightRestriction = false
var singleRider = false
var disabledAccess = false
var mustSee = false
var fastPassTime = ""
var namesArray: [String] = []
var waitTimesArray: [String] = []
var favouritesArray: [String] = []
var hasWaitTimeArray: [Bool] = []
var fastPassArray: [Bool] = []
var heightRestrictionArray: [Bool] = []
var singleRiderArray: [Bool] = []
var disabledAccessArray: [Bool] = []
var mustSeeArray: [Bool] = []
var fastPassTimeArray: [String] = []
var query = PFQuery(className: pfqueryRequest as! String)
query.orderByAscending("Name")
var objects = query.findObjects()
if let objects = objects as? [PFObject] {
for object in objects {
name = (object.objectForKey("Name") as? String)!
waitTime = (object.objectForKey("WaitTime") as? String)!
hasWaitTime = (object.objectForKey("HasWaitTime") as? Bool)!
fastPass = (object.objectForKey("FastPass") as? Bool)!
heightRestriction = (object.objectForKey("HeightRestriction") as? Bool)!
singleRider = (object.objectForKey("SingleRider") as? Bool)!
disabledAccess = (object.objectForKey("DisabledAccess") as? Bool)!
mustSee = (object.objectForKey("MustSee") as? Bool)!
namesArray.append(name)
waitTimesArray.append(waitTime)
hasWaitTimeArray.append(hasWaitTime)
fastPassArray.append(fastPass)
heightRestrictionArray.append(heightRestriction)
singleRiderArray.append(singleRider)
disabledAccessArray.append(disabledAccess)
mustSeeArray.append(mustSee)
}
var urlString = (DataManager.sharedInstance.getParkByName(pfqueryRequest as! String)?.dataSource)!
if let url = NSURL(string: urlString) {
if let data = NSData(contentsOfURL: url, options: .allZeros, error: nil) {
let json = JSON(data: data)
for count in 0...json.count - 1 {
let rideName: JSON = json[count]["name"]
let waitTime: JSON = json[count]["waitTime"]
var fastPassTime: JSON = json[count]["fastPass"]
if find(namesArray, rideName.string!) != nil {
let index = find(namesArray, rideName.string!)
var modifiedWaitTime = "".join(waitTime.string!.componentsSeparatedByCharactersInSet(NSCharacterSet.decimalDigitCharacterSet().invertedSet))
if waitTime == "Down" || waitTime == "Closed" {
modifiedWaitTime = "Closed"
}
if fastPassTime.string == nil {
fastPassTime = "Unavailable"
} else if fastPassTime.string == "N/A" {
fastPassTime = "Expired"
}
waitTimesArray.removeAtIndex(index!)
waitTimesArray.insert(waitTime.string!, atIndex: index!)
fastPassTimeArray.removeAtIndex(index!)
fastPassTimeArray.insert(fastPassTime.string!, atIndex: index!)
}
}
}
}
for favourite in favouritesArrayDefaults {
favouritesArray.append(favourite as! String)
}
println(fastPassTimeArray)
reply(["success": true, "name": namesArray, "waitTime": waitTimesArray, "hasWaitTime": hasWaitTimeArray, "favourites": favouritesArray, "fastPass": fastPassArray, "heightRestriction": heightRestrictionArray, "singleRider": singleRiderArray, "disabledAccess": disabledAccessArray, "mustSee": mustSeeArray, "fastPassTime": fastPassTimeArray])
endBackgroundUpdateTask(taskID)
}
} else if let pfqueryRequest: AnyObject = (userInfo as? [String: AnyObject])?["parkNameSubmit"] {
let taskID = beginBackgroundUpdateTask()
var query = PFQuery(className: pfqueryRequest as! String)
//query.orderByAscending("Name")
query.whereKey("Name", equalTo: userInfo!["name"]!)
query.getFirstObjectInBackgroundWithBlock {
(object: PFObject?, error: NSError?) -> Void in
if error != nil {
println("The getFirstObject request failed.")
} else {
if let obj = object {
obj.setValue(userInfo!["waitTime"], forKey: "WaitTime")
obj.saveInBackground()
}
println("Successfully retrieved the object.")
}
}
reply(["success": true, "message": "Hello!"])
endBackgroundUpdateTask(taskID)
}
}
很抱歉代码太多,但我真的不知道问题出在哪里
有人有什么想法吗?把你的
reply()。问题是在任何情况下都应该调用reply()
处理程序,但在您的示例中,如果pfqueryRequest
为nil
则永远不会调用该处理程序。序列化reply()
处理程序中的自定义对象
发生此错误的另一个原因是。如果您尝试这样做,iOS/watchOS将无法将您的对象序列化到应答的plist
文件,这就是通信的方式。由于文件序列化失败,因此从未写出该文件,WatchKit扩展认为从未调用过reply()
,因此出现错误
您必须将这些对象分解为更基本的对象类型,或者使用NSKeyedArchiver
将这些自定义对象编码为NSData
,然后在回复中发送并解码,然后使用nskeyedunachiver
将该数据解码回通信扩展端的自定义对象
立即启动后台任务以防止iOS暂停您的应用程序
此外,iOS还可以暂停应用程序的执行(即使您所做的只是验证请求或先创建变量)
发件人:
由于此方法可能在应用程序处于后台时调用,因此在实现开始时调用beginBackgroundTaskWithName:expirationHandler:方法并在处理回复并执行回复块后调用endBackgroundTask:方法。启动后台任务可确保应用程序在有机会发送回复之前不会被挂起
iOS应用程序的Xcode控制台输出在连接到WatchKit扩展进程时不可用
在WatchKit扩展上调试时,将不会显示从iOS应用程序写入控制台的print()
、println()
、NSLog()
或类似方法
解决这个问题的一种方法是在模拟器中运行WatchKit应用程序,然后在iOS模拟器中打开iOS应用程序。完成后,返回Xcode并转到Debug>attachtoprocess
,在列表中找到iOS应用程序的进程。Xcode现在应该显示来自两个进程的控制台输出(但是您需要使用Xcode调试/控制台区域顶部的控件在它们之间切换)
在Watch Connectivity Framework中使用更新的WatchKit API
我强烈推荐使用较新的而不是较旧的+[WKInterfaceController openParentApplication:reply://code>。苹果已经做了大量工作来改进watchOS应用程序与其主机iOS应用程序之间共享数据的初始机制
我个人在使用原始API时遇到了很多问题,当我放弃对watchOS 1.x的支持并转到watchOS 2.x及更高版本时,所有问题都消失了。我在不相关的代码中有另一个回复。我将更新我的代码以进行演示。我猜你犯了一个错误?你应该对else
块有一个关闭条件,不是吗telse if
one。我现在添加了一个else
,但这没有什么区别。我应该补充一点,我有相同的代码(减去JSON的东西),它以前工作得很好。好吧,如果你调用reply()
在处理程序的最后一行-它应该可以工作。我在处理这个处理程序时从来没有遇到过任何问题。是的,它在最后一行被调用。这个问题解决了吗?