2016-10-03 128 views
1

我使用Xcode 8爲iPhone構建應用程序。
我的簡單應用程序有一個按鈕。當用戶點擊這個按鈕時,messageComposeViewController被調用並且填充電話號碼和消息內容。
當我單擊發送按鈕時,郵件成功通過。

問題是MessageComposeViewController只顯示一次。
發送信息後,當我點擊按鈕調用它時,黑色屏幕顯示出來而不是消息編輯器。

我的代碼附在下面。
我很感激任何幫助。MessageComposeViewController只顯示一次

import UIKit 
import MessageUI 

class ViewController: UIViewController, MFMessageComposeViewControllerDelegate { 

    let msg = MFMessageComposeViewController() 

    @IBOutlet weak var coordinate_label: UILabel! 

    override func viewDidLoad() { 
     super.viewDidLoad() 
    } 

    override func didReceiveMemoryWarning() { 
     super.didReceiveMemoryWarning() 
    } 


    @IBAction func sendMessage(_ sender: AnyObject) { 

     self.msg.body = "Message Content" 
     self.msg.recipients = ["xxx-xxx-xxxx"] 
     self.msg.messageComposeDelegate = self 

     self.present(msg, animated: false, completion: nil) 
    } 

    func messageComposeViewController(_ controller: MFMessageComposeViewController, didFinishWith result: MessageComposeResult) { 
     switch result.rawValue { 
      case MessageComposeResult.cancelled.rawValue: 
       dismiss(animated: true, completion: nil) 
      case MessageComposeResult.failed.rawValue: 
       dismiss(animated: true, completion: nil) 
      case MessageComposeResult.sent.rawValue: 
       dismiss(animated: true, completion: nil) 
      default: 
       break; 
     } 
    } 
} 
+0

你的任務完成了我的代碼,然後批准我的答案。謝謝 –

回答

3

試試這個代碼

import Foundation 
import MessageUI 

let textMessageRecipients = ["1-800-867-5309"] // for pre-populating the recipients list (optional, depending on your needs) 

class MessageComposer: NSObject, MFMessageComposeViewControllerDelegate { 

    // A wrapper function to indicate whether or not a text message can be sent from the user's device 
    func canSendText() -> Bool { 
     return MFMessageComposeViewController.canSendText() 
    } 

    // Configures and returns a MFMessageComposeViewController instance 
    func configuredMessageComposeViewController() -> MFMessageComposeViewController { 
     let messageComposeVC = MFMessageComposeViewController() 
     messageComposeVC.messageComposeDelegate = self // Make sure to set this property to self, so that the controller can be dismissed! 
     messageComposeVC.recipients = textMessageRecipients 
     messageComposeVC.body = "Hey friend - Just sending a text message in-app using Swift!" 
     return messageComposeVC 
    } 

    // MFMessageComposeViewControllerDelegate callback - dismisses the view controller when the user is finished with it 
    func messageComposeViewController(controller: MFMessageComposeViewController!, didFinishWithResult result: MessageComposeResult) { 
     controller.dismissViewControllerAnimated(true, completion: nil) 
    } 
} 

注意,最新的語法2017年..

func messageComposeViewController(_ controller: MFMessageComposeViewController, didFinishWith result: MessageComposeResult) { 
    controller.dismiss(animated: true, completion: nil) 
} 

在你的viewController ..

import UIKit 

class ViewController: UIViewController { 
    // Create a MessageComposer 
    let messageComposer = MessageComposer() 

    @IBAction func sendTextMessageButtonTapped(sender: UIButton) { 
     // Make sure the device can send text messages 
     if (messageComposer.canSendText()) { 
      // Obtain a configured MFMessageComposeViewController 
      let messageComposeVC = messageComposer.configuredMessageComposeViewController() 

      // Present the configured MFMessageComposeViewController instance 
      // Note that the dismissal of the VC will be handled by the messageComposer instance, 
      // since it implements the appropriate delegate call-back 
      presentViewController(messageComposeVC, animated: true, completion: nil) 
     } else { 
      // Let the user know if his/her device isn't able to send text messages 
      let errorAlert = UIAlertView(title: "Cannot Send Text Message", message: "Your device is not able to send text messages.", delegate: self, cancelButtonTitle: "OK") 
      errorAlert.show() 
     } 
    } 
} 
+2

嗨Himanshu。謝謝,我剛剛編輯了最新的Swift語法(像平常一樣隨意放鬆,編輯等) – Fattie