0

나는이 일을 얼마 동안 해왔다. (주) 발신자와 수신자 모두에서 피어 투 피어 연결에 % 완료를 나타내는 레이블이있는 진행률 또는 활동 표시기를 추가 할 위치와 방법을 보여줄 수 있습니까?멀티 페어 연결성 진행률 표시 줄이있는 피어 투 피어 연결.

import UIKit 
import MultipeerConnectivity 



class ViewController: UIViewController, MCSessionDelegate, MCBrowserViewControllerDelegate, UINavigationControllerDelegate , UIImagePickerControllerDelegate{ 



//MARK: - Variables 
var myDictionary:NSDictionary = [:] 

//Variables for Peer to Peer. 
var browser : MCBrowserViewController! 
var assistant : MCAdvertiserAssistant! 
var session : MCSession! 
var peerID : MCPeerID! 

//Variables for Peer to Peer. 
let imagePicker = UIImagePickerController() 
var imageDataVar: NSData! 



//MARK: - Labels 
@IBOutlet weak var firstNameLabel: UILabel! 
@IBOutlet weak var lastNameLabel: UILabel! 

//MARK: - TextFields 
@IBOutlet weak var fistNameTextField: UITextField! 
@IBOutlet weak var lastNameTextField: UITextField! 

//MARK: - Outlets 

@IBOutlet weak var contactImageView: UIImageView! 

//MARK: - Buttons 
@IBAction func openPortButton(_ sender: AnyObject) { 
self.present(self.browser, animated: true, completion: nil) 
} 

@IBAction func sendButton(_ sender: AnyObject) { 
    sendInfo() 
} 

@IBAction func getImage(_ sender: AnyObject) { 
    chooseImageContact() 
} 


//MARK: - ViewDidLoad 
override func viewDidLoad() { 
    super.viewDidLoad() 
    loadPeerToPeer() 
} 


//MARK: - Functions 
func sendInfo() { 
    if self.session.connectedPeers.count > 0 { 
     let firstNameVar = fistNameTextField.text! 
     let lastNameVar = lastNameTextField.text! 
      myDictionary = ["itemA" : "\(firstNameVar)", "itemB" : "\ (lastNameVar)", "itemC" : imageDataVar] 
     do { 
      let data = NSKeyedArchiver.archivedData(withRootObject: myDictionary) 
      try self.session.send(data, toPeers: self.session.connectedPeers, with: MCSessionSendDataMode.unreliable) 
     } catch let error as NSError { 
      let ac = UIAlertController(title: "Send error", message:  error.localizedDescription, preferredStyle: .alert) 
      ac.addAction(UIAlertAction(title: "OK", style: .default, handler: nil)) 
      present(ac, animated: true, completion: nil) 
     } 
    } 
} 


// Called when a peer sends an NSData to us 
func session(_ session: MCSession, didReceive data: Data, fromPeer peerID: MCPeerID) { 

// This needs to run on the main queue 
DispatchQueue.main.async { 
    self.myDictionary = NSKeyedUnarchiver.unarchiveObject(with: data) as! NSDictionary 

    self.firstNameLabel.text = self.myDictionary.value(forKey: "itemA") as? String 
    self.lastNameLabel.text  = self.myDictionary.value(forKey: "itemB") as? String 
    let image     = self.myDictionary.value(forKey: "itemC") as? NSData 
    let newContactImage:UIImage = UIImage(data: image! as Data)! 
    let smallPicture   = self.scaleContactImageWith(newContactImage, newSize: CGSize(width: 100, height: 100)) 
    var sizeOfImage:CGRect  = self.contactImageView.frame 
     sizeOfImage.size  = smallPicture.size 
    self.contactImageView.frame = sizeOfImage 
    self.contactImageView.image = smallPicture 
} 
} 


func browserViewControllerDidFinish(_ browserViewController: MCBrowserViewController) { 
    dismiss(animated: true, completion: nil) 
} 
func browserViewControllerWasCancelled(_ browserViewController: MCBrowserViewController) { 
    dismiss(animated: true, completion: nil) 
} 
func browserViewController(_ browserViewController: MCBrowserViewController, shouldPresentNearbyPeer peerID: MCPeerID, withDiscoveryInfo info: [String : String]?) -> Bool { 
    return true 
} 

func session(_ session: MCSession, peer peerID: MCPeerID, didChange state: MCSessionState) { 
    switch state { 
    case MCSessionState.connected: 
     print("Connected: \(peerID.displayName)") 
    case MCSessionState.connecting: 
     print("Connecting: \(peerID.displayName)") 
    case MCSessionState.notConnected: 
     print("Not Connected: \(peerID.displayName)") 
    } 
} 

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?) { 
} 
func session(_ session: MCSession, didReceive stream: InputStream, withName streamName: String, fromPeer peerID: MCPeerID) { 
} 

