Android Presentation雙屏異顯開(kāi)發(fā)流程詳細(xì)講解
1. 背景
我們那個(gè)副屏是一塊汽車的后視鏡(流媒體后視鏡),是一塊長(zhǎng)條塊的屏幕,分辨率是400 * 1920 px
,如何將需要顯示的內(nèi)容正確擺放地顯示到這塊屏幕上,也是我們開(kāi)發(fā)中的一個(gè)重點(diǎn)。
并且,我們是使用平板橫屏進(jìn)行開(kāi)發(fā)的,對(duì)于橫屏情況下雙屏異顯的處理,也是我們開(kāi)發(fā)中的一個(gè)重點(diǎn)。
2. 創(chuàng)建主屏布局
主屏就用MainActivity
就好
class MainActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) //... } }
3. 創(chuàng)建副屏布局
這里,繼承了MyPresentation
接口
class MyPresentation(outerContext: Context, display: Display) : Presentation(outerContext, display) { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.dialog_normal)//綁定副屏顯示的布局 } //顯示時(shí)調(diào)用 override fun onStart() { super.onStart() } //消失時(shí)調(diào)用 override fun onStop() { super.onStop() } }
4. 將頁(yè)面投屏到副屏上
投屏到副屏上有多中方式,我們只需要在MainActivity
中去調(diào)用這些代碼就可以了。
4.1 MediaRouter
MediaRouter mediaRouter = (MediaRouter) getSystemService(Context.MEDIA_ROUTER_SERVICE); MediaRouter.RouteInfo route = mediaRouter.getSelectedRoute(MediaRouter.ROUTE_TYPE_LIVE_AUDIO); if (route != null) { Display presentationDisplay = route.getPresentationDisplay(); if (presentationDisplay != null) { MyPresentation myPresentation = new MyPresentation(MainActivity.this, presentationDisplay); myPresentation.show(); } }
4.2 DisplayManager
DisplayManager mDisplayManager = (DisplayManager) getSystemService(Context.DISPLAY_SERVICE); Display[] displays = mDisplayManager.getDisplays(); if (displays.length > 1) { //displays[0] 主屏,displays[1] 副屏 MyPresentation myPresentation = new MyPresentation(MainActivity.this, displays[1]); myPresentation.show(); }
5. 橫屏狀態(tài)下雙屏異顯的處理
在我們那個(gè)副屏上,副屏的顯示邏輯是,主屏是豎屏,副屏就以副屏顯示,主屏是橫屏,副屏就以橫屏顯示。
如下圖所示
而我們想要達(dá)到的效果是,主屏是橫屏,而主屏是豎屏。
后來(lái),我們想到了一個(gè)辦法,就是搞兩個(gè)Activity
,Activity1
負(fù)責(zé)顯示主屏的頁(yè)面,而Activity2
負(fù)責(zé)副屏的顯示。
首先啟動(dòng)Activity2
,然后迅速啟動(dòng)Activity1
,當(dāng)Activity1
關(guān)閉的時(shí)候,也去關(guān)閉Activity1
,這樣就可以實(shí)現(xiàn)主屏和副屏方向顯示不一樣的情況了。
6. 將需要顯示的內(nèi)容正確擺放到副屏上
由于我們的副屏是一塊長(zhǎng)條塊的屏幕,分辨率是400 * 1920 px
,我們現(xiàn)在主屏上是橫屏顯示,而副屏通過(guò)上述的操作,顯示的是豎屏。
而我們真正期望顯示的內(nèi)容是藍(lán)色這部分
所以,我們需要對(duì)View做一下旋轉(zhuǎn)并位移
val rotation: ObjectAnimator = ObjectAnimator.ofFloat(binding.textureView, "rotation", 0f, 90f) val translationX: ObjectAnimator = ObjectAnimator.ofFloat(binding.textureView, "translationX", 0f, -720F) val translationY: ObjectAnimator = ObjectAnimator.ofFloat(binding.textureView, "translationY", 0f, 420F) val animatorSet = AnimatorSet() animatorSet.playSequentially(rotation, translationX, translationY) animatorSet.duration = 0 animatorSet.start()
最終顯示為這樣
7. 其他
沒(méi)有副屏的情況下,如何調(diào)試 ?
如果手頭上沒(méi)有副屏,可以在開(kāi)發(fā)者選項(xiàng)中,打開(kāi)模擬輔助顯示設(shè)備
這里我們可以選擇1080P
顯示出來(lái)的虛擬副屏如下所示
這樣,我們就可以通過(guò)虛擬的副屏進(jìn)行調(diào)試了。
參考
感謝
Android三種雙屏異顯實(shí)現(xiàn)方法介紹
Android Presentation實(shí)現(xiàn)雙屏異顯
到此這篇關(guān)于Android Presentation雙屏異顯開(kāi)發(fā)流程詳細(xì)講解的文章就介紹到這了,更多相關(guān)Android Presentation內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android監(jiān)聽(tīng)電池狀態(tài)實(shí)例代碼
這篇文章給大家介紹Android監(jiān)聽(tīng)電池狀態(tài)實(shí)例代碼,對(duì)android監(jiān)聽(tīng)電池狀態(tài)相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧2016-03-03解決Android Studio4.1沒(méi)有Gsonfomat插件,Plugin “GsonFormat” is inco
這篇文章主要介紹了解決Android Studio4.1沒(méi)有Gsonfomat插件,Plugin “GsonFormat” is incompatible (supported only in IntelliJ IDEA)的問(wèn)題 ,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2020-12-12深入學(xué)習(xí)Kotlin?枚舉的簡(jiǎn)潔又高效進(jìn)階用法
這篇文章主要為大家介紹了深入學(xué)習(xí)Kotlin?枚舉簡(jiǎn)潔又高效的進(jìn)階用法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05Android 架構(gòu)之?dāng)?shù)據(jù)庫(kù)框架升級(jí)
上一篇講解了# Android 架構(gòu)之?dāng)?shù)據(jù)框架搭建 ,里面含有數(shù)據(jù)庫(kù)最基礎(chǔ)的增刪改查功能,不過(guò)只考慮了單數(shù)據(jù)庫(kù),開(kāi)發(fā)者可以舉一反三按照對(duì)應(yīng)思路設(shè)計(jì)多數(shù)據(jù)庫(kù)架構(gòu)。 在本篇里,將會(huì)講解令開(kāi)發(fā)者比較頭疼的數(shù)據(jù)庫(kù)升級(jí),需要的朋友可以參考下面文章內(nèi)容2021-09-09Android水波紋載入控件CircleWaterWaveView使用詳解
這篇文章主要為大家詳細(xì)介紹了Android水波紋載入控件CircleWaterWaveView使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-01-01