iOS視頻播放AVPlayer的視頻內(nèi)容拉伸設置

在iOS開發(fā)中遇到使用視頻播放器的案例,使用的是別人封裝好的 WMPlayer 這么一個視頻播放器,他使用的是AVPlayer這個底層的視頻框架來搭建的視頻界面,在開發(fā)時會遇到適配適配內(nèi)容比例的需求,一開始沒注意到視頻被拉伸過,后來遇到一個用豎屏錄制的視頻時才發(fā)現(xiàn)視頻被拉伸了,于是來查找相關(guān)的設置屬性。
最后查找到使用其中一個叫videoGravity 的屬性,默認設置了AVLayerVideoGravityResize,查看該屬性以及相關(guān)的其他屬性值發(fā)現(xiàn)有3種值可以設置,

AVLayerVideoGravityResizeAspect
AVLayerVideoGravityResizeAspectFill
AVLayerVideoGravityResize

逐一試用后發(fā)現(xiàn)了其中的一些不同,在這里分享一下,可能我說的不太標準,只是個人的一些理解。
開始把描述放到百度翻譯上去翻譯了一下,

1.Preserve aspect ratio; fit within layer bounds
2.Preserve aspect ratio; fill layer bounds
3.Stretch to fill layer bounds

解釋是
1.保持縱橫比;適合層范圍內(nèi)
2.保持縱橫比;填充層邊界
3.拉伸填充層邊界

再看我分別設置了 WMPlayer 這個播放器中的3種不同屬性值得結(jié)果圖,

1. wmPlayer.playerLayer.videoGravity = AVLayerVideoGravityResizeAspect
2. wmPlayer.playerLayer.videoGravity = AVLayerVideoGravityResizeAspectFill
3. wmPlayer.playerLayer.videoGravity = AVLayerVideoGravityResize
屏幕快照 2016-10-14 下午4.32.15.png
屏幕快照 2016-10-14 下午4.32.01.png
屏幕快照 2016-10-14 下午4.32.25.png

可以總結(jié)一下,
第1種模式AVLayerVideoGravityResizeAspect是按原視頻比例顯示,是豎屏的就顯示出豎屏的,兩邊留黑;
第2種AVLayerVideoGravityResizeAspectFill是以原比例拉伸視頻,直到兩邊屏幕都占滿,但視頻內(nèi)容有部分就被切割了;
第3種AVLayerVideoGravityResize是拉伸視頻內(nèi)容達到邊框占滿,但不按原比例拉伸,這里明顯可以看出寬度被拉伸了。

有點像UIImageView的ContentMode設置,這里是個人對這個屬性值得一些理解,有不足還請包涵。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容