Android Webview解决input事件

原创 2016年05月30日 10:42:52

webview调用input上传图片,记录下来

private ValueCallback<Uri> mUploadMessage;
private ValueCallback<Uri[]> mUploadCallbackAboveL;


private final static int FILECHOOSER_RESULTCODE = 1;


@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_web);


    initUI();
    initAV();
    setWebView();
}


private void initUI() {
    top_title_tv = (TextView) findViewById(R.id.top_title_tv);
    top_left_iv = (ImageView) findViewById(R.id.top_left_iv);
    webView = (WebView) findViewById(R.id.web);
    myProgressBar = (ProgressBar) findViewById(R.id.myProgressBar);
}




private void initAV() {
    Intent i = getIntent();
    String title = i.getStringExtra("title");
    url = i.getStringExtra("url");
    top_title_tv.setText(title);
    top_left_iv.setBackgroundResource(R.drawable.back);
    top_left_iv.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            finish();
        }
    });
}


private void setWebView() {
    WebSettings ws = webView.getSettings();
    ws.setBuiltInZoomControls(true);


    ws.setDatabaseEnabled(true);
    String dir = this.getApplicationContext().getDir("database", Context.MODE_PRIVATE).getPath();
    //设置数据库路径
    ws.setDatabasePath(dir);


    ws.setUseWideViewPort(true);
    ws.setLoadWithOverviewMode(true);
    ws.setAllowFileAccess(true);//允许访问文件数据
    ws.setSaveFormData(true);
    ws.setJavaScriptEnabled(true);


    ws.setDefaultTextEncodingName("UTF-8");
    ws.setSupportZoom(true);
    ws.supportMultipleWindows();


    //启用地理定位
    ws.setGeolocationEnabled(true);
    ws.setDomStorageEnabled(true);
    ws.setSupportMultipleWindows(true);
    //webView.setWebViewClient(new WebViewClient());
    webView.setWebViewClient(new WebViewClient() {
        public boolean shouldOverrideUrlLoading(WebView view, String url) {
            view.loadUrl(url);
            return true;
        }


        public void onPageFinished(WebView view, String url) {
            super.onPageFinished(view, url);
        }


        public void onPageStarted(WebView view, String url, Bitmap favicon) {
            super.onPageStarted(view, url, favicon);
        }
    });




    webView.setWebChromeClient(new WebChromeClient(){
        // For Android 3.0+
        public void openFileChooser(ValueCallback<Uri> uploadMsg) {
            Log.e(TAG, "openFileChoose(ValueCallback<Uri> uploadMsg)");
            mUploadMessage = uploadMsg;
            Intent i = new Intent(Intent.ACTION_GET_CONTENT);
            i.addCategory(Intent.CATEGORY_OPENABLE);
            i.setType("*/*");
            Web.this.startActivityForResult(Intent.createChooser(i, "File Chooser"), FILECHOOSER_RESULTCODE);
        }


        // For Android 3.0+
        public void openFileChooser( ValueCallback uploadMsg, String acceptType ) {
            Log.e(TAG, "openFileChoose( ValueCallback uploadMsg, String acceptType )");
            mUploadMessage = uploadMsg;
            Intent i = new Intent(Intent.ACTION_GET_CONTENT);
            i.addCategory(Intent.CATEGORY_OPENABLE);
            i.setType("*/*");
            Web.this.startActivityForResult(
                    Intent.createChooser(i, "File Browser"),
                    FILECHOOSER_RESULTCODE);
        }
        //For Android 4.1
        public void openFileChooser(ValueCallback<Uri> uploadMsg, String acceptType, String capture){
            Log.e(TAG, "4.1 openFileChoose(ValueCallback<Uri> uploadMsg, String acceptType, String capture)");
            mUploadMessage = uploadMsg;
            Intent i = new Intent(Intent.ACTION_GET_CONTENT);
            i.addCategory(Intent.CATEGORY_OPENABLE);
            i.setType("*/*");
            Web.this.startActivityForResult( Intent.createChooser( i, "File Browser" ), Web.FILECHOOSER_RESULTCODE );
        }
        // For Android 5.0+


        public boolean onShowFileChooser (WebView webView, ValueCallback<Uri[]> filePathCallback, WebChromeClient.FileChooserParams fileChooserParams) {
            Log.e(TAG, "5.0 onShowFileChooser(ValueCallback<Uri> uploadMsg, String acceptType, String capture)");
            mUploadCallbackAboveL = filePathCallback;
            Intent i = new Intent(Intent.ACTION_GET_CONTENT);
            i.addCategory(Intent.CATEGORY_OPENABLE);
            i.setType("*/*");
            Web.this.startActivityForResult(
                    Intent.createChooser(i, "File Browser"),
                    FILECHOOSER_RESULTCODE);
            return true;
        }
    });
    // String url="http://v.youku.com/v_show/id_XMTUzMjUwOTc2MA==_ev_1.html";
    webView.loadUrl(url);
}


