php+mui+头像上传,mui开发APP教程之上传用户头像

2024-01-24 23:20

本文主要是介绍php+mui+头像上传,mui开发APP教程之上传用户头像,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

mui开发APP教程之上传用户头像

mui开发APP教程之上传用户头像

页面展示:

dd0cb87d411ca28b3209d5b8010d032e.png

实现功能:

点击头像出现acntionsheet框,让你选择是从相册选取还是拍照

html代码:

头像

2.1.jpg

js代码:

mui.plusReady(function(){

document.getElementById('userImg').addEventListener('tap',function(){

if(mui.os.plus){

var a=[{

title:'拍照'

},{

title:'从手机相册选择'

}];

plus.nativeUI.actionSheet({

title:'修改头像',

cancel:'取消',

buttons:a

},function(b){

switch(b.index){

case 0:

break;

case 1:

//拍照

getImages();

break;

case 2:

//打开相册

galleryImages();

break;

default:

break;

}

},false);

}

});

//拍照

function getImages(){

var mobileCamera=plus.camera.getCamera();

mobileCamera.captureImage(function(e){

plus.io.resolveLocalFileSystemURL(e,function(entry){

var path=entry.toLocalURL()+'?version='+new Date().getTime();

uploadHeadImg(path);

},function(err){

console.log("读取拍照文件错误");

});

},function(e){

console.log("er",err);

},function(){

filename:'_doc/head.png';

});

}

//从本地相册选择

function galleryImages(){

console.log("你选择了从相册选择");

plus.gallery.pick(function(a){

plus.io.resolveLocalFileSystemURL(a,function(entry){

plus.io.resolveLocalFileSystemURL('_doc/',function(root){

root.getFile('head.png',{},function(file){

//文件已经存在

file.remove(function(){

console.log("文件移除成功");

entry.copyTo(root,'head.png',function(e){

var path=e.fullPath+'?version='+new Date().getTime();

uploadHeadImg(path);

},function(err){

console.log("copy image fail: ",err);

});

},function(err){

console.log("删除图片失败:("+JSON.stringify(err)+")");

});

},function(err){

//打开文件失败

entry.copyTo(root,'head.png',function(e){

var path=e.fullPath+'?version='+new Date().getTime();

uploadHeadImg(path);

},function(err){

console.log("上传图片失败:("+JSON.stringify(err)+")");

});

});

},function(e){

console.log("读取文件夹失败:("+JSON.stringify(err)+")");

});

});

},function(err){

console.log("读取拍照文件失败: ",err);

},{

filter:'image'

});

};

//上传图片

function uploadHeadImg(imgPath){

//选中图片之后,头像当前的照片变为选择的照片

var mainImg=document.getElementById('userImg');

mainImg.src=imgPath;

var images=new Image();

images.src=imgPath;

var imgData=getBase64Image(images);

mui.ajax('http://127.0.0.1/uploadHeadImg',{

data:{

'imgDatas':imgData

},

dataType:'json',//服务器返回json格式数据

type:'post',//HTTP请求类型

timeout:10000,//超时时间设置为10秒;

success:function(data){

if(data.status=='1'){

mui.alert('上传成功!');

}

},

error:function(xhr,type,errorThrown){

if(type=='timeout'){

mui.alert('服务器连接超时,请稍后再试');

}

}

});

}

//压缩图片转成base64

function getBase64Image(img){

var canvas=document.createElement("canvas");

var width=img.width;

var height=img.height;

if(width>height){

if(width>100){

height=Math.round(height*=100/width);

width=100;

}

}else{

if(height>100){

width=Math.round(width*=100/height);

}

height=100;

}

canvas.width=width;

canvas.height=height;

var ctx=canvas.getContext('2d');

ctx.drawImage(img,0,0,width,height);

var dataUrl=canvas.toDataURL('image/png',0.8);

return dataUrl.replace('data:image/png:base64,','');

}

});

mui开发APP教程之上传用户头像相关教程

这篇关于php+mui+头像上传,mui开发APP教程之上传用户头像的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/641345

相关文章

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

Ubuntu固定虚拟机ip地址的方法教程

《Ubuntu固定虚拟机ip地址的方法教程》本文详细介绍了如何在Ubuntu虚拟机中固定IP地址,包括检查和编辑`/etc/apt/sources.list`文件、更新网络配置文件以及使用Networ... 1、由于虚拟机网络是桥接,所以ip地址会不停地变化,接下来我们就讲述ip如何固定 2、如果apt安

PyCharm 接入 DeepSeek最新完整教程

《PyCharm接入DeepSeek最新完整教程》文章介绍了DeepSeek-V3模型的性能提升以及如何在PyCharm中接入和使用DeepSeek进行代码开发,本文通过图文并茂的形式给大家介绍的... 目录DeepSeek-V3效果演示创建API Key在PyCharm中下载Continue插件配置Con

TP-Link PDDNS服将于务6月30日正式停运:用户需转向第三方DDNS服务

《TP-LinkPDDNS服将于务6月30日正式停运:用户需转向第三方DDNS服务》近期,路由器制造巨头普联(TP-Link)在用户群体中引发了一系列重要变动,上个月,公司发出了一则通知,明确要求所... 路由器厂商普联(TP-Link)上个月发布公告要求所有用户必须完成实名认证后才能继续使用普联提供的 D

Deepseek R1模型本地化部署+API接口调用详细教程(释放AI生产力)

《DeepseekR1模型本地化部署+API接口调用详细教程(释放AI生产力)》本文介绍了本地部署DeepSeekR1模型和通过API调用将其集成到VSCode中的过程,作者详细步骤展示了如何下载和... 目录前言一、deepseek R1模型与chatGPT o1系列模型对比二、本地部署步骤1.安装oll

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创

Spring Boot整合log4j2日志配置的详细教程

《SpringBoot整合log4j2日志配置的详细教程》:本文主要介绍SpringBoot项目中整合Log4j2日志框架的步骤和配置,包括常用日志框架的比较、配置参数介绍、Log4j2配置详解... 目录前言一、常用日志框架二、配置参数介绍1. 日志级别2. 输出形式3. 日志格式3.1 PatternL

MySQL8.2.0安装教程分享

《MySQL8.2.0安装教程分享》这篇文章详细介绍了如何在Windows系统上安装MySQL数据库软件,包括下载、安装、配置和设置环境变量的步骤... 目录mysql的安装图文1.python访问网址2javascript.点击3.进入Downloads向下滑动4.选择Community Server5.

CentOS系统Maven安装教程分享

《CentOS系统Maven安装教程分享》本文介绍了如何在CentOS系统中安装Maven,并提供了一个简单的实际应用案例,安装Maven需要先安装Java和设置环境变量,Maven可以自动管理项目的... 目录准备工作下载并安装Maven常见问题及解决方法实际应用案例总结Maven是一个流行的项目管理工具

本地私有化部署DeepSeek模型的详细教程

《本地私有化部署DeepSeek模型的详细教程》DeepSeek模型是一种强大的语言模型,本地私有化部署可以让用户在自己的环境中安全、高效地使用该模型,避免数据传输到外部带来的安全风险,同时也能根据自... 目录一、引言二、环境准备(一)硬件要求(二)软件要求(三)创建虚拟环境三、安装依赖库四、获取 Dee