Ich experimentiere mit Multipeer Connectivity Framework in iOS. Ich möchte eine einfache App erstellen, die das Gerät ankündigt und nach anderen Geräten sucht. Hier ist mein Code:Problem mit Multipeer Connectivity Framework in iOS
class ViewController: UIViewController {
static let serviceType = "mult-demo"
let localPeerID = MCPeerID(displayName: UIDevice.currentDevice().name)
func startAdvertising() {
let advertiser = MCNearbyServiceAdvertiser(peer: localPeerID, discoveryInfo: nil, serviceType: ViewController.serviceType)
advertiser.delegate = self
advertiser.startAdvertisingPeer()
print("advertising")
}
func startBrowsing() {
let browser = MCNearbyServiceBrowser(peer: localPeerID, serviceType: ViewController.serviceType)
browser.delegate = self
browser.startBrowsingForPeers()
print("browsing")
}
override func viewDidLoad() {
super.viewDidLoad()
startAdvertising()
startBrowsing()
}
}
extension ViewController : MCNearbyServiceAdvertiserDelegate, MCNearbyServiceBrowserDelegate {
func advertiser(advertiser: MCNearbyServiceAdvertiser, didReceiveInvitationFromPeer peerID: MCPeerID, withContext context: NSData?, invitationHandler: (Bool, MCSession) -> Void) {
print("received invitation")
}
func browser(browser: MCNearbyServiceBrowser, foundPeer peerID: MCPeerID, withDiscoveryInfo info: [String : String]?) {
print("found peer \(peerID)")
}
func browser(browser: MCNearbyServiceBrowser, lostPeer peerID: MCPeerID) {
}
}
Allerdings, wenn ich es auf zwei iPads (iOS 9), die mit dem gleichen WiFi-Netzwerk laufen sie einander nicht entdecken. Was mache ich falsch?
Sie sollten Ihre "Browser" und "Werbetreibenden" in Eigenschaften statt lokalen Variablen speichern, da sie freigegeben werden, sobald die Funktionen – Paulw11
@ Paulw11 Ich habe es behoben, aber es funktioniert immer noch nicht :( – Ruslan
@ Paulw11 Problem gelöst, Danke vielmals) – Ruslan