百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>html5教程> HTML5结合canvas实现图片紧缩
分享文章到:

HTML5结合canvas实现图片紧缩

发布时间:09/01 来源:未知 浏览: 关键词:
这次给大家带来HTML5结合canvas实现图片紧缩,主要以代码的情势表现,下面就是实战案例,一起来看一下。

<!DOCTYPE html>
<html>
<head>
 <meta charset="UTF-8">
 <meta name='viewport' content='width=device-width, initial-scale=1, maximum-scale=1'>
 <title>lianxi </title>
 <style type="text/css">
    </style>
</head>
<body>
    <form>
 名字:<input type="text " name = 'username' id = 'username'/>
 上传:<input type="file" name = 'fileimage' id = 'fileimage' />
 </form>
 <button>button</button>
 <script>
 var file = document.querySelector('#fileimage')
 var username = document.querySelector('#username')
 var canvas = document.createElement('canvas');
 var span = document.createElement('span')
 var formData = new FormData()
 file.addEventListener('change',function() {
 //实现的道理的new formData()然后把这个formData 用ajax传进去
 span.innerHTML = '预览图加载中...'
 document.body.appendChild(span)
 console.log(file.files[0])
 username.value ? formData.append('username',username.value) : null;
 resize(file.files[0]);
 })
 //上传前的图片紧缩
 function resize(file) {
 var reader = new FileReader()
 reader.readAsDataURL(file)
 var img = new Image()
 reader.onload = function (e) {
 // this.result就是图片的base64地址信息
 img.src = this.result;
 }
 
 var context = canvas.getContext('2d');
 var gif = document.createElement('img')
 
 // base64地址图片加载完毕后
 img.onload = function () {
 // 图片原始尺寸
 //定义画布的大小
 if (img.width > 300 || img.height > 300) {
 if (img.width > img.height) {
 canvas.width = 300
 canvas.height = img.height / img.width * 300
 }
 else {
 canvas.height = 300
 canvas.width = img.width / img.height * 300
 }
 }
 //从那里开端截取图片
 context.drawImage(img, 0, 0, canvas.width, canvas.height)
 /*第一个参数是创立的img对象;第二个参数是左上角坐标,后面两个是画布区域宽高*/
 //紧缩后的图片base64 url
                /*canvas.toDataURL(mimeType, qualityArgument),mimeType 默许值是'image/jpeg';
                 * qualityArgument表示输出的图片质量,只要输出为jpg和webp格局的时候此参数才有结果,默许值是0.92*/
 //var newUrl = canvas.toDataURL('image/jpeg', 0.92);//base64 格局
 document.body.removeChild(span)
 document.querySelector('body').appendChild(canvas)
 };
 }
 //这是上传的
 document.querySelector('button').addEventListener('click',function(){
 canvas.toBlob(function(blob){
 var xhr = new XMLHttpRequest()
 formData.append('fileimage', blob,'002.webp')
 xhr.open('POST', 'test.php', true)//默许true 为异步
 //上传进度
 xhr.upload.addEventListener('progress',function (e) {
 console.log('上传进度为:'+ (e.loaded/e.total*100).toFixed(2)+'%')//屡次显现
 // event.total是需要传输的总字节,event.loaded是已经传输的字节
 })
 xhr.upload.addEventListener('loadstart', function () {
 console.log('上传开端')//只显现一次
 })
 xhr.onreadystatechange = function () {
 if (xhr.readyState === 4) {
 if (xhr.status >= 200 && xhr.status <300 || xhr.status == 304) {
 console.log(JSON.parse(xhr.responseText))//成功后的返回值
 }
 else {
 console.log("Request was unsuccessful: " + xhr.status);
 } 
 }
 
 }
 //xhr.setRequestHeader("Content-type", "multipart/form-data");
 xhr.send(formData)
 }, 'image/webp',0.9)
 })
 </script>
</body>
</html>

需要留意的是后端需要加上header("Access-Control-Allow-Origin:*");以实现跨域

相关链接:

html5+canvas实现图片的紧缩上传

HTML5 Canvas 实现当地紧缩图片

HTML5 canvas实现图片拉伸、紧缩与裁剪

以上就是HTML5结合canvas实现图片紧缩的具体内容,更多请关注百分百源码网其它相关文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有150人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板