那曲檬骨新材料有限公司

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

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

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%

      發表評論

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

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

      ?
      什么是百家乐的大路| 易赢百家乐软件| 大发888老虎机| 百家乐平注法技巧| 百家乐官网1元投注| 赌场里的美少年| 免费百家乐过滤工具| 金三角百家乐官网的玩法技巧和规则| 亚东县| 菲律宾太阳城网| MG百家乐大转轮| 百家乐官网牌盒| 百家乐官网马渚| 广州市| 大发888 894| 菲律宾太阳城官方网| 申博太阳城官网| 澳门百家乐如何算| 百家乐光纤洗牌机如何做弊| 百家乐官网长龙技巧| 百家乐官网筹码币方形| 百家乐官网筹码素材| 澳门威尼斯人娱乐| 做生意风水问题| 赌场百家乐官网的玩法技巧和规则| 澳门百家乐官网赢钱秘诀| 江油市| 九龙城区| 晓游棋牌官网| 百家乐官网真人游戏赌场娱乐网规则| 百家乐官网澳门有网站吗| 大发888官方df888gfxzylc8| 战神百家乐娱乐城| 百家乐庄闲和赢率| 玩百家乐凤凰娱乐城| 百家乐现金平台排名| 百家乐官网游戏| 24山风水水口| 赌百家乐心里技巧| pc百家乐官网模拟游戏| 大发888娱乐场下载iypuqrd|