func textFieldShouldReturn(_ textField: UITextField) -> Bool { 
    textField.resignFirstResponder() 
    return true 
} 



func loadPeerToPeer(){ 
    self.peerID = MCPeerID(displayName: UIDevice.current.name) 
    self.session = MCSession(peer: peerID, securityIdentity: nil, encryptionPreference: .required) 
    self.session = MCSession(peer: self.peerID) 
    self.session.delegate = self 
    self.assistant = MCAdvertiserAssistant(serviceType:"VBC-ShareCard", discoveryInfo:nil, session:self.session) 
    self.assistant.start() 
    self.browser = MCBrowserViewController(serviceType: "VBC- ShareCard", session: self.session) 
    self.browser.delegate = self 
} 

func imagePickerControllerDidCancel(_ picker: UIImagePickerController) { 
    picker.dismiss(animated: true, completion: nil) 
} 


// Picking the image 
func chooseImageContact(){ 
    let imagePicker   = UIImagePickerController() 
     imagePicker.delegate = self 
     imagePicker.sourceType = UIImagePickerControllerSourceType.photoLibrary 
    self.present(imagePicker, animated: true, completion: nil) 
} 


//Scalling the image 
func scaleContactImageWith(_ image:UIImage, newSize:CGSize)->UIImage{ 
     UIGraphicsBeginImageContextWithOptions(newSize, false, 0.0) 
     image.draw(in: CGRect(x: 0, y: 0, width: newSize.width, height: newSize.height)) 
    let newContactImage:UIImage = UIGraphicsGetImageFromCurrentImageContext()! 
     UIGraphicsEndImageContext() 
    return newContactImage 
} 

func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : Any]) { 

    //This gets the Contact image inside the imagePickerController 
    let pickedImage:UIImage  = info[UIImagePickerControllerOriginalImage] as! UIImage 
    let smallPicture   = scaleContactImageWith(pickedImage, newSize: CGSize(width: 100, height: 100)) 
    var sizeOfImage:CGRect  = contactImageView.frame 
     sizeOfImage.size  = smallPicture.size 
     contactImageView.frame = sizeOfImage 
     picker.dismiss(animated: true, completion: nil) 
     contactImageView.image = smallPicture as UIImage 
    let test : Data    = UIImagePNGRepresentation(smallPicture)! 
     imageDataVar   = test as NSData! 
} 

} 

답변

0

내 작품.

//New Variable for spinner. 
    var spinnerOnOff = "" 

    //New Function to start, stop, hide and unhide spinner. 
    func spin(){ 
    if spinnerOnOff == "on"{ 
     activityIndicatorOutlet.isHidden = false 
     activityIndicatorOutlet.startAnimating() 
    }else{ 
     activityIndicatorOutlet.isHidden = true 
     activityIndicatorOutlet.stopAnimating() 
    } 
} 


//Updated function. (code block will ran "Quickly") 
func sendInfo() { 
    if self.session.connectedPeers.count > 0 { 
     let firstNameVar = fistNameTextField.text! 
     let lastNameVar = lastNameTextField.text! 
      myDictionary = ["itemA" : "\(firstNameVar)", "itemB" : "\  (lastNameVar)", "itemC" : imageDataVar] 
     do { 
      let data = NSKeyedArchiver.archivedData(withRootObject: myDictionary) 
      try self.session.send(data, toPeers: self.session.connectedPeers, with: MCSessionSendDataMode.unreliable) 
     } catch let error as NSError { 
      let ac = UIAlertController(title: "Send error", message:  error.localizedDescription, preferredStyle: .alert) 
      ac.addAction(UIAlertAction(title: "OK", style: .default, handler: nil)) 
      present(ac, animated: true, completion: nil) 
     } 
    } 

    //New. Stop spinner when function Executes. 
    spinnerOnOff = "off" 
    spin() 

} 

