最近要支持一個(gè)視頻挑戰(zhàn)的活動(dòng),要求 WebView 能全屏播放視頻,現(xiàn)在把 Android 端實(shí)現(xiàn)的方法分享給大家。
專注于為中小企業(yè)提供網(wǎng)站設(shè)計(jì)制作、網(wǎng)站設(shè)計(jì)服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)荔波免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了上1000家企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過(guò)網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。
要實(shí)現(xiàn)全屏需要給 WebView 設(shè)置 WebChromeClient 并覆寫 onShowCustomView 和 onHideCustomView() 兩方法:
webView.setWebChromeClient(new WebChromeClient() { @Override public void onShowCustomView(View view, CustomViewCallback callback) { // 此處的 view 就是全屏的視頻播放界面,需要把它添加到我們的界面上 } @Override public void onHideCustomView() { // 退出全屏播放,我們要把之前添加到界面上的視頻播放界面移除 } });
為了實(shí)現(xiàn)全屏的效果,需要將視頻界面添加我們界面的最上層,有兩種方式,一種是添加到 ContentView 中,核心代碼如下:
contentParentView = findViewById(android.R.id.content); webView.setWebChromeClient(new WebChromeClient() { @Override public void onShowCustomView(View view, CustomViewCallback callback) { contentParentView.addView(view); } @Override public void onHideCustomView() { contentParentView.removeView(fullScreenView); } });
另一種是添加到 WindowManager 中,完整代碼如下:
public class WebActivity extends AppCompatActivity { ... private WindowManager windowManager; private View fullScreenView = null; @Override protected void onResume() { super.onResume(); // 如果之前處于全屏狀態(tài),重新進(jìn)入后需要再次調(diào)用全屏 if (fullScreenView != null) fullScreen(fullScreenView); } @Override public void onBackPressed() { // 全屏狀態(tài)點(diǎn)擊返回退出全屏 if (fullScreenView != null) { windowManager.removeViewImmediate(fullScreenView); fullScreenView = null; } else { super.onBackPressed(); } } @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_webview); windowManager = getWindowManager(); webView.setWebChromeClient(new WebChromeClient() { @Override public void onShowCustomView(View view, CustomViewCallback callback) { // 此處的 view 就是全屏的視頻播放界面,需要把它添加到我們的界面上 windowManager.addView(view, new WindowManager.LayoutParams(WindowManager.LayoutParams.TYPE_APPLICATION)); // 去除狀態(tài)欄和導(dǎo)航按鈕 fullScreen(view); fullScreenView = view; } @Override public void onHideCustomView() { // 退出全屏播放,我們要把之前添加到界面上的視頻播放界面移除 windowManager.removeViewImmediate(fullScreenView); fullScreenView = null; } }); } private void fullScreen(View view) { if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) { view.setSystemUiVisibility(View.SYSTEM_UI_FLAG_LOW_PROFILE | View.SYSTEM_UI_FLAG_FULLSCREEN | View.SYSTEM_UI_FLAG_LAYOUT_STABLE | View.SYSTEM_UI_FLAG_IMMERSIVE_STICKY | View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION | View.SYSTEM_UI_FLAG_HIDE_NAVIGATION); } else { view.setSystemUiVisibility(View.SYSTEM_UI_FLAG_LOW_PROFILE | View.SYSTEM_UI_FLAG_FULLSCREEN | View.SYSTEM_UI_FLAG_LAYOUT_STABLE | View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION | View.SYSTEM_UI_FLAG_HIDE_NAVIGATION); } } }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。
網(wǎng)站標(biāo)題:WebView實(shí)現(xiàn)全屏播放視頻的示例代碼
文章網(wǎng)址:http://jinyejixie.com/article2/peoiic.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站設(shè)計(jì)、軟件開(kāi)發(fā)、網(wǎng)站制作、全網(wǎng)營(yíng)銷推廣、響應(yīng)式網(wǎng)站、企業(yè)網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)