Fragment中使用高德MapView讨韭,切換頁面時(shí)遇到問題解決過程

問題描述

最近的一個(gè)項(xiàng)目中,首頁使用了ViewPager+Fragment模式能扒,在ViewPager里有一個(gè)Flutter頁面和一個(gè)用MapView寫的地圖頁面块茁。從地圖切換過去的時(shí)候MapView會有一個(gè)拉伸的截圖覆蓋在Flutter頁面上了齿坷。但是Flutter頁面實(shí)際上是加載出來的,并且如點(diǎn)擊事件等都可以正常響應(yīng)数焊,很是奇怪永淌。

問題分析

因?yàn)辄c(diǎn)擊事件都能被響應(yīng),說明Flutter頁面已經(jīng)加載完成了佩耳,只是被遮擋了遂蛀,故把Flutter頁面從懷疑對象中排除。所以把注意力轉(zhuǎn)移到地圖頁面干厚。地圖頁面里嵌入里一個(gè)高德SDK提供的MapView李滴,應(yīng)該是這里在切換時(shí)出問題了。

第一次嘗試

嘗試在地圖頁面切換時(shí)將MapView隱藏起來蛮瞄,這樣就不會產(chǎn)生截圖了所坯。由于是ViewPager+Fragment的組合,所以在setUserVisibleHint()中進(jìn)行操作挂捅,代碼如下:

override fun setUserVisibleHint(isVisibleToUser: Boolean) {
    super.setUserVisibleHint(isVisibleToUser)
    if (isVisibleToUser)  mapView?.visibility = View.VISIBLE  else   mapView?.visibility = View.GONE
}

到這里確實(shí)解決了切換存在截圖問題芹助,但是同時(shí)引入了兩個(gè)新問題。

問題1 切換時(shí)出現(xiàn)閃屏黑屏

從地圖切換其他頁面時(shí)會出現(xiàn)一次短暫的黑屏
這個(gè)問題應(yīng)該是高德地圖的問題闲先,因?yàn)镸apView中封裝了一個(gè)GlSurfaceView,SurfaceView和其他View不同周瞎,他有自己良好的緩沖以及數(shù)據(jù)存取機(jī)制,系統(tǒng)對他有特殊處理饵蒂。在網(wǎng)上也有很多關(guān)于SurfaceView黑屏的解決辦法声诸,如

在activity的oncreate方法中加入getWindow().setFormat(PixelFormat.TRANSLUCENT);

經(jīng)過測試對我的項(xiàng)目無效,在翻看了高德API手冊里發(fā)現(xiàn)了一個(gè)叫做TextureMapView的東東退盯,對他的介紹是這樣的:

一個(gè)顯示地圖的視圖(View)彼乌,它負(fù)責(zé)從服務(wù)端獲取地圖數(shù)據(jù),它將會捕捉屏幕觸控手勢事件渊迁。 使用這個(gè)類必須按照它的生命周期進(jìn)行操控慰照,你必須參照以下方法onCreate(Bundle)、 onResume()琉朽、onPause()毒租、onDestroy()。等聲明周期函數(shù)箱叁。
它和MapView的區(qū)別在于墅垮,TextureMapView是一個(gè)TextureView而MapView是一個(gè)GLSurfaceView惕医。
所以TextureMapView 可以和其他的GlSurfaceView(比如相機(jī))共存不會出現(xiàn)穿透現(xiàn)象,也可以放在ViewPager中不會出現(xiàn)滑動(dòng)黑邊現(xiàn)象算色。

這個(gè)完美應(yīng)對我現(xiàn)在的需求啊抬伺,于是乎將MapView替換為TextureMapView,果然解決了閃屏問題灾梦。

問題2 MapView中添加過多Marker和繪制的點(diǎn)線后峡钓,在切換時(shí)閃屏黑屏?xí)r間明顯變長。

黑屏問題解決后若河,性能問題也是不能不解決的能岩。在Activity中使用MapView的時(shí)候,切換到其他頁面時(shí)MapView會調(diào)用onPasue()方法萧福,再回到當(dāng)前頁面時(shí)會調(diào)用onRsume()方法捧灰,雖然不知道onPasue()方法具體做了什么,但是我們知道地圖時(shí)很消耗內(nèi)存的控件统锤,所以不難猜測在onPasue()方法中肯定做了相關(guān)資源的釋放和一些性能上的優(yōu)化操作毛俏。
根據(jù)這個(gè)思路,在fragment不可見時(shí)主動(dòng)調(diào)用一次onPause()饲窿,在可見時(shí)再調(diào)用onResume()煌寇。

最終解決辦法

修改后的代碼如下:

override fun setUserVisibleHint(isVisibleToUser: Boolean) {
    super.setUserVisibleHint(isVisibleToUser)
    if (isVisibleToUser) {      
        mapView?.onResume()
        mapView?.visibility = View.VISIBLE
    } else {
        mapView?.onPause()      
        mapView?.visibility = View.GONE
    }
}

代碼很簡單逾雄,再次運(yùn)行后順利的解決了問題阀溶。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市鸦泳,隨后出現(xiàn)的幾起案子银锻,更是在濱河造成了極大的恐慌,老刑警劉巖做鹰,帶你破解...
    沈念sama閱讀 206,723評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件击纬,死亡現(xiàn)場離奇詭異,居然都是意外死亡钾麸,警方通過查閱死者的電腦和手機(jī)更振,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來饭尝,“玉大人肯腕,你說我怎么就攤上這事≡科剑” “怎么了实撒?”我有些...
    開封第一講書人閱讀 152,998評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我知态,道長捷兰,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,323評論 1 279
  • 正文 為了忘掉前任肴甸,我火速辦了婚禮,結(jié)果婚禮上囚巴,老公的妹妹穿的比我還像新娘原在。我一直安慰自己,他們只是感情好彤叉,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,355評論 5 374
  • 文/花漫 我一把揭開白布庶柿。 她就那樣靜靜地躺著,像睡著了一般秽浇。 火紅的嫁衣襯著肌膚如雪浮庐。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,079評論 1 285
  • 那天柬焕,我揣著相機(jī)與錄音审残,去河邊找鬼。 笑死斑举,一個(gè)胖子當(dāng)著我的面吹牛搅轿,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播富玷,決...
    沈念sama閱讀 38,389評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼璧坟,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了赎懦?” 一聲冷哼從身側(cè)響起雀鹃,我...
    開封第一講書人閱讀 37,019評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎励两,沒想到半個(gè)月后黎茎,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,519評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡当悔,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,971評論 2 325
  • 正文 我和宋清朗相戀三年工三,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片先鱼。...
    茶點(diǎn)故事閱讀 38,100評論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡俭正,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出焙畔,到底是詐尸還是另有隱情掸读,我是刑警寧澤,帶...
    沈念sama閱讀 33,738評論 4 324
  • 正文 年R本政府宣布,位于F島的核電站儿惫,受9級特大地震影響澡罚,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜肾请,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,293評論 3 307
  • 文/蒙蒙 一留搔、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧铛铁,春花似錦隔显、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,289評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至倍权,卻和暖如春掷豺,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背薄声。 一陣腳步聲響...
    開封第一講書人閱讀 31,517評論 1 262
  • 我被黑心中介騙來泰國打工当船, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人默辨。 一個(gè)月前我還...
    沈念sama閱讀 45,547評論 2 354
  • 正文 我出身青樓生年,卻偏偏與公主長得像,于是被迫代替她去往敵國和親廓奕。 傳聞我的和親對象是個(gè)殘疾皇子抱婉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,834評論 2 345