flutter自動(dòng)跳轉(zhuǎn)的簡單介紹

Android & Flutter 相互跳轉(zhuǎn)

本文中native和flutter的跳轉(zhuǎn)是借助于咸魚的FlutterBoost和ARouter框架實(shí)現(xiàn)的。

我們提供的服務(wù)有:成都網(wǎng)站建設(shè)、成都網(wǎng)站制作、微信公眾號(hào)開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認(rèn)證、靈臺(tái)ssl等。為近千家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的靈臺(tái)網(wǎng)站制作公司

Sync Now...

flutterBoost中需要給每個(gè)頁面定義一個(gè)router_path,然后根據(jù)router_path找到對(duì)應(yīng)頁面再跳轉(zhuǎn)。

在Application的onCreate中初始化

android jump to flutter

flutter jump to android

flutter 創(chuàng)建頁面、跳轉(zhuǎn)動(dòng)畫

本文演示flutter創(chuàng)建 page1 和 page2 兩個(gè)頁面,并且頁面之間跳轉(zhuǎn)添加動(dòng)畫

Flutter跳轉(zhuǎn)到原生iOS、Android頁面

:之所以讓AppDelegate繼承于UINavigationControllerDelegate,并實(shí)現(xiàn)navigationController:willShow方法, ,所以實(shí)現(xiàn)代理方法對(duì)導(dǎo)航欄的顯示做了判斷。

JumpTestViewController.swift 為:

JumpChannel.kt :

SecondActivity.kt :

在AndroidManifest.xml的application中注冊(cè)SecondActivity:

在res文件夾下創(chuàng)建一個(gè)layout文件夾,并添加activity_second.xml文件:

Demo: flutter_jumpto_native

flutter_webview_plugin 與dart頁面跳轉(zhuǎn)使用

使用flutter_webview_plugin 加載一個(gè)H5頁面,是從dart頁面中跳轉(zhuǎn)h5頁面,h5頁面中可返回dart頁面,也可跳轉(zhuǎn)到其他dart頁面。

經(jīng)測(cè)試,在Android上可正常使用,但在ios上關(guān)閉web頁面時(shí)顯示白屏,web頁面并沒有close,還沒找到原因。。。

flutter跳轉(zhuǎn)原生頁面后的穿透問題

現(xiàn)象:

flutter頁面通過present跳轉(zhuǎn)原生頁面后,原生頁面上的點(diǎn)擊會(huì)首先響應(yīng)下面的flutter頁面中的內(nèi)容(比如按鈕什么的)。

這是flutter框架一直存在的一個(gè)bug。在github上有相關(guān)的issue。

原因推測(cè):

推測(cè)是flutter對(duì)控制器(或者view)加了分類,重寫了控制器的點(diǎn)擊事件,用來計(jì)算是否在對(duì)應(yīng)的點(diǎn)擊位置有flutter響應(yīng)事件。沒有的話再扔出去點(diǎn)擊事件。

解決方案1:

在原生控制器中,加入點(diǎn)擊事件的幾個(gè)方法的空實(shí)現(xiàn),用以覆蓋flutter框架中的實(shí)現(xiàn):

-(void)touchesBegan:(NSSetUITouch * *)touches withEvent:(UIEvent *)event{

}

-(void)touchesMoved:(NSSetUITouch * *)touches withEvent:(UIEvent *)event{

}

-(void)touchesCancelled:(NSSetUITouch * *)touches withEvent:(UIEvent *)event{

}

-(void)touchesEnded:(NSSetUITouch * *)touches withEvent:(UIEvent *)event{

}

讓事件不被flutter截獲即可。

解決方案2:

直接切換window的根控制器到原生控制器即可。別忘暫時(shí)保存flutter控制器。

在返回時(shí)再切換回flutter中。

解決方案3:

在flutter跳轉(zhuǎn)到原生頁面之前,在flutter中加上一個(gè)蒙層,用來隔絕手勢(shì)往flutter下面的view傳遞。原生頁面返回flutter時(shí)再移除這個(gè)蒙層。

當(dāng)前標(biāo)題:flutter自動(dòng)跳轉(zhuǎn)的簡單介紹
分享路徑:http://muchs.cn/article34/phgdpe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站設(shè)計(jì)、App設(shè)計(jì)微信小程序、定制開發(fā)、移動(dòng)網(wǎng)站建設(shè)App開發(fā)

廣告

聲明:本網(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í)需注明來源: 創(chuàng)新互聯(lián)

綿陽服務(wù)器托管