那曲檬骨新材料有限公司

您好,歡迎來電子發燒友網! ,新用戶?[免費注冊]

您的位置:電子發燒友網>源碼下載>通訊/手機編程>

ReplayKit框架入門指南

大小:0.3 MB 人氣: 2017-09-26 需要積分:1

  ReplayKit框架提供了RPScreenRecorder類以及類單例方法sharedRecorder()供您進行游戲錄制。這個實例對象負責檢查設備的記錄功能,包括啟動、停止以及丟棄記錄,并可以選擇啟動麥克風讓玩家錄制真人語音解說!

  打開從GitHub下載的初始工程中GameViewController.swift文件。在文件頂部,導入ReplayKit框架。

  import ReplayKit

  接下來,在用戶按下Start Recording按鈕時調用GameViewController類中的startRecording(_:)這個方法開始錄制。

  func startRecording(sender: UIButton) { if RPScreenRecorder.sharedRecorder().available { RPScreenRecorder.sharedRecorder().startRecordingWithMicrophoneEnabled(true, handler: { (error: NSError?) -》 Void in if error == nil { // Recording has started sender.removeTarget(self, action: “startRecording:”, forControlEvents: .TouchUpInside) sender.addTarget(self, action: “stopRecording:”, forControlEvents: .TouchUpInside) sender.setTitle(“Stop Recording”, forState: .Normal) sender.setTitleColor(UIColor.redColor(), forState: .Normal) } else { // Handle error } }) } else { // Display UI for recording being unavailable } }

  跟著代碼一步一步走。我們通過sharedRecorder()方法訪問RPScreenRecorder實例以檢查我們的設備錄制功能是否可用。如果功能可用,我們便可以通過調用startRecordingWithMicrophone(_:handler:)方法啟動一段記錄。此方法的第一個參數為BOOL類型值,表示是否開啟設備的麥克風,第二個參數則為完成后回調的代碼塊。如果出現一些錯誤,RepalyKit框架可以通過代碼塊返回給你并提示您錯誤的信息。如果一切準備就緒,我們改變按鈕的式樣告知用戶錄制已開始,再次點擊可以停止錄制。

  編譯運行你的應用程序并嘗試按下綠色按鈕,你會看到類似一團火焰的粒子效果,如果你點擊Start Recording,你會看到這樣的警告,如圖:

  ReplayKit框架入門指南

  注意,這個警告每次會在你開始錄制時出現。然而,一旦用戶選擇了其中一種偏好設置,系統會在接下來的8分鐘記住這個選擇。

  在你選擇選項之后,Start Recording按鈕變為了紅色的Stop Recording按鈕。

  停止,丟棄和編輯記錄

  現在,我們的app可以開始ReplayKit的錄制,是時候去了解在完成的時候編寫怎樣的代碼了。在GameViewController類中實現stopRecording(_:)這個方法:

  func stopRecording(sender: UIButton) { RPScreenRecorder.sharedRecorder().stopRecordingWithHandler { (previewController: RPPreviewViewController?, error: NSError?) -》 Void in if previewController != nil { let alertController = UIAlertController(title: “Recording”, message: “Do you wish to discard or view your gameplay recording?”, preferredStyle: .Alert) let discardAction = UIAlertAction(title: “Discard”, style: .Default) { (action: UIAlertAction) in RPScreenRecorder.sharedRecorder().discardRecordingWithHandler({ () -》 Void in // Executed once recording has successfully been discarded }) } let viewAction = UIAlertAction(title: “View”, style: .Default, handler: { (action: UIAlertAction) -》 Void in self.presentViewController(previewController!, animated: true, completion: nil) }) alertController.addAction(discardAction) alertController.addAction(viewAction) self.presentViewController(alertController, animated: true, completion: nil) sender.removeTarget(self, action: “stopRecording:”, forControlEvents: .TouchUpInside) sender.addTarget(self, action: “startRecording:”, forControlEvents: .TouchUpInside) sender.setTitle(“Start Recording”, forState: .Normal) sender.setTitleColor(UIColor.blueColor(), forState: .Normal) } else { // Handle error } } }

  繼續一步一步地研究這個方法的實現。我們還是用RPScreenRecorder的實例對象調用stopRecordingWithHandler(_:)這個方法,這次在回調的塊中,我們通過檢查previewController存不存在來判斷app完成錄制的成功與否。

  我們創建一個UIAlertController,它有兩個action,一個為丟棄記錄,另一個為回看記錄。選擇丟棄記錄則調用discardRecordingWithHandler(_:)這個方法。要注意的是,這個方法只能在確保錄制成功地完成后才可以調用,要是在錄制進行的時候就調用的話,雖然系統不會拋出任何錯誤,但是也不會丟棄任何記錄。

  選擇回看記錄,我們就呈現previewController視圖,它是RPPreviewController類的實例,從stopRecordingWithHandler(_:)方法回調塊中返回給我們,用來回看、編輯或分享記錄。這個previewController視圖控制器實例是唯一能夠訪問到由ReplayKit生成的視頻文件,它的職能就是負責保存/分享記錄。

  最后,別忘了恢復startRecording按鈕以便再次另一段記錄的開始!

非常好我支持^.^

(0) 0%

不好我反對

(0) 0%

      發表評論

      用戶評論
      評價:好評中評差評

      發表評論,獲取積分! 請遵守相關規定!

      ?
      百家乐官网娱乐网备用网址| 网上百家乐官网指| 百家乐娱乐网网| 澳门百家乐官网鸿福厅| 百家乐博彩优惠论坛| 百家乐论坛香港马会| 理塘县| 百家乐好多假网站| 众发国际娱乐| 百家乐是否有路子| 博盈注册| 皇冠网百家乐平台| 鸿胜娱乐城| 百家乐视频游戏中心| 88娱乐城注册| 百家乐下注几多| 石首市| 玩百家乐技巧巧| 注册百家乐官网送彩金| 威尼斯人娱乐城 老品牌值得信赖| 破解百家乐官网游戏机| 大发888真人真钱网址| 百家乐官网群1188999| 大发888手机版下载安装到手| 百家乐官网倍投软件| 澳门百家乐真人斗地主| 百家乐官网筹码防伪定制| 威尼斯人娱乐城排名| 黄金城百家乐官网手机用户| 鹿邑县| 澳门百家乐路单| 尊龙百家乐官网娱乐场开户注册| 大连娱网棋牌下载| 网上百家乐有没有假| 百家乐官网网络游戏平台| 大发888娱乐真钱游戏下载| 百家乐学院教学视频| 高级百家乐官网出千工具| 大发888有手机版本吗| 皇冠百家乐皇冠网| 太阳城百家乐官网分析解码 |