- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在使用 WCSession 的 tranferUserInfo
在 watch 和 iOS 应用程序之间发送数据,以获取当任一产品处于后台时需要处理的信息。这在模拟器上 100% 的时间都有效,但在实际设备上却永远无效。
通过使用断点,我发现 func session(session: WCSession, didReceiveUserInfo userInfo: [String : AnyObject])
永远不会在后台调用,但是当应用程序被带到前景。显然 session.transferUserInfo(data)
正在被调用,但在后台状态下未被接收。再次运行完全相同的代码,但在模拟器上运行完美。
我运行的是 iOS 9.3.2 和 Watch OS 2.2.1。显然,此功能旨在处理后台状态下的通信,因此我相信模拟器正在按预期工作。我尝试将发送方和接收方包装在 dispatch_async(dispatch_get_main_queue(), {
block 中,但无济于事。
关于 transferUerInfo
我错过了什么,它似乎无法正常处理背景状态?
仅供引用 - 在 didRecieveUserInfo
开头设置的断点在应用进入前台之前永远不会命中。
func transferInfo(data:[String: AnyObject])
{
dispatch_async(dispatch_get_main_queue(), {
if #available(watchOSApplicationExtension 2.2, *)
{
if #available(iOS 9.3, *)
{
if self.session.activationState == .Activated
{
self.session.transferUserInfo(data)
}
else
{
NSNotificationCenter.defaultCenter().postNotificationName("alertError", object: self, userInfo: ["error":"Failed to transfer"])
}
}
else
{
self.session.transferUserInfo(data)
}
}
else
{
self.session.transferUserInfo(data)
}
})
}
func session(session: WCSession, didReceiveUserInfo userInfo: [String : AnyObject])
{
dispatch_async(dispatch_get_main_queue(), {
for delegate in self.watchCommsProtocols
{
delegate.watchCommsDidUpdateInfo!(userInfo)
}
})
}
最佳答案
我刚刚观看了 WWDC 2015 的 Watch Connectivity session 。似乎 transferUserInfo
在应用程序处于前台之前无法被 iOS 接收。这当然是我在实际设备上看到的。那么这里的问题,以及让我失望的是,在撰写本文时,模拟器确实在后台接收到这些消息。这不是正确的行为,因此应被视为模拟器功能中的错误。
出于我的目的,当 iOS 处于后台时,我应该能够使用 sendMessage
从 watch 到 iOS。然而,反过来就不一样了。要从 iOS 向 watch 使用 sendMessage
, watch 必须位于前台。
关于ios - WCSession transferUserInfo 仅适用于前台,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38091088/
我的 iOS 应用程序通过 WatchConnectivity 框架发送及时的信息。接收方实现 WCSession 的委托(delegate)。 我有 2 个 interfaceControllers
当我调用 session.activateSession() 方法时,我遇到了 WatchKit 连接 session 无法激活的问题。这是我用来设置 session 的代码。 if (WCSessi
我有一个带有“今日”扩展程序的应用程序和一个 watch 应用程序。从主应用程序 WCSession 工作正常,数据传输到 watch 并正确接收,但是当我尝试通过今日小部件中的 WCSession
Apple 文档显示: PayloadTooLarge - An error indicating that the item being sent exceeds the maximum size
有没有办法取消WCSession的sendMessage(_:replyHandler:errorHandler:)方法发送的消息? 来自documentation : Messages are qu
在我的应用程序中,我必须将信息从 watch InterfaceController 发送到手机 HomeViewController。但是,当我运行我的代码时,这些信息只有效一次。为了让它再次运行,
我在从父设备向 Apple Watch 发送文件时遇到问题。有时文件会通过并被完全解析。其他时候,它开始文件传输,但它失败了,甚至从未在 Apple Watch 上调用 session:(WCSess
当我尝试发送内容时收到 WCSession 尚未激活错误。而且我不知道我做错了什么。我已经测试了一些“必须”工作的预制解决方案。但它在我的模拟器和物理设备上不起作用。 部分代码: 我的应用委托(del
在 iOS 和 iWatch 设备之间建立连接,xCode 写入 [WC] WCSession 对应应用程序未安装。 经过大量研究,我找到了一个解决方案,也许它会对某人有所帮助。 - Check yo
委托(delegate)函数返回之前是否需要调用replyHandler?我需要进行几次 Web 服务 API 调用才能回复,以下实现正确吗? func session(_ session: WCSe
根据我的经验,我注意到为 WatchKit 应用程序创建两个或多个界面 Controller (IC) 时,AppleWatch 在用户滑动到它之前开始加载下一个界面。这可能对系统性能很有用,但后来有
我正在尝试向我的应用程序添加简单的WatchOS 2.0功能,以允许在手表上触发简单的操作并在iPhone上的主应用程序中产生效果。所有这些取决于使用WCSession的sendMessage方法从手
我正在从 iPhone 向 Watch (WatchOS2) 发送一条消息,其中 iPhone 上运行着一个内部计时器。每隔 30 秒,我就会从 iPhone 发送消息以供观看。不幸的是,发送消息仅在
我正在开发一个带有 watch 扩展 (watchOS 2) 的 iPhone 应用程序 (iOS 9 beta),并使用 WCSession 将数据从 watch 传递到手机。 我有 2 个使用 W
我正在使用 WCSession 的 tranferUserInfo 在 watch 和 iOS 应用程序之间发送数据,以获取当任一产品处于后台时需要处理的信息。这在模拟器上 100% 的时间都有效,但
Apple 是否表明对于 sendMessage(_ message: [String : AnyObject]...) 从 watch 到 iPhone 的传输时间的实际预期是多少?对于单个字符串的
我在使用 WCSession activateSession 时遇到了问题。我在我的 viewDidLoad 方法中添加了这段代码,它在调用 activateSession 时崩溃了。 sendMes
我正在使用 WatchKit 2.0,我注意到一个非常奇怪的行为。如果我使用我的 watch 应用程序超过 5 分钟,我开始从 WCSession sendMessage 调用中收到超时错误,该调用之
我正在使用 Xamarin 开发 Apple Watch 应用。我正在尝试使用 SendMessage 函数从我的 watch 向 iPhone 发送消息。当我这样做时,我收到了 out 错误消息 p
我想知道什么时候会在 watch 和 iOS 设备上的 WCSession 对象上调用 activateSession()。 在文档中它说: 在调用任何与 session 相关的方法之前,始终分配一个
我是一名优秀的程序员,十分优秀!