//Updated Function. 
func session(_ session: MCSession, didReceive data: Data, fromPeer peerID: MCPeerID) { 

// This needs to run on the main queue 
DispatchQueue.main.async { 
    self.myDictionary = NSKeyedUnarchiver.unarchiveObject(with: data) as! NSDictionary 

    self.firstNameLabel.text = self.myDictionary.value(forKey: "itemA") as? String 
    self.lastNameLabel.text  = self.myDictionary.value(forKey: "itemB") as? String 
    let image     = self.myDictionary.value(forKey: "itemC") as? NSData 
    let newContactImage:UIImage = UIImage(data: image! as Data)! 
    let smallPicture   = self.scaleContactImageWith(newContactImage, newSize: CGSize(width: 100, height: 100)) 
    var sizeOfImage:CGRect  = self.contactImageView.frame 
     sizeOfImage.size  = smallPicture.size 
    self.contactImageView.frame = sizeOfImage 
    self.contactImageView.image = smallPicture 

    //New. Stop spinner when data is received. 
    self.spinnerOnOff = "off" 
    self.spin() 

} 
} 
    //Updated Function 
    func session(_ session: MCSession, peer peerID: MCPeerID, didChange state: MCSessionState) { 

    switch state { 
    case MCSessionState.connected: 

     //New. Start spinner on connected phone. 
     DispatchQueue.main.async {   
     self.spinnerOnOff = "on" 
     self.spin() 
     } 

     print("Connected: \(peerID.displayName)") 
    case MCSessionState.connecting: 

     //New. Start spinner on sender phone. 
     DispatchQueue.main.async { 
     self.spinnerOnOff = "on" 
     self.spin() 
     } 

     print("Connecting: \(peerID.displayName)") 
    case MCSessionState.notConnected: 

     //New. Stop when disconnected. 
     DispatchQueue.main.async { 
     self.spinnerOnOff = "off" 
     self.spin() 
     } 

     print("Not Connected: \(peerID.displayName)") 
    } 
} 
0

구현 한 MCSessionDelegate 기능을 사용해야합니다.

func session(MCSession, didStartReceivingResourceWithName: String, fromPeer: MCPeerID, with: Progress) 

진행률 개체를 사용하여 전송을 취소하거나 진행 상황을 확인할 수 있습니다.

데이터를 보내는 동안 데이터를 보내는 데 사용 된 함수의 완료 핸들러를 사용할 수 있습니다.

func sendResource(at resourceURL: URL, 
    withName resourceName: String, 
     toPeer peerID: MCPeerID, withCompletionHandler completionHandler: ((Error?) -> Void)? = nil) -> Progress? 

다시 진행률 개체를 사용하여 진행 상황을 추적 할 수 있습니다.

iOS 10에서 MultipeerConnectivity를 사용해 본 적이 있고 작동하는 경우 알려 주시기 바랍니다. 나는 지난 주 전체를 시도해 왔지만 그것은 동료와 연결되어 있지 않습니다. (감사합니다)

희망이 도움이됩니다.

건배

+0

_ 나는이 두 가지를 모두 구현하려고했지만 어떻게 할 수없는 것처럼 보입니다. 나는 프로그래밍에 다소 익숙하다. IOS를 사용 중입니다. 10_ – dscrown

+0

NSHipster 기사를 확인하십시오. 날짜는 약간이지만 도움이됩니다. http://nshipster.com/multipeer-connectivity/ – illuminate

+0

_didStartReceivingResourceWithName_에 브레이크 포인트를 추가했지만 절대 호출되지 않습니다. 이거 버그 야? – dscrown