好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 關于webview適配H5上傳照片或者視頻文件的方法

關于webview適配H5上傳照片或者視頻文件的方法

熱門標簽:高德地圖標注廁所 地圖標注沿海城市房價 通遼地圖標注app 威海語音外呼系統平臺 西安金倫外呼系統 地圖標注員工作內容 智能語音電銷機器人客戶端 中國地圖標注城市的 江西ai電銷機器人如何

一、需要實現的功能:

用H5實現的App中需要在H5獲取手機中的照片或者視頻文件上傳到服務器。

 

二、分析實現方法:

由于不懂前端開發,不知道H5中有 input file之類的標簽控件,可以用來選擇文件,剛開始的思路還是想著native 端是否要通過提供inputstream流方式,將文件內容傳遞給JS。后來和前端溝通之后,H5在電腦端都是用input 設置type為 file 來實現文件選擇功能,于是才開始搜索資料,發現時需要在webview中設置  setWebChromeClient ,其中有對input 的響應回調:

三、具體實現:

前端代碼

<input type="file" accept="*/*" name="choose file">
<input type="file" accept="image/*" name="choose image">
<input type="file" accept="video/*" name="choose video">
<input type="file" accept="image/example" name="take photo and upload image">
<input type="file" accept="video/example" name="take video and upload video">

native端代碼:

@RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
@Override
public boolean onShowFileChooser(WebView webView,
                                 ValueCallback<Uri[]> filePathCallback,
                                 WebChromeClient.FileChooserParams fileChooserParams) {
    mFilePathCallbacks = filePathCallback;
    // TODO: 根據標簽中得接收類型,啟動對應的文件類型選擇器
    String[] acceptTypes = fileChooserParams.getAcceptTypes();
    for (String type : acceptTypes) {
        Log.d(TAG, "acceptTypes=" + type);
    }
    // 針對拍照后馬上進入上傳狀態處理
    if ((acceptTypes.length > 0) && acceptTypes[0].equals("image/example")) {
        Log.d(TAG, "onShowFileChooser takePhoto");
        Intent it = CameraFunction.takePhoto(mContext);
        startActivityForResult(it, TAKE_PHOTO_AND_UPLOAD_REQUEST);
        return true;
    }

    // 針對錄像后馬上進入上傳狀態處理
    if ((acceptTypes.length > 0) && acceptTypes[0].equals("video/example")) {
        Log.d(TAG, "onShowFileChooser record video");
        Intent it = CameraFunction.recordVideo(mContext);
        startActivityForResult(it, RECORD_VIDEO_AND_UPLOAD_REQUEST);
        return true;
    }

    Intent intent = new Intent(Intent.ACTION_GET_CONTENT);
    intent.addCategory(Intent.CATEGORY_OPENABLE);
    if (acceptTypes.length > 0) {
        if (acceptTypes[0].contains("image")) {
            intent.setType("image/*");
        } else if (acceptTypes[0].contains("video")) {
            intent.setType("video/*");
        } else {
            intent.setType("*/*");
        }
    } else {
        intent.setType("*/*");
    }

    WebViewActivity.this.startActivityForResult(Intent.createChooser(intent, "File Chooser"),
            REQUEST_FILE_PICKER);
    return true;
}

回調設置uri

/**
 * 設置input 標簽出發的回調選擇文件路徑,優先使用path參數,
 * 其次使用uri參數
 * @param uriParam
 * @param pathParam
 */
private void setFilePathCallback(Uri uriParam, String pathParam) {
    //都為空,則設置null
    if (uriParam == null && pathParam == null) {
        if (mFilePathCallback != null) {
            mFilePathCallback.onReceiveValue(null);
        }
        if (mFilePathCallbacks != null) {
            mFilePathCallbacks.onReceiveValue(null);
        }
    } else if (null != pathParam) { // 優先使用path
        if (mFilePathCallback != null) {
            Uri uri = Uri.fromFile(new File(pathParam));
            mFilePathCallback.onReceiveValue(uri);
        }
        if (mFilePathCallbacks != null) {
            Uri uri = Uri.fromFile(new File(pathParam));
            mFilePathCallbacks.onReceiveValue(new Uri[] { uri });
        }
    } else if (null != uriParam) { //其次使用uri
        if (mFilePathCallback != null) {
            String path = UriUtils.getPath(getApplicationContext(), uriParam);
            Uri uri = Uri.fromFile(new File(path));
            mFilePathCallback.onReceiveValue(uri);
        }
        if (mFilePathCallbacks != null) {
            String path = UriUtils.getPath(getApplicationContext(), uriParam);
            Uri uri = Uri.fromFile(new File(path));
            mFilePathCallbacks.onReceiveValue(new Uri[] { uri });
        }
    }

    mFilePathCallback = null;
    mFilePathCallbacks = null;

}

針對各個請求場景進行處理:

public void onActivityResult(int requestCode, int resultCode, Intent intent) {

總結:既然用H5開發APP,就需要了解前端,不懂就要問了。查詢方向要對,否則南轅北轍,方向有時候比努力重要!

到此這篇關于關于webview適配H5上傳照片或者視頻文件的方法的文章就介紹到這了,更多相關webview適配H5上傳照片內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章,希望大家以后多多支持腳本之家!

標簽:眉山 北海 營口 阜陽 河池 青海 晉中 崇左

巨人網絡通訊聲明:本文標題《關于webview適配H5上傳照片或者視頻文件的方法》,本文關鍵詞  關于,webview,適配,上傳,照片,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《關于webview適配H5上傳照片或者視頻文件的方法》相關的同類信息!
  • 本頁收集關于關于webview適配H5上傳照片或者視頻文件的方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 操美女的逼逼| S货叫大声点C懒烂你的SBXS| 欧美性白人极品1819hd高清| 成人性生交大免费看喜爱夜蒲| 诱子偷伦初尝云雨小说| 天天性视频| 美女张开腿让男人桶| 黄色在线观看视频免费| 人妻 丝袜美腿 中文字幕| 欧美午夜精品久久久久久浪潮| 女同精品| 唐宫艳史120分未删减版| 国产成人精品三上悠亚久久 | 福利深夜小视频秒拍微拍| 久久综合这里只有精品| 丰满老熟妇好大BBBBB四p| 韩国三级bd高清中禁止的爱字| yy6080影视| 汤唯被实干20分钟无删减版| jiZZjiZZ日本老师水多| 和拘做受又硬又粗又大的视频 | 女人毛毛扒开自慰| 一点睡六点起顺口溜| 古装一级毛片免费观看| 亚洲永久无码7777kkkk| 三个黑人强欧洲金发女人| 久久理论片午夜琪琪电影网| 免费无码又爽又刺激A片软件妖精 成人做爰高潮片免费看直播蜜臀 国产做受???高潮91按摩 | 国产精品无码亚洲精品传媒| 欧美成人精品aV在线观看图图破 | 欧美护士激情第一欧美精品| 好男人在线社区www影视下载| 中文在线日韩| 007韩国在线观看视频| 99久久久久久久无码| 小小水蜜桃3[电视剧]在线观看| 男人插女人阴道的视频| 女脱男生内裤摸j的视频| 岳潮湿的大肥| 小受扒开腿狂躁c到高潮网站| 国产美女网|