質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
85.48%
iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

iPhone

iPhoneとは、アップル社が開発・販売しているスマートフォンです。 同社のデジタルオーディオプレーヤーiPodの機能、電話機能、インターネットやメールなどのWeb通信機能の3つをドッキングした機器です。

Q&A

解決済

1回答

2468閲覧

【SwiftUI】AVKitでフルスクリーン動画再生したいです。お力添えください。

taichi_dm_

総合スコア60

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

iPhone

iPhoneとは、アップル社が開発・販売しているスマートフォンです。 同社のデジタルオーディオプレーヤーiPodの機能、電話機能、インターネットやメールなどのWeb通信機能の3つをドッキングした機器です。

0グッド

1クリップ

投稿2020/04/24 17:56

編集2020/05/01 02:45

【環境】
・Xcode11.4
・Swift

動画再生アプリを作りたいです。
以下のスクショ・ソースコードのように、動画をそのまま再生する方法はわかりました。
イメージ説明

Swift

1 2import SwiftUI 3import AVKit 4 5struct ContentView : View { 6 var body: some View { 7 PlayerView() 8 } 9} 10struct PlayerView: UIViewRepresentable { 11 12 func updateUIView(_ uiView: UIView, context: UIViewRepresentableContext<PlayerView>) { 13 } 14 func makeUIView(context: Context) -> UIView { 15 return PlayerUIView(frame: .zero) 16 } 17 18} 19class PlayerUIView: UIView { 20 private let playerLayer = AVPlayerLayer() 21 22 override init(frame: CGRect) { 23 super.init(frame: frame) 24 25 let url = URL(string: "https://bitdash-a.akamaihd.net/content/sintel/hls/playlist.m3u8")! 26 let player = AVPlayer(url: url) 27 player.play() 28 player.rate = 1.0 29 30 playerLayer.player = player 31 playerLayer.videoGravity = .resizeAspect 32 layer.addSublayer(playerLayer) 33 } 34 required init?(coder: NSCoder) { 35 fatalError("init(coder:) has not been implemented") 36 } 37 override func layoutSubviews() { 38 super.layoutSubviews() 39 playerLayer.frame = bounds 40 } 41}

しかし、下の画面のようにフルスクリーン再生をする方法が見つかりませんでした。
イメージ説明
どうすれば良いでしょうか。また、どんな検索ワードで調べれば良いでしょうか?
・Swift 動画 フルスクリーン
・Swift AVKit FullScreen
・SwiftUI AVKit FullScreen
などで調べましたが、自力では有力な情報を見つけられておりません。

よろしくお願いいたします。


追記
イメージ説明
イメージ説明
イメージとしては、このコントローラーが使えるフルスクリーン再生がしたいです。

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

SwiftUIは詳しくないのですが、「videoGravity」を".resizeAspect"としている以上、Portrait(縦画面表示)では貼っていただいているスクショが正しい動きではないでしょうか。

Swift

1playerLayer.videoGravity = .resizeAspect // <-こちら 2

全画面にするのであれば、DeviceOrientation(Landscape Leftなど)の設定を追加した上で、シミュレータを横向きにしたら表示が全画面に変わりませんでしょうか。
実際、質問者様のコードをコピペしただけで以下のように全画面表示になりました。
(求めている回答と異なっていたら申し訳ないです。。)

※検証環境
Xcode11.4.1
iOSシミュレータ13.4.1

Xcode
Simulator


5/1追記

質問に対する問題点を理解しておらず、大変失礼いたしました。。
"コントローラ表示かつFullScreen"に関しては、「AVPlayerViewController」を実装したら解決する様なのですが、いかがでしょうか。

参考URL

上記リンク内の回答をコピペして実行した結果が以下です。
(今回も回答違ったら申し訳ないです。。)
イメージ説明

投稿2020/04/30 15:21

編集2020/05/01 04:07
tsuki01

総合スコア1751

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

taichi_dm_

2020/05/01 02:46

ご回答ありがとうございます。 説明不足でしたね... 質問を編集させていただきますので、もう一度読んでくださると幸いです。
taichi_dm_

2020/05/01 05:01

ご回答ありがとうございます。 まさにこれを求めてました! 「AVPlayerViewController」の方だったんですね。 おかげさまで期待通りの実装ができるようになりました。 ベストアンサーにさせていただきます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問