質問するログイン新規登録

Q&A

0回答

1559閲覧

swiftUIでskaywayを使う。UIViewとして実装したい。

xiongjie

総合スコア4

WebRTC

WebRTC(Web Real-Time Communication)とは、プラグイン無しでウェブブラウザ間の音声通話・ビデオチャットなどリアルタイムコミュニケーションができるオープンフレームワークです。W3CがAPIレベルで、IETFがプロトコルレベルでそれぞれ標準化が進められています。

0グッド

0クリップ

投稿2019/10/04 12:01

0

0

前提・実現したいこと

SwiftUIでskywayを使用したいと考えています。
skyway自体はUIViewで実装し、 UIViewRepresentableでラップしてswiftUIのViewとして行けるかと思ったのですが、詰まっています。iPadの実機で実行した時のエラーが以下です。
それからそもそもこのアプローチでいいのかも教えていただきたいです。まだswiftUIでskywayは使えないはず等の情報あれば教えてください。swiftUIの一部の画面でUIViewを使うアプローチに他のものがあればそれもご教授いただきたいです。
swiftUIでwebRTCを使ったことがある人も知見をくださったら幸いです。よろしくお願いします。

発生している問題・エラーメッセージ

Terminating app due to uncaught exception 'NSInternalInconsistencyException', reason: 'Modifications to the layout engine must not be performed from a background thread after it has been accessed from the main thread.'

該当のソースコード

swiftUI

1import SwiftUI 2import SkyWay 3import UIKit 4 5struct ContentView: View { 6 @State var video = SKWVideo() 7 8 var body: some View { 9 VideoView(localStreamView: $video) 10 } 11} 12 13struct VideoView: UIViewRepresentable { 14 @Binding var localStreamView: SKWVideo 15 16 func makeUIView(context: Context) -> SKWVideo { 17 let option: SKWPeerOption = SKWPeerOption.init() 18 option.key = "xxxx" 19 option.domain = "localhost" 20 let peer = SKWPeer(options: option) 21 SKWNavigator.initialize(peer!) 22 let constraints: SKWMediaConstraints = SKWMediaConstraints() 23 let localStream = SKWNavigator.getUserMedia(constraints) 24 localStream?.addVideoRenderer(localStreamView, track: 0) 25 return localStreamView 26 } 27 28 func updateUIView(_ uiView: SKWVideo, context: Context) { 29 // 30 } 31} 32

補足情報(FW/ツールのバージョンなど)

iOS 13.0
xcode 11.0

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.29%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問