Android 使用騰訊X5瀏覽器上傳圖片的示例
這幾天在客戶端接入一個Web頁的客服系統(tǒng),用來接受用戶的反饋和建議。Android客戶端集成這個客服H5之后,圖片死活傳遞不上去??戳艘幌耰OS同事的集成效果,可以自由上傳圖片,再把H5的地址用Android原生瀏覽器打開,也可以正常打開相冊上傳圖片。
What??? 見鬼了, 氣抖冷?。?!

看了一些博客,使用Android的WebView在默認情況下是不能夠支持上傳文件的(需要重寫 onShowFileChooser方法)。那就只能擼起袖子自己干了。
項目中使用的瀏覽器內(nèi)核是騰訊X5瀏覽器,那就去騰訊X5的技術(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) {
//保存對應(yīng)的valuecallback供選擇后使用
//通過startActivityForResult啟動文件選擇窗口或自定義文件選擇
}
});
文件多選:設(shè)置client回調(diào)
mWebView.setWebChromeClientExtension(new ProxyWebChromeClientExtension() {
@Override
public void openFileChooser(
android.webkit.ValueCallback<Uri[]> uploadFile,
String acceptType,
String captureType) {
//保存對應(yīng)的valuecallback供選擇后使用
//通過startActivityForResult啟動文件選擇窗口或自定義文件選擇
}
});
方法二: 設(shè)置client回調(diào)(單選多選均會回調(diào)該接口)
mWebView.setWebChromeClient(new WebChromeClient() {
@Override
public boolean onShowFileChooser(
IX5WebViewBase webView,
ValueCallback<Uri[]> filePathCallback,
FileChooserParams fileChooserParams) {
//保存對應(yīng)的valuecallback供選擇后使用
//通過startActivityForResult啟動文件選擇窗口或自定義文件選擇
}
});
然后在activity返回時將用戶的選擇設(shè)置給對應(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、實現(xiàn)文件單選
在項目自定義的WebChromeClient 中,重寫openFileChooser方法, 調(diào)用項目中圖片選擇組件,圖片選擇成功后將生成的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)用項目中圖片選擇組件
// 圖片選擇成功后將生成的uri使用valueCallback回調(diào)
// 即可上傳成功
}
// 很多博客介紹了, 要寫很多Android各個API的兼容代碼, 其實不用。 X5在這個方法底層其實實現(xiàn)了兼容各系統(tǒng)的能力,不需要上層開發(fā)者來實現(xiàn)。 只需實現(xiàn)這一個方法即可
實現(xiàn)效果:

3、舉個例子
為簡單起見, 集成一個第三方的圖片選擇控件
集成方式:
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() {
@Override
public void callback(String uri) {
//uri為圖片路徑
Picasso.with(activityContext).load(new File(uri)).into(mImageView);
}
});
實現(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)//是否裁剪,默認裁剪
.setTextColor(Color.BLUE)
.dimEnabled(true)//背景是否dim 默認true
.setAspect(1, 1)//裁剪比例 默認1:1
.setOutput(200, 200)//裁剪大小 默認200*200
.setText("打開相機", "從相冊中選取", "取消")
.show(new AvatarStudio.CallBack() {
@Override
public void callback(String uri) {
//uri為圖片路徑
valueCallback.onReceiveValue(Uri.parse(uri)); // 將生成的Uri使用valueCallback 回調(diào)給X5底層,實現(xiàn)圖片上傳
}
});
}
......
}
至此,圖片的上傳就實現(xiàn)了。文件的實現(xiàn)也是同理, 大家感興趣的可以試試
以上就是Android 使用騰訊X5瀏覽器上傳圖片的示例的詳細內(nèi)容,更多關(guān)于Android 上傳圖片的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
OpenGL關(guān)于glStencilFuncSeparate()和glStencilFunc()函數(shù)的區(qū)別講解
今天小編就為大家分享一篇OpenGL關(guān)于glStencilFuncSeparate()和glStencilFunc()函數(shù)的區(qū)別講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-04-04
Android Studio提示inotify大小不足的解決辦法
大家在使用Android Studio導入AOSP源碼的時候,可能會遇到inotify大小不足的問題,這篇文章就給大家介紹了怎么解決這個問題的方法,有需要的朋友們可以參考借鑒。2016-09-09
Android編程使用pull方式解析xml格式文件的方法詳解
這篇文章主要介紹了Android編程使用pull方式解析xml格式文件的方法,結(jié)合實例形式分析了Android調(diào)用pull解析器操作xml格式文件的步驟與相關(guān)操作技巧,需要的朋友可以參考下2017-07-07
Android自定義view利用PathEffect實現(xiàn)動態(tài)效果
這篇文章主要為大家詳細介紹了Android自定義view利用PathEffect實現(xiàn)動態(tài)效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-05-05
Android網(wǎng)絡(luò)數(shù)據(jù)開關(guān)用法簡單示例
這篇文章主要介紹了Android網(wǎng)絡(luò)數(shù)據(jù)開關(guān)用法,通過自定義函數(shù)調(diào)用系統(tǒng)服務(wù)實現(xiàn)開關(guān)功能,具有一定參考借鑒價值,需要的朋友可以參考下2016-06-06
Android如何讓WebView中的HTML5頁面實現(xiàn)視頻全屏播放
最近在工作遇到一個需求,需要讓WebView中的HTML5頁面實現(xiàn)視頻全屏播放的效果,通過查找相關(guān)的資料終于找到了解決的方法,所以想著分享給大家,所以本文介紹了關(guān)于Android如何讓WebView中的HTML5頁面實現(xiàn)視頻全屏播放的相關(guān)資料,需要的朋友可以參考學習。2017-04-04
Android drawable微技巧,你不知道的drawable細節(jié)
今天小編就為大家分享一篇關(guān)于Android drawable微技巧,你不知道的drawable細節(jié),小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-10-10
Android使用viewpager實現(xiàn)畫廊式效果
這篇文章主要為大家詳細介紹了Android使用viewpager實現(xiàn)畫廊式效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-08-08

