色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

Android 使用騰訊X5瀏覽器上傳圖片的示例

瀏覽:3日期:2022-09-19 18:52:17

這幾天在客戶端接入一個Web頁的客服系統,用來接受用戶的反饋和建議。Android客戶端集成這個客服H5之后,圖片死活傳遞不上去。看了一下iOS同事的集成效果,可以自由上傳圖片,再把H5的地址用Android原生瀏覽器打開,也可以正常打開相冊上傳圖片。

What??? 見鬼了, 氣抖冷!!!

Android 使用騰訊X5瀏覽器上傳圖片的示例

看了一些博客,使用Android的WebView在默認情況下是不能夠支持上傳文件的(需要重寫 onShowFileChooser方法)。那就只能擼起袖子自己干了。

項目中使用的瀏覽器內核是騰訊X5瀏覽器,那就去騰訊X5的技術文檔看看有沒有實現方式:TBS開發指引, 找了一下發現還真有

Android 使用騰訊X5瀏覽器上傳圖片的示例

1、文件選擇

方法一: 文件單選:設置client回調

mWebView.setWebChromeClient(new WebChromeClient() { @Override public void openFileChooser( ValueCallback<Uri> uploadFile, String acceptType, String captureType) { //保存對應的valuecallback供選擇后使用 //通過startActivityForResult啟動文件選擇窗口或自定義文件選擇 } });

文件多選:設置client回調

mWebView.setWebChromeClientExtension(new ProxyWebChromeClientExtension() { @Override public void openFileChooser( android.webkit.ValueCallback<Uri[]> uploadFile, String acceptType, String captureType) { //保存對應的valuecallback供選擇后使用 //通過startActivityForResult啟動文件選擇窗口或自定義文件選擇 }});

方法二: 設置client回調(單選多選均會回調該接口)

mWebView.setWebChromeClient(new WebChromeClient() { @Override public boolean onShowFileChooser( IX5WebViewBase webView, ValueCallback<Uri[]> filePathCallback, FileChooserParams fileChooserParams) { //保存對應的valuecallback供選擇后使用 //通過startActivityForResult啟動文件選擇窗口或自定義文件選擇 } });

然后在activity返回時將用戶的選擇設置給對應的ValueCallback

protected void onActivityResult(int requestCode, int resultCode, Intent data) { //如果是文件選擇 if (resultCode == RESULT_OK) { //給文件選擇的ValueCallback設置onReceiveValue值 } else if (resultCode == RESULT_CANCELED) { //給文件選擇的ValueCallback設置null值 }}2、實現文件單選

在項目自定義的WebChromeClient 中,重寫openFileChooser方法, 調用項目中圖片選擇組件,圖片選擇成功后將生成的uri使用valueCallback回調,即可上傳成功

// 圖片單選上傳 @Override public void openFileChooser(ValueCallback<Uri> valueCallback, String s, String s1) { Log.i(TAG, 'openFileChooser: acceptType: ' + s + ' captureType: ' + s1);// 調用項目中圖片選擇組件 // 圖片選擇成功后將生成的uri使用valueCallback回調 // 即可上傳成功 } // 很多博客介紹了, 要寫很多Android各個API的兼容代碼, 其實不用。 X5在這個方法底層其實實現了兼容各系統的能力,不需要上層開發者來實現。 只需實現這一個方法即可

實現效果:

Android 使用騰訊X5瀏覽器上傳圖片的示例

3、舉個例子

為簡單起見, 集成一個第三方的圖片選擇控件

github.com/thewyp/Avat…

集成方式:

dependencies {...compile ’me.thewyp:avatar:1.0.4’ }

使用方式:

new AvatarStudio.Builder(activityContext) .needCrop(true)//是否裁剪,默認裁剪 .setTextColor(Color.BLUE) .dimEnabled(true)//背景是否dim 默認true .setAspect(1, 1)//裁剪比例 默認1:1 .setOutput(200, 200)//裁剪大小 默認200*200 .setText('打開相機', '從相冊中選取', '取消') .show(new AvatarStudio.CallBack() {@Overridepublic void callback(String uri) { //uri為圖片路徑 Picasso.with(activityContext).load(new File(uri)).into(mImageView);} });

實現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)//是否裁剪,默認裁剪 .setTextColor(Color.BLUE) .dimEnabled(true)//背景是否dim 默認true .setAspect(1, 1)//裁剪比例 默認1:1 .setOutput(200, 200)//裁剪大小 默認200*200 .setText('打開相機', '從相冊中選取', '取消') .show(new AvatarStudio.CallBack() {@Overridepublic void callback(String uri) { //uri為圖片路徑 valueCallback.onReceiveValue(Uri.parse(uri)); // 將生成的Uri使用valueCallback 回調給X5底層,實現圖片上傳} }); } ......}

至此,圖片的上傳就實現了。文件的實現也是同理, 大家感興趣的可以試試

以上就是Android 使用騰訊X5瀏覽器上傳圖片的示例的詳細內容,更多關于Android 上傳圖片的資料請關注好吧啦網其它相關文章!

標簽: Android
相關文章:
主站蜘蛛池模板: 亚洲系列中文字幕一区二区 | 国产成人综合91精品 | 欧美视频网站在线观看 | 国产精品嘿咻嘿咻在线播放 | 久久免费在线视频 | 免费国产一区二区在免费观看 | 日本精品一区二区三区在线视频一 | 亚洲www视频 | 日韩欧美国产精品第一页不卡 | 欧美一级视频在线高清观看 | 操爽视频| 小泽玛利亚的一级毛片的 | 国内精品国语自产拍在线观看55 | 一级做a爱过程免费视 | 午夜手机福利 | 丁香五香天堂 | 日本三级午夜 | 国产欧美日韩精品一区二 | 欧美性猛交xxxxxxxx软件 | 国产视频二区在线观看 | 国产系列 视频二区 | 99黄色网| 日韩在线高清视频 | 国产成人无精品久久久久国语 | 日本暖暖在线视频 | 找国产毛片 | 萌白酱香蕉白丝护士服喷浆 | 久久久精品久久久久久久久久久 | 真人一级毛片免费完整视 | 免费又黄又爽的视频 | 欧美成人午夜毛片免费影院 | 国产激情一级毛片久久久 | 久久精品久久精品久久精品 | 一级做a毛片免费视频 | 欧美日韩一区二区不卡三区 | 久久久久国产精品免费看 | 日本欧美一区二区三区视频 | 日韩 国产 欧美视频一区二区三区 | 色吊丝在线观看国产 | 在线观看国产精品入口 | 欧美高清免费精品国产自 |