android系統(tǒng)webview使用input實現(xiàn)選擇圖片并預(yù)覽

一般系統(tǒng)的實現(xiàn)方式:

  • 代碼實現(xiàn)
<!doctype html>
<html>

<head>
    <meta charset="utf-8">
    <title>圖片預(yù)覽</title>
    <script src="https://libs.baidu.com/jquery/1.11.3/jquery.min.js"></script>

</head>

<body>
    <p>
        <img class="img" width="100" height="100" id="previewimg">
    </p>
    <input class="select" type="file" id="picfile">

    <script>
        $('.select').change(function(e) {
            var _URL = window.URL || window.webkitURL;
            $("#previewimg").attr("src", _URL.createObjectURL(this.files[0]))
        })
    </script>

</body>

</html>
  • input type="file"就是文件選擇標(biāo)簽成福,默認(rèn)樣式為:


  • 如果不喜歡默認(rèn)樣式宜狐,可以把它設(shè)置為透明屠列,然后自己用圖片或元素覆蓋它弱睦,這時候他仍然能響應(yīng)點(diǎn)擊:

opacity: 0;
  • multiple="multiple" 屬性可以讓input一次選擇多個文件
  • 注冊change監(jiān)聽或定義onChange方法可以在選擇完圖片后回調(diào)踪央,回調(diào)中使用files數(shù)組屬性來獲取選擇的文件臀玄,如果是選擇單文件,files[0]表示選擇的圖片
  • jquery回調(diào)中畅蹂,this會自動指向當(dāng)前操作的元素健无,例子中的this和getElementById("picfile")相對,如果要使用jquery方法液斜,可以用$(this)
  • oninput事件在元素值發(fā)生變化時立即觸發(fā)累贤, onchange在元素失去焦點(diǎn)時觸發(fā)叠穆,如果是輸入文字,oninput在輸入過程中一直回調(diào)(輸入或刪除一個文字就會調(diào)用一次)畦浓,onchange在輸入完成痹束,點(diǎn)擊其他地方調(diào)用。
  • createObjectURL把file對象轉(zhuǎn)為url讓img標(biāo)簽顯示

android系統(tǒng)的實現(xiàn)

安卓webview系統(tǒng)無法通過input打開系統(tǒng)選擇文件框讶请,必須在原生里面攔截webview事件祷嘶,選擇完文件,處理相關(guān)邏輯(比如上傳文件到oss)后回調(diào)到webview

wvmain.setWebChromeClient(new WebChromeClient(){

            //For Android  >= 5.0
            @Override
            public boolean onShowFileChooser(WebView webView, ValueCallback<Uri[]> filePathCallback, FileChooserParams fileChooserParams) {

                uploadMessageAboveL = filePathCallback;
                uploadPicture();
                return true;
            }


            //For Android  >= 4.1
            public void openFileChooser(ValueCallback<Uri> valueCallback, String acceptType, String capture) {
                uploadMessage = valueCallback;
                uploadPicture();
            }
        });
  • android依靠uploadMessageAboveL/uploadMessage回調(diào)向webview回傳圖片uri等信息
  • android在uploadPicture里調(diào)用原生方法彈出原生圖片選擇框夺溢,點(diǎn)擊選擇圖片后论巍,得到所選擇的圖片uri,上傳到oss
  • 處理完文件上傳后风响,調(diào)用Callback(valueCallback 或 filePathCallback)的onReceiveValue方法嘉汰,webview里的input標(biāo)簽才會調(diào)用onchange
    比如以下是選擇完文件后,上傳文件到oss成功后的回調(diào)里状勤,如果成功得到oss圖片地址鞋怀,則調(diào)用onReceiveValue方法把圖片的本地uri回傳給webview,失敗或異常情況回傳null給webview
public void successImg(String img_url) {

                            if (img_url != null){
                                curPicUrl = img_url;
                                mHandle.sendEmptyMessage(UPLOAD_SUCESS);
                                if (uploadMessage != null) {
                                    uploadMessage.onReceiveValue(imageUri);
                                    uploadMessage = null;
                                }
                                if (uploadMessageAboveL != null) {
                                    uploadMessageAboveL.onReceiveValue(new Uri[]{imageUri});
                                    uploadMessageAboveL = null;
                                }
                            }else{
                                curPicUrl = "";
                                mHandle.sendEmptyMessage(UPLOAD_FAIL);
                                if (uploadMessage != null) {
                                    uploadMessage.onReceiveValue(null);
                                    uploadMessage = null;
                                }
                                if (uploadMessageAboveL != null) {
                                    uploadMessageAboveL.onReceiveValue(null);
                                    uploadMessageAboveL = null;

                                }
                            }
                        }
  • 如果回傳null給webview持搜,如果input里面之前還沒有文件密似, input的onchange,oninput方法不會調(diào)用葫盼,如果之前已經(jīng)選擇過文件残腌,files對象之前里面有內(nèi)容,現(xiàn)在內(nèi)容會變成空贫导,發(fā)生了改變,onchange抛猫,oninput方法都會調(diào)用(先調(diào)用oninput),但是files對象的長度為0孩灯,可以根據(jù)files的長度來做不同的處理闺金,比如:
