Я работаю над приложением, в котором есть два контроллера представления, использующих MP C, один для рекламы в качестве хоста и один для выбора других пользователей для подключения. Как только пользователь подключения готов продолжить, он говорит рекламодателю и ему самому перейти к другому контроллеру представления. Однако, хотя я использую методы, аналогичные первым двум контроллерам представления, которые работали успешно, я не могу успешно отправлять или получать данные в этом новом контроллере представления, и я не получил сообщений об ошибках. Цель состоит в том, чтобы одно устройство могло делиться изображением с другими подключенными устройствами, все из которых будут на этом контроллере представления. Вот что у меня есть
import UIKit
import MultipeerConnectivity
class VotingViewController: UIViewController {
@IBOutlet weak var imageView: UIImageView!
var mcAdvertiserAssistant: MCAdvertiserAssistant!
var peerID: MCPeerID = MCPeerID(displayName: UIDevice.current.name)
var mcSession: MCSession!
var stream: InputStream?
override func viewDidLoad() {
super.viewDidLoad()
mcSession = MCSession(peer: peerID, securityIdentity: nil, encryptionPreference: .required)
mcSession.delegate = self
}
@IBAction func share(_ sender: Any) {
guard let imageToSend = UIImage(named: "Car.png") else { return }
sendImage(img: imageToSend)
}
func sendImage(img: UIImage) {
guard let mcSession = mcSession else { return }
if mcSession.connectedPeers.count > 0 {
if let imageData = img.pngData() {
//here's what to do
do {
try mcSession.send(imageData, toPeers: mcSession.connectedPeers, with: .reliable)
} catch let error as NSError {
let ac = UIAlertController(title: "Send error", message: error.localizedDescription, preferredStyle: .alert)
ac.addAction(UIAlertAction(title: "OK", style: .default))
present(ac, animated: true)
}
}
}
}
}
// MARK: MCSessionDelegate
extension VotingViewController: MCSessionDelegate {
func session(_ session: MCSession, peer peerID: MCPeerID, didChange state: MCSessionState) {
switch state {
case .connected:
DispatchQueue.main.async{
}
case .connecting:
DispatchQueue.main.async{
}
print("Connecting: \(peerID.displayName)")
case .notConnected:
DispatchQueue.main.async{
}
print("Not Connected: \(peerID.displayName)")
@unknown default:
print("Unknown state received: \(peerID.displayName)")
}
}
func session(_ session: MCSession, didReceive data: Data, fromPeer peerID: MCPeerID) {
DispatchQueue.main.async { [weak self] in
if let image = UIImage(data: data) {
self?.imageView.image = image
}
}
}
func session(_ session: MCSession, didReceive stream: InputStream, withName streamName: String, fromPeer peerID: MCPeerID) {
print("Received stream")
stream.delegate = self
stream.schedule(in: RunLoop.main, forMode:RunLoop.Mode.common)
stream.open()
}
func session(_ session: MCSession, didStartReceivingResourceWithName resourceName: String, fromPeer peerID: MCPeerID, with progress: Progress) {}
func session(_ session: MCSession, didFinishReceivingResourceWithName resourceName: String, fromPeer peerID: MCPeerID, at localURL: URL?, withError error: Error?) {}
}
// MARK: MCAdvertiserAssistantDelegate
extension VotingViewController: MCAdvertiserAssistantDelegate {}
// MARK: StreamDelegate
extension VotingViewController: StreamDelegate {
func stream(_ aStream: Stream, handle eventCode: Stream.Event) {
}
}
Я все еще знакомлюсь с MP C, так что это, вероятно, глупая ошибка. Заранее спасибо.