头像裁剪上传功能实现

头像裁剪上传功能实现主要实现一个如图的头像裁剪上传功能:思路设置固定宽高的div,用于头像裁剪的最终部分并设置其overflow属性为hidden,position设置为relative给之后拖拽canvas作为参照,然后通过监听input的onchange事件,利用canvas绘图,将图片绘制到canvas上,并将该canvas加到该div之中,并设置其position为absolute...
摘要由CSDN通过智能技术生成

头像裁剪上传功能实现

主要实现一个如图的头像裁剪上传功能:
在这里插入图片描述

思路

设置固定宽高的div,用于头像裁剪的最终部分并设置其overflow属性为hidden,position设置为relative给之后拖拽canvas作为参照,然后通过监听input的onchange事件,利用canvas绘图,将图片绘制到canvas上,并将该canvas加到该div之中,并设置其position为absolute。然后通过对canvas进行mousedown,mousemove,mouseup三个事件的监听,计算好拖拽的边界值。

图片的展示

通过监听input的onchange事件,用FileReader读到选取图片的内容,在其onload事件中赋给一个image对象作为src,然后在image对象的onload事件中利用canvas的drawImage(img, width, height)绘制出画布,最后用oDIV.appendChild(canvas)加入到div之后,详情可以看前篇博客enter link description here

拖拽的实现

前提:设置了absolute,因为是通过改变被拖拽对象的top和left值,实现的拖拽。
三个事件及触发时的事件对象e:

  • onmousedown : 鼠标被按下
  • onmousemove: 鼠标移动
  • 5
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值