栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 移动开发 > Android

Android WebView支持input file启用相机/选取照片功能

Android 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Android WebView支持input file启用相机/选取照片功能

webview要调起input-file拍照或者选取文件功能,可以在webview.setWebChromeClient方法中重写指定的方法,来拦截webview的input事件,并做我们相应的操作。

Android代码

webView.setWebChromeClient(new WebChromeClient() {
      @Override
      public void onProgressChanged(WebView view, int newProgress) {
 if (newProgress == 100) {
   progressBar.setVisibility(View.GONE);//加载完网页进度条消失
 } else {
   progressBar.setProgress(newProgress);//设置进度值
   progressBar.setVisibility(View.VISIBLE);//开始加载网页时显示进度条
 }
      }
 
      
      private void openFileChooser(android.webkit.ValueCallback uploadMsg) {
 Log.e("WangJ", "运行方法 openFileChooser-1");
 // (2)该方法回调时说明版本API < 21,此时将结果赋值给 mUploadCallbackBelow,使之 != null
 mUploadCallbackBelow = uploadMsg;
 takePhoto();
      }
 
      
      public void openFileChooser(android.webkit.ValueCallback uploadMsg, String acceptType) {
 Log.e("WangJ", "运行方法 openFileChooser-2 (acceptType: " + acceptType + ")");
 // 这里我们就不区分input的参数了,直接用拍照
 openFileChooser(uploadMsg);
      }
 
      
      public void openFileChooser(android.webkit.ValueCallback uploadMsg, String acceptType, String capture) {
 Log.e("WangJ", "运行方法 openFileChooser-3 (acceptType: " + acceptType + "; capture: " + capture + ")");
 // 这里我们就不区分input的参数了,直接用拍照
 openFileChooser(uploadMsg);
      }
 
      
      @Override
      public boolean onShowFileChooser(WebView webView, ValueCallback valueCallback, FileChooserParams fileChooserParams) {
 Log.e("WangJ", "运行方法 onShowFileChooser");
 // (1)该方法回调时说明版本API >= 21,此时将结果赋值给 mUploadCallbackAboveL,使之 != null
 mUploadCallbackAboveL = valueCallback;
 takePhoto();
 return true;
      }
    });

这里的java代码是来拦截input事件的,里面做了很多api版本的判断,不同版本的api调用不同的方法,下面是一些其他方法:

调起相机/选择文件的方法:takePhoto();

 
  private void takePhoto() {
    // 指定拍照存储位置的方式调起相机
    String filePath = Environment.getExternalStorageDirectory() + File.separator
 + Environment.DIRECTORY_PICTURES + File.separator;
    String fileName = "IMG_" + DateFormat.format("yyyyMMdd_hhmmss", Calendar.getInstance(Locale.CHINA)) + ".jpg";
    imageUri = Uri.fromFile(new File(filePath + fileName));
 
//    Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
//    intent.putExtra(MediaStore.EXTRA_OUTPUT, imageUri);
//    startActivityForResult(intent, REQUEST_CODE);
 
    // 选择图片(不包括相机拍照),则不用成功后发刷新图库的广播
//    Intent i = new Intent(Intent.ACTION_GET_CONTENT);
//    i.addCategory(Intent.CATEGORY_OPENABLE);
//    i.setType("image
  private void chooseBelow(int resultCode, Intent data) {
    Log.e("WangJ", "返回调用方法--chooseBelow");
 
    if (RESULT_OK == resultCode) {
      updatePhotos();
 
      if (data != null) {
 // 这里是针对文件路径处理
 Uri uri = data.getData();
 if (uri != null) {
   Log.e("WangJ", "系统返回URI:" + uri.toString());
   mUploadCallbackBelow.onReceivevalue(uri);
 } else {
   mUploadCallbackBelow.onReceivevalue(null);
 }
      } else {
 // 以指定图像存储路径的方式调起相机,成功后返回data为空
 Log.e("WangJ", "自定义结果:" + imageUri.toString());
 mUploadCallbackBelow.onReceivevalue(imageUri);
      }
    } else {
      mUploadCallbackBelow.onReceivevalue(null);
    }
    mUploadCallbackBelow = null;
  }
 
  
  private void chooseAbove(int resultCode, Intent data) {
    Log.e("WangJ", "返回调用方法--chooseAbove");
 
    if (RESULT_OK == resultCode) {
      updatePhotos();
 
      if (data != null) {
 // 这里是针对从文件中选图片的处理
 Uri[] results;
 Uri uriData = data.getData();
 if (uriData != null) {
   results = new Uri[]{uriData};
   for (Uri uri : results) {
     Log.e("WangJ", "系统返回URI:" + uri.toString());
   }
   mUploadCallbackAboveL.onReceivevalue(results);
 } else {
   mUploadCallbackAboveL.onReceivevalue(null);
 }
      } else {
 Log.e("WangJ", "自定义结果:" + imageUri.toString());
 mUploadCallbackAboveL.onReceivevalue(new Uri[]{imageUri});
      }
    } else {
      mUploadCallbackAboveL.onReceivevalue(null);
    }
    mUploadCallbackAboveL = null;
  }
 
  private void updatePhotos() {
    // 该广播即使多发(即选取照片成功时也发送)也没有关系,只是唤醒系统刷新媒体文件
    Intent intent = new Intent(Intent.ACTION_MEDIA_SCANNER_SCAN_FILE);
    intent.setData(imageUri);
    sendBroadcast(intent);
  }

相关的全局变量:

private android.webkit.ValueCallback mUploadCallbackAboveL;
private android.webkit.ValueCallback mUploadCallbackBelow;
private Uri imageUri;
private int REQUEST_CODE = 1234;

总结

以上所述是小编给大家介绍的Android WebView支持input file启用相机/选取照片功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对考高分网网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/154811.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号