apiCloud上传头像

简介:

apiCloud上传头像

1.拍照

2.从相机中选择

aui布局

<li class="aui-list-item">
            <div class="aui-list-item-inner">
                <div class="aui-list-item-label">
                    头像
                </div>
                <div class="aui-list-item-input" style="margin:15px;" onclick="showAction();">
                    <img id="avatar" name="avatar" src="../image/default_headimg.png" width="100px;">
                </div>
            </div>
</li>

2.js事件,弹出选择

function showAction(){
    api.actionSheet({
        title: '上传头像',
        cancelTitle: '取消',
        buttons: ['拍照','从手机相册选择']
    }, function(ret, err) {
        if (ret) {
            getPicture(ret.buttonIndex);
        }
    });
}

422101-20161103151705002-295604291.png

3.处理事件

function getPicture(sourceType) {
    if(sourceType==1){ // 拍照
        //获取一张图片
        api.getPicture({
            sourceType: 'camera',
            encodingType: 'png',
            mediaValue: 'pic',
            allowEdit: false,
            quality: 90,
            saveToPhotoAlbum: true
        }, function(ret, err) {
            // 获取拍照数据并处理
            if (ret) {
                var imgSrc = ret.data;
                if (imgSrc != "") {
                    var ele=$api.dom('#avatar');
                    $api.attr(ele,'src',imgSrc);
                }
            }
        });
    }
    else if(sourceType==2){ // 从相机中选择
        //UIMediaScanner 是一个多媒体扫描器,可扫描系统的图片、视频等多媒体资源
        var obj = api.require('UIMediaScanner');
        obj.open({
            //返回的资源种类,picture(图片),video(视频),all(图片和视频)
            type: 'picture',
            //(可选项)图片显示的列数,须大于1
            column: 4,
            max: 1,
            //(可选项)图片排序方式,asc(旧->新),desc(新->旧)
            sort: {
                key: 'time',
                order: 'desc'
            },
            //(可选项)模块各部分的文字内容
            texts: {
                stateText: '已选择*项',
                cancelText: '取消',
                finishText: '完成'
            },
            styles: {
                bg: '#fff',
                mark: {
                    icon: '',
                    position: 'bottom_right',
                    size: 20
                },
                nav: {
                    bg: '#eee',
                    stateColor: '#000',
                    stateSize: 18,
                    cancleBg: 'rgba(0,0,0,0)',
                    cancelColor: '#000',
                    cancelSize: 18,
                    finishBg: 'rgba(0,0,0,0)',
                    finishColor: '#000',
                    finishSize: 18
                }
            }
        }, function(ret) {
            // 获取图片数据并处理
            if (ret) {
                if (getJsonObjLength(ret.list) != 0) {
                    var ele=$api.dom('#avatar');
                    $api.attr(ele,'src',ret.list[0].path);
                }
            }
        });
    }
}

第一种是apiCloud自带的,获取拍照数据的接口。

第二种需要引入模块,UIMediaScanner。
422101-20161103151718721-1959725349.png

两种方式都能获取图片的app中的地址,把地址通过ajax传递出去到服务器,就可以完成保存头像了。

调试请用手机,不然看不到效果。


本文转自TBHacker博客园博客,原文链接:http://www.cnblogs.com/jiqing9006/p/6026757.html,如需转载请自行联系原作者

相关文章
|
19天前
|
移动开发 小程序 前端开发
|
3月前
|
小程序
微信小程序实现上传视频 / 上传图片功能以及整合上传视频 / 上传图片功能(超详细)
微信小程序实现上传视频 / 上传图片功能以及整合上传视频 / 上传图片功能(超详细)
|
4月前
Typora上传图片失败PicGo
Typora上传图片失败PicGo
|
JavaScript API
uniapp获取微信昵称和头像
uniapp获取微信昵称和头像
|
SQL JSON 前端开发
上传头像【项目 商城】
上传头像【项目 商城】
42 0
|
前端开发 JavaScript
前端上传图片到七牛云
前端上传图片到七牛云
285 0
|
小程序 JavaScript 前端开发
微信小程序上传头像和昵称持久化保存
微信小程序上传头像和昵称持久化保存
1103 0
|
小程序 JavaScript API
微信小程序如何更换头像
微信小程序如何更换头像
251 0
|
开发者
一步步教你如何上传头像
一步步教你如何上传头像
336 0
一步步教你如何上传头像
|
前端开发 JavaScript
前端培训-初级阶段-场景实战(2019-05-16)-聊天头像-微信头像-群组头像
前端最基础的就是 HTML+CSS+Javascript。掌握了这三门技术就算入门,但也仅仅是入门,现在前端开发的定义已经远远不止这些。前端小课堂(HTML/CSS/JS),本着提升技术水平,打牢基础知识的中心思想,我们开课啦(每周四)。 场景实战这块内容每个人的内容都不一样。所以最近的更新基本都是我遇到并解决掉的问题。后期会吧他们的内容贴地址。
197 0
前端培训-初级阶段-场景实战(2019-05-16)-聊天头像-微信头像-群组头像