日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

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

瀏覽:36日期: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
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日韩av不卡在线观看| 国产成人精品福利| 亚洲视频综合| 秋霞影院一区二区三区| 免费看一区二区三区| 麻豆精品视频在线| 国产精品嫩草影院在线看| 国产精选久久| 精品久久国产一区| 日韩不卡在线| 午夜精品影院| 另类激情亚洲| 日韩精品视频中文字幕| 日韩成人av影视| 国产图片一区| 国产一区二区三区久久 | 久久亚洲欧美| 久久成人国产| 偷拍亚洲精品| 国产探花一区| 国产一区二区三区四区五区| 欧美三级网址| 久久福利一区| 国产精品永久| 色偷偷色偷偷色偷偷在线视频| 91精品国产调教在线观看| 欧美日韩精品一本二本三本 | 亚洲h色精品| 欧美~级网站不卡| 国产视频一区在线观看一区免费| 美国三级日本三级久久99| 欧美亚洲免费| 性感美女一区二区在线观看| 亚洲一区中文| 97久久中文字幕| 麻豆视频在线观看免费网站黄| 欧美高清不卡| 日韩福利视频一区| аⅴ资源天堂资源库在线| 国产精品日本欧美一区二区三区| 91午夜精品| 日韩毛片视频| 在线精品观看| 精品美女在线视频| 欧美精品一区二区久久| 91嫩草精品| 另类中文字幕国产精品| 在线精品福利| 欧美黄色网页| 亚州av一区| 精品日韩视频| 91精品国产自产在线丝袜啪| 国产一区二区三区亚洲综合| 国产韩日影视精品| 国产精品二区影院| 欧美日韩视频| 国模精品一区| 中文不卡在线| 成人三级高清视频在线看| 久久最新视频| 成人在线视频免费| 亚洲九九精品| 久久精品青草| 国产精品免费99久久久| 欧美午夜不卡| 久久精品九色| 亚洲日韩视频| 少妇精品导航| 国产精品一区二区三区四区在线观看| 神马日本精品| 国产精品magnet| 亚洲一区久久| 黄色aa久久| 7777精品| 午夜av一区| 日本一二区不卡| 日精品一区二区三区| 色爱av综合网| 久久99精品久久久久久园产越南| 久久av一区| 成人羞羞视频播放网站| 麻豆精品久久| 欧美日本一区| 男女男精品视频网| 欧美一级精品| 欧洲av不卡| 里番精品3d一二三区| 午夜亚洲福利| 免费欧美日韩| 久久三级福利| 久久久久久夜| 国产精品videossex久久发布 | 激情欧美国产欧美| 精品久久97| 91精品国产自产精品男人的天堂 | 六月丁香综合在线视频| 亚洲最大av| 亚洲成人免费| 日本精品影院| 日韩在线免费| 樱桃视频成人在线观看| 国产精品片aa在线观看| 亚洲精品乱码| 日韩中文字幕av电影| 蜜臀久久99精品久久一区二区| 精品72久久久久中文字幕| 国产欧美日韩免费观看| 日韩精品一区二区三区中文| 亚洲香蕉视频| 亚洲男人在线| 蜜臀av一区二区在线免费观看| 樱桃成人精品视频在线播放| 91亚洲国产| 国产精品二区不卡| 9999国产精品| 国产理论在线| 成人日韩在线| 日韩中文在线播放| 91精品国产调教在线观看| 日韩毛片视频| 成人免费电影网址| 夜鲁夜鲁夜鲁视频在线播放| 天堂а√在线最新版中文在线| 久久久久免费| 四虎4545www国产精品| 欧美天堂视频| 久久精品一区二区不卡| 岛国av免费在线观看| 成人午夜亚洲| 中文在线中文资源| 精品欧美一区二区三区在线观看| 在线一区视频观看| 久久国产日韩| 日本美女一区| 婷婷亚洲成人| 电影亚洲精品噜噜在线观看| 中文亚洲欧美| 国产欧美高清视频在线| 日韩欧美中文在线观看| 午夜在线一区二区| 国产精品男女| 美女精品一区| 美女少妇全过程你懂的久久| 亚洲精选成人| 久久久久国产一区二区| 日韩黄色免费网站| 日韩综合小视频| 亚洲综合专区| 国产欧美高清| 91中文字幕精品永久在线| 日韩精品首页| 爽好久久久欧美精品| 亚洲精品精选| 国产精品乱战久久久| 国产精品久久观看| 在线综合亚洲| 日本亚洲最大的色成网站www| 亚洲18在线| 国内精品美女在线观看| 久久视频精品| 一区二区三区网站| 久久国产精品免费精品3p| 麻豆视频久久| 欧美日韩精品在线一区| 石原莉奈一区二区三区在线观看| 日韩国产欧美在线播放| 免费视频一区二区三区在线观看| 综合日韩av| 夜夜嗨av一区二区三区网站四季av| 日韩在线观看中文字幕| 久久久久亚洲精品中文字幕| 91精品一区二区三区综合| 乱人伦精品视频在线观看| 国产亚洲久久| 视频福利一区| 日本久久二区| 欧美日韩国产观看视频| 视频一区中文字幕| 久久婷婷国产| 亚洲欧美日韩国产一区| 欧美国产中文高清| 亚洲精品99| 国产精品sm| 成人av二区| 国产精品三级| 午夜欧美理论片| 久久99精品久久久野外观看| 999国产精品999久久久久久| 日韩精品视频网站| 欧美日韩精品免费观看视欧美高清免费大片 | 天海翼精品一区二区三区| 久久av免费| 久久国产精品免费精品3p | 婷婷综合电影| 国产麻豆久久| 久久亚洲视频| 视频在线不卡免费观看| 亚洲五月综合| 欧美日韩视频免费观看| 国产亚洲字幕|