Androoid WebView加载html调用手机拍照和相册
2017-03-31 11:06
423 查看
最近两篇都是关于WebView的,以前就觉得WebView很坑,存在各种问题,所以特别讨厌使用WebView,但是最近因为公司项目需求,不得不使用了。今天说的是WebView加载的网页中点击按钮可以调用手机相册和拍照的功能。因为WebView本身是没有这个权限的,所以需要你重写其中的方法,下面是代码:
但是有一个问题还没与解决,就是Android4.4的手机还是不能够调用,如果有人知道,请告诉我,在此谢过
public class MainActivity extends AppCompatActivity { private WebView mWebView; private String path="http://123.56.64.244:8082/hgjl.admin/timeline/time.html?customerid=166"; private ValueCallback<Uri> mUploadMessage;// 表单的数据信息 private ValueCallback<Uri[]> mUploadCallbackAboveL; private final static int FILECHOOSER_RESULTCODE = 1;// 表单的结果回调</span> private Uri imageUri; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mWebView = (WebView) findViewById(R.id.web); mWebView.loadUrl(path); mWebView.getSettings().setJavaScriptEnabled(true); mWebView.getSettings().setRenderPriority(WebSettings.RenderPriority.HIGH); WebSettings settings = mWebView.getSettings(); settings.setUseWideViewPort(true); settings.setLoadWithOverviewMode(true); settings.setJavaScriptEnabled(true); settings.setSupportZoom(true); mWebView.setWebViewClient(new WebViewClient() { @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { // TODO Auto-generated method stub return super.shouldOverrideUrlLoading(view, url); } @Override public void onPageStarted(WebView view, String url, Bitmap favicon) { // TODO Auto-generated method stub super.onPageStarted(view, url, favicon); } @Override public void onPageFinished(WebView view, String url) { // TODO Auto-generated method stub super.onPageFinished(view, url); } }); mWebView.setWebChromeClient(new WebChromeClient() { @Override public boolean onShowFileChooser(WebView webView, ValueCallback<Uri[]> filePathCallback, FileChooserParams fileChooserParams) { mUploadCallbackAboveL = filePathCallback; takePhoto(); return true; } public void openFileChooser(ValueCallback<Uri> uploadMsg) { mUploadMessage = uploadMsg; takePhoto(); } public void openFileChooser(ValueCallback<Uri> uploadMsg, String acceptType) { mUploadMessage = uploadMsg; takePhoto(); } public void openFileChooser(ValueCallback<Uri> uploadMsg, String acceptType, String capture) { mUploadMessage = uploadMsg; takePhoto(); } }); } @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { super.onActivityResult(requestCode, resultCode, data); if (requestCode == FILECHOOSER_RESULTCODE) { if (null == mUploadMessage && null == mUploadCallbackAboveL) return; Uri result = data == null || resultCode != RESULT_OK ? null : data.getData(); if (mUploadCallbackAboveL != null) { onActivityResultAboveL(requestCode, resultCode, data); } else if (mUploadMessage != null) { Log.e("Mr.Kang", "onActivityResult: "+result); if (result == null) { mUploadMessage.onReceiveValue(imageUri); mUploadMessage = null; Log.e("Mr.Kang", "onActivityResult: "+imageUri); } else { mUploadMessage.onReceiveValue(result); mUploadMessage = null; } } } } @SuppressWarnings("null") @TargetApi(Build.VERSION_CODES.LOLLIPOP) private void onActivityResultAboveL(int requestCode, int resultCode, Intent data) { if (requestCode != FILECHOOSER_RESULTCODE || mUploadCallbackAboveL == null) { return; } Uri[] results = null; if (resultCode == Activity.RESULT_OK) { if (data == null) { results = new Uri[]{imageUri}; } else { String dataString = data.getDataString(); ClipData clipData = data.getClipData(); if (clipData != null) { results = new Uri[clipData.getItemCount()]; for (int i = 0; i < clipData.getItemCount(); i++) { ClipData.Item item = clipData.getItemAt(i); results[i] = item.getUri(); } } if (dataString != null) results = new Uri[]{Uri.parse(dataString)}; } } if (results != null) { mUploadCallbackAboveL.onReceiveValue(results); mUploadCallbackAboveL = null; } else { results = new Uri[]{imageUri}; mUploadCallbackAboveL.onReceiveValue(results); mUploadCallbackAboveL = null; } return; } private void takePhoto() { File imageStorageDir = new File(Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_PICTURES), "MyApp"); // Create the storage directory if it does not exist if (!imageStorageDir.exists()) { imageStorageDir.mkdirs(); } File file = new File(imageStorageDir + File.separator + "IMG_" + String.valueOf(System.currentTimeMillis()) + ".jpg"); imageUri = Uri.fromFile(file); final List<Intent> cameraIntents = new ArrayList<Intent>(); final Intent captureIntent = new Intent(android.provider.MediaStore.ACTION_IMAGE_CAPTURE); final PackageManager packageManager = getPackageManager(); final List<ResolveInfo> listCam = packageManager.queryIntentActivities(captureIntent, 0); for (ResolveInfo res : listCam) { final String packageName = res.activityInfo.packageName; final Intent i = new Intent(captureIntent); i.setComponent(new ComponentName(res.activityInfo.packageName, res.activityInfo.name)); i.setPackage(packageName); i.putExtra(MediaStore.EXTRA_OUTPUT, imageUri); cameraIntents.add(i); } Intent i = new Intent(Intent.ACTION_GET_CONTENT); i.addCategory(Intent.CATEGORY_OPENABLE); i.setType("image/*"); Intent chooserIntent = Intent.createChooser(i, "Image Chooser"); chooserIntent.putExtra(Intent.EXTRA_INITIAL_INTENTS, cameraIntents.toArray(new Parcelable[]{})); MainActivity.this.startActivityForResult(chooserIntent, FILECHOOSER_RESULTCODE); } }
但是有一个问题还没与解决,就是Android4.4的手机还是不能够调用,如果有人知道,请告诉我,在此谢过
相关文章推荐
- android使用WebView加载html input标签调用手机相机相册 后添加扫码功能
- iOS模态跳转的页面WebView中加载html调用本机相册会dismiss返回上一个页面解决办法
- WebView中调用系统相册或拍照上传
- WebView加载html代码,js脚本中调用android对象的方法...
- iOS 加载HTML的相关问题(与JS的互相调用和WKWebView加载本地网页)
- Android WebView 选择图片并上传(调用相机拍照/相册/选择文件)
- iOS webView加载本地html 调用 js,css (基本使用)
- WebView和加载html页面时无法调用alert的解决办法
- android webview加载html图片自适应手机屏幕大小&点击查看大图
- web调用手机相册和拍照
- webview 调用相册和拍照功能,100分求
- android webview加载html图片自适应手机屏幕大小&点击查看大图
- webview之加载H5界面无法调用手机本地图库
- android webview加载html图片自适应手机屏幕大小&点击查看大图
- WebView加载html实现网页上传本地文件(图片,拍照,语音等)
- webview加载html调用js
- webView显示html到Js调用手机功能到Base64的方式将数据返回到Html中
- uiwebview加载html页面调用相册、拍照无法选择的问题
- Android的WebView加载的Html输入框被手机键盘挡住解决
- Webview--如何让加载进来的页面自适应手机屏幕分辨率居中显示