@Override
protected void onResume() {
    super.onResume();
    webView.onResume();
//有的5.0的机型只显示一次选择图片的对话框  解决办法是加上这句
    if(mUploadCallbackAboveL!=null){
        mUploadCallbackAboveL.onReceiveValue(null);
    }
}


@Override
protected void onPause() {
    super.onPause();
    webView.onPause();
}


@Override
protected void onDestroy() {
    super.onDestroy();
    webView = null;
}


@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
    /**
     * 这里监控的是物理返回或者设置了该接口的点击事件
     * 当按钮事件为返回时,且WebView可以返回,即触发返回事件
     */
    if (keyCode == KeyEvent.KEYCODE_BACK) {
        if( webView.canGoBack())
        webView.goBack(); // goBack()表示返回WebView的上一页面
        else
        Web.this.finish();
        return true; // 返回true拦截事件的传递
    }
    return false;
}


@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) {
            mUploadMessage.onReceiveValue(result);
            mUploadMessage = null;
        }
    }
}


@TargetApi(Build.VERSION_CODES.JELLY_BEAN)
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) {


        } 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)};
        }
    }
    mUploadCallbackAboveL.onReceiveValue(results);
    mUploadCallbackAboveL = null;
    return;
}
版权声明:本文为博主原创文章,未经博主允许不得转载。

android Webview支持input type=file

http://david-wei.github.io/2015/07/07/Webview-%E6%94%AF%E6%8C%81-input-type-file/ 在一个带有input tpye=...
  • earbao
  • earbao
  • 2016年02月22日 14:41
  • 9884

Android WebView 不支持 H5 input type="file" 解决方法

最近因为赶项目进度,因此将本来要用原生控件实现的界面,自己做了H5并嵌入webview中。发现点击H5中 标签 不能打开android资源管理器。 通过网络搜索发现是因为 android webvie...
  • hvkCoder
  • hvkCoder
  • 2016年05月10日 17:43
  • 12550

android webview input 弹出软键盘

android的webview如果需要让其自动弹出软键盘,需要将input元素获取焦点 document.getElementById("txt").focus() 然后js调用后台java方法 ...
  • Sky_Cat
  • Sky_Cat
  • 2016年12月19日 15:33
  • 1711

处理android手机html5页面中,点击text文本框无法自动获取焦点的处理方法

当我们使用了jQuery 这样$(”#name”) 返回的就不是DOM对象了而是jQuery对象,这样的话$(”#name”).focus()这个方法的意义也就变了,并不是使这个文本框获 得焦点 而是...
  • shipeng22022
  • shipeng22022
  • 2015年04月29日 09:32
  • 8187

【Android进阶】Android里webview不支持input file的解决方法(上传按钮点击失效的原因)

三星、华为等android里webview不支持input file的解决方法 原文地址:http://camnpr.com/archives/1093.html 由于安全因素android web...
  • dodod2012
  • dodod2012
  • 2016年03月09日 14:10
  • 7029

Android解决全屏下WebView中输入框被键盘遮挡

Android解决全屏下WebView中输入框被键盘遮挡 最近项目遇到了webView中使用输入框,但是输入框被遮挡的问题,于是上网百度了一下,发现大多数的解决方式无非两种,一种是代码编辑,另一种是配...
  • qiuyin2015
  • qiuyin2015
  • 2016年11月14日 10:45
  • 2967

完美解决 Android WebView 文本框获取焦点后自动放大问题

完美解决 Android WebView 文本框获取焦点后自动放大问题
  • aa1000777
  • aa1000777
  • 2015年04月17日 10:04
  • 3701

Android webview Input type=file 文件上传 解决方法

默认的情况下在HTML中 写 的时候回弹出选择文件的窗口,但实际上在webview中默认的是不弹出窗口的 解决方法 在WebChromeClient中增加一些方法: webView.set...
  • u010615629
  • u010615629
  • 2017年05月13日 14:35
  • 328

Android WebView 不支持 H5 input type="file" 解决方法

最近因为赶项目进度,因此将本来要用原生控件实现的界面,自己做了H5并嵌入webview中。发现点击H5中 标签 不能打开android资源管理器。 通过网络搜索发现是因为 android webvie...
  • hvkCoder
  • hvkCoder
  • 2016年05月10日 17:43
  • 12550

android input 事件的获取

  • 2013年01月06日 13:00
  • 184KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Android Webview解决input事件
举报原因:
原因补充:

(最多只允许输入30个字)