html5在线拍照,h5调用html5拍照上传功能

今天遇到一个需求,需要用到html5的拍照功能,然后生成base64格式的图片,然后上传后台。其实找了好多解决方案,大致都说了思路,没有完整的解决ios和安卓的各种问题(比如:ios横向和竖向图片展示的问题),然后再群里问了一下,一个兄弟给推荐了这个插件ImageFile,用了一下挺好用的,赞一个,mark一下。

示例代码,直接拷贝运行:

base

*{

margin:0;

padding:0;

}

body{

}

.img-box{

padding:20px;

overflow: hidden;

}

.img-box .item{

width:100px;

height:100px;

background: #dedede;

float:left;

margin-right:20px;

position:relative;

}

.img-box .item input{

position: absolute;

width:100px;

height:100px;

top:0;

left:0;

opacity: 0;

}

function fileChange(ev) {

let file = ev.target.files[0];

ImageFile.getImageFileData(file, {

width: 100,

height: 100,

cover: false

}).then(({ blob, base64 }) => {

ev.target.previousSibling.previousSibling.setAttribute('src',base64);

});

}

使用:

function fileChange(ev) {

let file = ev.target.files[0];

ImageFile.getImageFileData(file, { width: 600, height: 800, cover: false }).then(({ blob, base64 }) => {

let img = ImageFile.blobToImage(blob);

img.style.width = '300px';

console.log(blob, base64.length)

document.body.appendChild(img);

});

}

API

getImageFileData(file, option);

get image file input data, can compress size with option with and height

参数类型说明filefile type文件类型

optionobject配置项

width宽度

height高度

cover是否覆盖整个区域,默认false

function fileChange(ev) {

let file = ev.target.files[0];

ImageFile.getImageFileData(file, { width: 300, height: 400, cover: true }).then(blob => {

let img = ImageFile.blobToImage(blob);

document.body.appendChild(img);

})

}

blobToImage(blob)

blob translate to image, use for ImageFileData() result

参数类型说明blobblob二进制文件

let img = ImageFile.blobToImage(blob);

fileToCanvas(file, option);

file translate to canvas and image, get canvas and image

参数类型说明filefile type文件类型

optionobject配置项

width宽度

height高度

cover是否覆盖整个区域,默认false

ImageFile.fileToCanvas(file, { width: 400, height: 400 }).then(({ canvas, image }) => {

document.body.appendChild(canvas);

})

fileToImage(file);

file translate to image

参数类型说明filefile type文件类型

ImageFile.fileToImage(file).then(img => {

document.body.appendChild(img);

})

imageToCanvas(img);

image translate to canvas

参数类型说明imgimage element图片

let canvas = ImageFile.imageToCanvas(img);

canvasToImage(canvas);

canvas tranlate to image, return promise

参数类型说明canvascanvascanvas

ImageFile.canvasToImage(cvs, 'image/png').then(canvas => {

document.body.append(canvas);

})

canvasToFile(canvas);

canvas translate to file

let file = ImageFile.canvasToFile(cvs);

canvasToBase64(canvas, type = ‘image/png’, encoderOptions = ‘0.92’);

canvas to base64

let base64 = ImageFile.canvasToBase64(cvs);

imageToBase64(img);

image translate to base64

let base64 = ImageFile.imageToBase64(img);

rotate(canvas, image, degree);

rotate image by canvas and return canvas

参数类型说明canvascanvas需要绘制的canvs

imageimgimg元素

degreeint角度

ImageFile.rotate(cvs, img, degree);

欢迎关注小程序,感谢您的支持!

643d0cbe423265bc928203babbc7e1a7.png

