Android 使用騰訊X5瀏覽器上傳圖片的示例
這幾天在客戶端接入一個(gè)Web頁的客服系統(tǒng),用來接受用戶的反饋和建議。Android客戶端集成這個(gè)客服H5之后,圖片死活傳遞不上去??戳艘幌耰OS同事的集成效果,可以自由上傳圖片,再把H5的地址用Android原生瀏覽器打開,也可以正常打開相冊(cè)上傳圖片。
What??? 見鬼了, 氣抖冷?。?!
看了一些博客,使用Android的WebView在默認(rèn)情況下是不能夠支持上傳文件的(需要重寫 onShowFileChooser方法)。那就只能擼起袖子自己干了。
項(xiàng)目中使用的瀏覽器內(nèi)核是騰訊X5瀏覽器,那就去騰訊X5的技術(shù)文檔看看有沒有實(shí)現(xiàn)方式:TBS開發(fā)指引, 找了一下發(fā)現(xiàn)還真有
1、文件選擇
方法一: 文件單選:設(shè)置client回調(diào)
mWebView.setWebChromeClient(new WebChromeClient() { @Override public void openFileChooser( ValueCallback<Uri> uploadFile, String acceptType, String captureType) { //保存對(duì)應(yīng)的valuecallback供選擇后使用 //通過startActivityForResult啟動(dòng)文件選擇窗口或自定義文件選擇 } });
文件多選:設(shè)置client回調(diào)
mWebView.setWebChromeClientExtension(new ProxyWebChromeClientExtension() { @Override public void openFileChooser( android.webkit.ValueCallback<Uri[]> uploadFile, String acceptType, String captureType) { //保存對(duì)應(yīng)的valuecallback供選擇后使用 //通過startActivityForResult啟動(dòng)文件選擇窗口或自定義文件選擇 } });
方法二: 設(shè)置client回調(diào)(單選多選均會(huì)回調(diào)該接口)
mWebView.setWebChromeClient(new WebChromeClient() { @Override public boolean onShowFileChooser( IX5WebViewBase webView, ValueCallback<Uri[]> filePathCallback, FileChooserParams fileChooserParams) { //保存對(duì)應(yīng)的valuecallback供選擇后使用 //通過startActivityForResult啟動(dòng)文件選擇窗口或自定義文件選擇 } });
然后在activity返回時(shí)將用戶的選擇設(shè)置給對(duì)應(yīng)的ValueCallback
protected void onActivityResult(int requestCode, int resultCode, Intent data) { //如果是文件選擇 if (resultCode == RESULT_OK) { //給文件選擇的ValueCallback設(shè)置onReceiveValue值 } else if (resultCode == RESULT_CANCELED) { //給文件選擇的ValueCallback設(shè)置null值 } }
2、實(shí)現(xiàn)文件單選
在項(xiàng)目自定義的WebChromeClient 中,重寫openFileChooser方法, 調(diào)用項(xiàng)目中圖片選擇組件,圖片選擇成功后將生成的uri使用valueCallback回調(diào),即可上傳成功
// 圖片單選上傳 @Override public void openFileChooser(ValueCallback<Uri> valueCallback, String s, String s1) { Log.i(TAG, "openFileChooser: acceptType: " + s + " captureType: " + s1); // 調(diào)用項(xiàng)目中圖片選擇組件 // 圖片選擇成功后將生成的uri使用valueCallback回調(diào) // 即可上傳成功 } // 很多博客介紹了, 要寫很多Android各個(gè)API的兼容代碼, 其實(shí)不用。 X5在這個(gè)方法底層其實(shí)實(shí)現(xiàn)了兼容各系統(tǒng)的能力,不需要上層開發(fā)者來實(shí)現(xiàn)。 只需實(shí)現(xiàn)這一個(gè)方法即可
實(shí)現(xiàn)效果:
3、舉個(gè)例子
為簡(jiǎn)單起見, 集成一個(gè)第三方的圖片選擇控件
集成方式:
dependencies { ... compile 'me.thewyp:avatar:1.0.4' }
使用方式:
new AvatarStudio.Builder(activityContext) .needCrop(true)//是否裁剪,默認(rèn)裁剪 .setTextColor(Color.BLUE) .dimEnabled(true)//背景是否dim 默認(rèn)true .setAspect(1, 1)//裁剪比例 默認(rèn)1:1 .setOutput(200, 200)//裁剪大小 默認(rèn)200*200 .setText("打開相機(jī)", "從相冊(cè)中選取", "取消") .show(new AvatarStudio.CallBack() { @Override public void callback(String uri) { //uri為圖片路徑 Picasso.with(activityContext).load(new File(uri)).into(mImageView); } });
實(shí)現(xiàn)Web上傳圖片
public class WebChromeClientImpl extends WebChromeClient { ...... // 圖片單選上傳 @Override public void openFileChooser(ValueCallback<Uri> valueCallback, String s, String s1) { Log.i(TAG, "openFileChooser: acceptType: " + s + " captureType: " + s1); new AvatarStudio.Builder(context) .needCrop(true)//是否裁剪,默認(rèn)裁剪 .setTextColor(Color.BLUE) .dimEnabled(true)//背景是否dim 默認(rèn)true .setAspect(1, 1)//裁剪比例 默認(rèn)1:1 .setOutput(200, 200)//裁剪大小 默認(rèn)200*200 .setText("打開相機(jī)", "從相冊(cè)中選取", "取消") .show(new AvatarStudio.CallBack() { @Override public void callback(String uri) { //uri為圖片路徑 valueCallback.onReceiveValue(Uri.parse(uri)); // 將生成的Uri使用valueCallback 回調(diào)給X5底層,實(shí)現(xiàn)圖片上傳 } }); } ...... }
至此,圖片的上傳就實(shí)現(xiàn)了。文件的實(shí)現(xiàn)也是同理, 大家感興趣的可以試試
以上就是Android 使用騰訊X5瀏覽器上傳圖片的示例的詳細(xì)內(nèi)容,更多關(guān)于Android 上傳圖片的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- iOS Crash常規(guī)跟蹤方法及Bugly集成運(yùn)用詳細(xì)介紹
- Android 通過騰訊TBS實(shí)現(xiàn)文件預(yù)覽功能
- Android基于騰訊云實(shí)時(shí)音視頻仿微信視頻通話最小化懸浮
- Android集成騰訊X5實(shí)現(xiàn)文檔瀏覽功能
- Android自定義View仿騰訊TIM下拉刷新View
- Android在項(xiàng)目中接入騰訊TBS瀏覽器WebView的教程與注意的地方
- Android實(shí)現(xiàn)視頻播放--騰訊瀏覽服務(wù)(TBS)功能
- Android開發(fā)騰訊驗(yàn)證碼遇到的坑
- 騰訊、百度、華為、搜狗和滴滴Android面試題匯總
- Android如何快速集成騰訊Bugly
相關(guān)文章
Android開發(fā)實(shí)現(xiàn)錄屏小功能
這篇文章主要介紹了Android開發(fā)實(shí)現(xiàn)錄屏小功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-07-07如何通過Android Stduio來編寫一個(gè)完整的天氣預(yù)報(bào)APP
這篇文章主要介紹了通過Android Stduio來編寫一個(gè)天氣預(yù)報(bào)APP,具體的實(shí)現(xiàn)是通過調(diào)用天氣預(yù)報(bào)接口來獲得天氣數(shù)據(jù),再將查詢的天氣信息存儲(chǔ)在SQLiteDatabase中,界面則用LIstView和GridView來搭建2021-08-08Android實(shí)現(xiàn)歌詞漸變色和進(jìn)度的效果
這篇文章主要介紹了Android實(shí)現(xiàn)歌詞漸變色和進(jìn)度的效果的相關(guān)資料,需要的朋友可以參考下2016-03-03Android ListView自動(dòng)顯示隱藏布局的實(shí)現(xiàn)方法
這篇文章主要介紹了Android ListView自動(dòng)顯示隱藏布局的實(shí)現(xiàn)方法的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-09-09Android 簡(jiǎn)單的實(shí)現(xiàn)滑塊拼圖驗(yàn)證碼功能
這篇文章主要介紹了Android 簡(jiǎn)單的實(shí)現(xiàn)滑塊拼圖驗(yàn)證碼功能,幫助大家更好的理解和學(xué)習(xí)使用Android開發(fā),感興趣的朋友可以了解下2021-03-03Android基于ImageSwitcher實(shí)現(xiàn)圖片切換功能
這篇文章主要介紹了Android基于ImageSwitcher實(shí)現(xiàn)圖片切換功能的相關(guān)資料,需要的朋友可以參考下2016-02-02Android仿微信底部實(shí)現(xiàn)Tab選項(xiàng)卡切換效果
這篇文章主要為大家介紹了Android仿微信底部實(shí)現(xiàn)Tab選項(xiàng)卡切換效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-02-02