MUI+Hbuilder之图片上传(六)

document.getElementById("uploadImg").addEventListener("tap", function() {
                var editButtons = new Array();
                if(vm.uploadImgArr.length < 9) {
                    editButtons.push({
                        title: "拍照上传",
                        style: "default"
                    });
                    editButtons.push({
                        title: "从相册选择",
                        style: "default"
                    });
                    plus.nativeUI.actionSheet({
                        cancel: "取消",
                        buttons: editButtons
                    }, function(e) {
                        var index = e.index;
                        switch(index) {
                            case 1:
                                captureImage(); //拍照
                                break;
                            case 2:
                                selectImage(); //相册选择
                                break;
                        }
                    });

                } else {
                    mui.toast("最大允许上传九张图片");
                }

            });

            //选择图片
            function selectImage() {
                plus.gallery.pick(function(path) {
                    //设置最大只能上传9张图片
                    var canUploadLength=9-vm.uploadImgUrlArr.length;
                    if(canUploadLength < path.files.length){
                        mui.toast("最大允许上传九张图片");
                        return false;
                    } 
                    loadImage(path);
                }, function(e) {
                    mui.toast("没有选择图片");
                }, {
                    filter: 'image',
                    multiple: true,
                    system: false
                });
            }
            //确定选择图片
            function loadImage(path) {
                if(typeof path == 'string') {
                    vm.uploadImgArr.push({
                        "status": 0,
                        "url": path
                    });
                    uploadPicture(path);
                } else {
                    path.files.forEach(function(v, k) {
                        vm.uploadImgArr.push({
                            "status": 0,
                            "url": v
                        });
                    });
                    uploadPicture();
                }
            }

            //上传图片 
            function uploadPicture() {
                vm.uploadImgArr.forEach(function(v, k) {
                    if(v.status == '0') {
                        vm.uploadImgArr[k].status=2;
                        var image = new Image();
                        image.src = v.url;
                        image.onload = function() {
                            var imgData = getBase64Image(image);
                            var sendData = {
                                'image': imgData
                            }
                            var AUTH_TOKEN = myStorage.getItem('AUTH_TOKEN');
                            var USER_KEY = myStorage.getItem('USER_KEY');
                            showLoading();
                            mui.ajax(BASE_URL + 'XXXXXXXXX/XXXXXX', {
                                type: 'POST',
                                dataType: 'json',
                                data: sendData,
                                async: true,
                                timeout: 100000, //超时时间设置为10秒;
                                success: function(res) {
                                    if(typeof res == 'string') {
                                        var res = JSON.parse(res);
                                    }

                                    //如果登陆失效
                                    if(res.code == '-1' || res.code == '-2') {
                                        mui.toast(res.msg);
                                        clearUserInfoCache(myStorage)
                                        mui.openWindow({
                                            url: '/view/login.html'
                                        })
                                    } else if(res.code == '-3') {
                                        mui.toast(res.msg);
                                        hideLoading();
                                        return false;
                                    }
                                    if(res.code != '1') {
                                        mui.toast(res.msg);
                                    }
                                    vm.uploadImgArr[k].status=1;
                                    vm.uploadImgUrlArr.push(res.param);//上传成功
                                    hideLoading();
                                },
                                error: function(xhr, type, errorThrown) {
                                    vm.uploadImgArr[k].status=-1;
                                    hideLoading();
                                },
                                headers: {
                                    'access_token': AUTH_TOKEN,
                                    'user_key': USER_KEY,
                                }
                            });
                        }
                    }
                });
            }

            //将图片压缩转成base64 
            function getBase64Image(img) {
                var canvas = document.createElement("canvas");
                var width = img.width;
                var height = img.height;
                // calculate the width and height, constraining the proportions 
                if(width > 1000){
                    height=height/1.5;
                    width=width/1.5;
                }
                
                if(height > 1000){
                    height=height/1.5;
                    width=width/1.5;
                }
                
                canvas.width = width; /*设置新的图片的宽度*/
                canvas.height = height; /*设置新的图片的长度*/
                var ctx = canvas.getContext("2d");
                ctx.drawImage(img, 0, 0, width, height); /*绘图*/
                var dataURL = canvas.toDataURL("image/png", 1);
                return dataURL.replace("data:image/png;base64,", "");
            }

            //拍照
            function captureImage() {
                var cmr = plus.camera.getCamera(2);
                cmr.captureImage(
                    function(path) {
                        //将图片地址转换
                        plus.io.resolveLocalFileSystemURL(path, function(entry) {
                            var newPath = entry.toLocalURL() + "?version=" + Math.random();
                            loadImage(newPath);
                        });
                    },
                    function(error) {
                        mui.toast(error.message);
                    }, {
                        filename: "_documents/"
                    }
                );

            }
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,874评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,102评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,676评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,911评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,937评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,935评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,860评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,660评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,113评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,363评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,506评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,238评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,861评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,486评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,674评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,513评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,426评论 2 352

推荐阅读更多精彩内容