shearphoto2.0 是HTML5头像截图插件,拍照截图,JS截图,美工切图插件,能直接压缩数码相机图片进行截图!是互联网上写得最好的一个同类型插件 ShearPhoto 完美支持Linux Windows 服务器,国外空间等完美通过。 兼容IE6及所有浏览器,兼容PHP5.2X至PHP7.0! ShearPhoto拖动拉伸超准,超流畅,在互联网同类型软件绝对排行第一,除了shearphoto,你别无选择! JAVA用户请到http://git.oschina.net/alexyang/JFinal-shearphoto 下载 ------------------------------------------------------------------------ 从shearphoto 1.5直接跳跃到shearphoto 2.0,这是shearphoto重大革新。本来我是想shearphoto 1.6 、1.7、 1.8 慢慢升的,但是这样升级只会让shearphoto慢慢走向灭亡!结果我又辛苦了一个多星期,把shearphoto 2.0升级完成! shearphoto2.0之前,我认为没必要加入HTML5,兼容IE6 7 8就够。但是直到后来!我知道这是我一个错误的决定 因为用户并没有为shearphoto 1.5埋单,原因shearphoto 1.5没有HTML5截取,用户觉得会增加服务器负载!而且又不是本地加载图片!我一个错误的决定!导致用户份额一直没有明显大增。 shearphoto 2.0是收集所有用户的意见开发而成的! 重大的特性就是全面支持HTML5 1:支持translate3d 硬件加速移动 2:加入图片预览功能 3:加入了压缩数码相机图片, 以及HTML5 canvas本地切图,截图 但依然继续支持IE6 7 8 哦!有人问IE6 7 8不兼容HTML5啊,你骗人吗? 先不要急!shearphoto 2.0的机制是这样的:有HTML5则使用HTML5 canvas切图,截图,JS先会截取一张最合理化的截图,然后交给后端,根据用户设置,进行压缩截图 没有HTML5的浏览器则采用先上传再截取的策略,就是原先1.5的策略。 当然有些用户如果不喜欢HTML5,也可以根据接口自行关闭 4:加HTML5图片特效,就一如美图秀秀这样的特效!shearphoto一共提供14种漂亮特效,感谢腾讯AI对图片特效提供支持 shearphoto 2.0增添很多接口,大部份是HTML5的设置!请下载源码体验 shearphoto外忧内患,已经没退路了。在WEB截图界,shearphoto必须要干个第一!.shearphoto不再局限于头像截取,shearphoto更可用于商城的商品图片编辑。 shearphoto含HTML5图片压缩功能!一张十M 二十M的图,照样能帮你压成你要的容量和尺寸, 一般情况下!商城的商品图片都是通过数码相机拍摄后,要用PHOTOshop把数码相机内几十M的图片,压缩,截取,然后才能上传到商城服务器! 这样的操作是不是太麻烦了! 如果你使用shearphoto你就快捷很多了,shearphoto你只需要直接选择图片,就会帮你进行压缩截取,上传,添加到数据库。这样的一条龙服务! shearphoto 2.0的机制是无可挑剔的!但是不排除有BUG存在,如果用户遇到BUG情况,请到论坛 或官方QQ群进行反馈,我会第一时间发布补丁! shearphoto支持PHP和JAVA,JAVA由网友所写,但是JAVA版并不是太完善,使用的是以前的shearphoto1.3!我 一直很想把NET python nodejs JAVA的很完善地做出来! 可惜个人能力有限,如果你喜欢shearphoto,你又会玩 NET python nodejs JAVA,又想为互联网做贡献,那么你可以加入shearphoto团队,把这些后端版本做出来。但shearphoto没有薪水给你! shearphoto免费开源的,没有利润可图,纯粹是抱着为互联网做贡献的心态!如果你跟我一样,请加入到shearphoto后端开发 浏览器支持: 兼容IE 6 及以上的所有浏览器 后端支持: 支持PHP5.X 至 PHP7.0或以上 支持JAVA后端(shearphoto1.3开发) 系统支持: 支持linux WINDOW服务器 shearphoto采用原生JS + 原生PHP所写,绝对不含JQ插件,对JQ情有独忠的,这个插件不合适你 2015 年 9月 5 日 shearphoto作者:明哥先生 版本
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值