doChange() {
      var file = document.getElementById("fileInput");
      if(file.files.length == 0){//清除之前的圖片
        document.getElementById("showpic" + i).style.display = "none";
        return;
      }else{
        //顯示圖片預(yù)覽
}
      
    }
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市钱反,隨后出現(xiàn)的幾起案子掖看,更是在濱河造成了極大的恐慌,老刑警劉巖面哥,帶你破解...
    沈念sama閱讀 216,544評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件哎壳,死亡現(xiàn)場離奇詭異,居然都是意外死亡尚卫,警方通過查閱死者的電腦和手機(jī)归榕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來吱涉,“玉大人刹泄,你說我怎么就攤上這事外里。” “怎么了特石?”我有些...
    開封第一講書人閱讀 162,764評論 0 353
  • 文/不壞的土叔 我叫張陵盅蝗,是天一觀的道長。 經(jīng)常有香客問我姆蘸,道長墩莫,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,193評論 1 292
  • 正文 為了忘掉前任逞敷,我火速辦了婚禮狂秦,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘推捐。我一直安慰自己裂问,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,216評論 6 388
  • 文/花漫 我一把揭開白布牛柒。 她就那樣靜靜地躺著堪簿,像睡著了一般。 火紅的嫁衣襯著肌膚如雪皮壁。 梳的紋絲不亂的頭發(fā)上戴甩,一...
    開封第一講書人閱讀 51,182評論 1 299
  • 那天,我揣著相機(jī)與錄音闪彼,去河邊找鬼。 笑死协饲,一個胖子當(dāng)著我的面吹牛畏腕,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播茉稠,決...
    沈念sama閱讀 40,063評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼描馅,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了而线?” 一聲冷哼從身側(cè)響起铭污,我...
    開封第一講書人閱讀 38,917評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎膀篮,沒想到半個月后嘹狞,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,329評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡誓竿,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,543評論 2 332
  • 正文 我和宋清朗相戀三年磅网,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片筷屡。...
    茶點(diǎn)故事閱讀 39,722評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡涧偷,死狀恐怖簸喂,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情燎潮,我是刑警寧澤喻鳄,帶...
    沈念sama閱讀 35,425評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站确封,受9級特大地震影響除呵,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜隅肥,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,019評論 3 326
  • 文/蒙蒙 一竿奏、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧腥放,春花似錦泛啸、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至种柑,卻和暖如春岗仑,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背聚请。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評論 1 269
  • 我被黑心中介騙來泰國打工荠雕, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人驶赏。 一個月前我還...
    沈念sama閱讀 47,729評論 2 368
  • 正文 我出身青樓炸卑,卻偏偏與公主長得像,于是被迫代替她去往敵國和親煤傍。 傳聞我的和親對象是個殘疾皇子盖文,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,614評論 2 353

推薦閱讀更多精彩內(nèi)容

  • 不知不覺,Hybird App已經(jīng)成了目前比較主流的一種開發(fā)方式蚯姆。 對于用戶體驗要求較高或者與硬件交互較多的功能我...
    香辣牛肉面閱讀 10,214評論 3 89
  • 一五续、WebView 谷歌提供的系統(tǒng)組件,用來加載和展現(xiàn)html網(wǎng)頁龄恋,其采用webkit內(nèi)核驅(qū)動疙驾,來實現(xiàn)網(wǎng)頁瀏覽功能...
    閑庭閱讀 6,949評論 2 12
  • Swift1> Swift和OC的區(qū)別1.1> Swift沒有地址/指針的概念1.2> 泛型1.3> 類型嚴(yán)謹(jǐn) 對...
    cosWriter閱讀 11,097評論 1 32
  • 轉(zhuǎn)自 http://www.reibang.com/p/3ad7c39858ec 不知不覺,Hybird App已...
    龐哈哈哈12138閱讀 3,890評論 0 9
  • 單例模式 適用場景:可能會在場景中使用到對象郭毕,但只有一個實例荆萤,加載時并不主動創(chuàng)建,需要時才創(chuàng)建 最常見的單例模式,...
    Obeing閱讀 2,065評論 1 10