最近项目中用到安卓原生APP 嵌套H5网页,使用安卓原生WebView实现,本来是需要我们通过协议调取系统相册完成选择图片和上传图片的,后来发现H5可以自己调用,就交给了H5,但是还是需要我们这边支持,因为他们在做的过程中发现,H5在网页可以自己调用,但是嵌套到App里面点了按钮没有任何反应,介于目前手机系统都很高了,我这边就不说3.0版本的兼容了,直接说5.0的;具体代码如下:
private ValueCallback<Uri> valueCallback;
private ValueCallback<Uri[]> valueCallbackArray;
private final int REQUEST_CODE = 0x1010;
private final static int RESULT_CODE = 0x1011;
@RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
@Override
public boolean onShowFileChooser(WebView webView, ValueCallback<Uri[]> filePathCallback, FileChooserParams fileChooserParams) {
if (valueCallbackArray != null) {
valueCallbackArray.onReceiveValue(null);
valueCallbackArray = null;
}
valueCallbackArray = filePathCallback;
Intent intent = fileChooserParams.createIntent();
try {
startActivityForResult(intent, REQUEST_CODE);
} catch (Exception e) {
valueCallbackArray = null;
return false;
}
return true;
}
});
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent intent) {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
if (requestCode == REQUEST_CODE) {
if (valueCallbackArray == null)
return;
valueCallbackArray.onReceiveValue(WebChromeClient.FileChooserParams.parseResult(resultCode, intent));
valueCallbackArray = null;
}
} else if (requestCode == RESULT_CODE) {
if (null == valueCallback)
return;
Uri result = intent == null || resultCode != RESULT_OK ? null : intent.getData();
valueCallback.onReceiveValue(result);
valueCallback = null;
}
}
当然webview的一些基本设置还是要全部加上的,这里我也把代码贴下吧
settings.setUserAgentString(userAgent);
settings.setDatabaseEnabled(true);
settings.setGeolocationEnabled(true);
settings.setDomStorageEnabled(true);//设置可以使用localStorage
settings.setAppCacheEnabled(true);//设置H5的缓存打开,默认关闭
settings.setAppCachePath(ConstantsData.DEFAULT_WEBVIEW_CACHE_FOLDER);// 把内部私有缓存目录'/data/data/包名/cache/'作为WebView的AppCache的存储路径
settings.setAppCacheMaxSize(5 * 1024 * 1024);
settings.setAllowFileAccess(true);
settings.setJavaScriptEnabled(true);
settings.setLoadWithOverviewMode(true);//设置webView自适应屏幕大小
settings.setBuiltInZoomControls(true);//关闭zoom
settings.setDisplayZoomControls(false);
settings.setSupportZoom(true);//关闭zoom按钮
settings.setRenderPriority(WebSettings.RenderPriority.LOW);
settings.setBlockNetworkImage(true);
settings.setDatabasePath(ConstantsData.DEFAULT_WEBVIEW_CACHE_FOLDER);// API 19
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN) {
settings.setAllowFileAccessFromFileURLs(true);
settings.setAllowUniversalAccessFromFileURLs(true);
}
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
WebView.setWebContentsDebuggingEnabled(true);
}
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
settings.setMixedContentMode(WebSettings.LOAD_NORMAL);
}
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
settings.setUseWideViewPort(true);
} else {
settings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.SINGLE_COLUMN);
}
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN_MR1) {
settings.setMediaPlaybackRequiresUserGesture(false);
}
if (android.os.Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
CookieManager.getInstance().setAcceptThirdPartyCookies(this, true);
}
希望能帮助到大家