位置: 编程技术 - 正文

jQuery实现模拟flash头像裁切上传功能示例(jquery模拟表单提交)

编辑:rootadmin

推荐整理分享jQuery实现模拟flash头像裁切上传功能示例(jquery模拟表单提交),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:jquery modal,jquery模块,jquery模拟表单提交,jquery模拟按钮点击,jquery模拟表单提交,jquery模拟表单提交,jquery 模态窗口,jquery 模态窗口,内容如对您有帮助,希望把文章链接给更多的朋友!

本文实例讲述了jQuery实现模拟flash头像裁切上传功能。分享给大家供大家参考,具体如下:

是的,jq已经有类似的插件了,或者干脆用flash算了,为什么我还要自己写?因为造(wo)轮(bu)子(hui)也(flash)是一个学习的过程,轮子不会造,将来怎么造飞机?先来一张最终效果图:

一、大概思路

用js来做这个效果,先得将图片A上传到服务器,关于异步上传的插件有很多,不用插件也可以参考本人上一篇博客用纯js的方式上传,上传之后显示到页面里,由于上传的图片尺寸各不相同,要完整地显示图片,就要将上传后的图片用css控制按比例缩放显示,然后通过矩形选框选择需要的部分,用js获取矩形选框的左上角坐标,加上选框的宽高按比例计算后传给后台,后台程序根据所传参数来裁切得到图片B后返回到前台并将上传的原图A删除,节省空间。

二、分析

将效果图分为左右两部分,先看左边,由一张图片加一个矩形选区组成,图片和选区之间有一层半透明的遮罩,但是这样的话会连选区部分一块遮住,就没有上面这种框选出来的效果了,事实上结构是这样的:由下往上分别是1图片层,2遮罩层,3选区层(一个div,绝对定位),4图片层(绝对定位)。第1层和第4层的图片是一样的,大小及left、top值也一样,给第3层选区层加个overflow:hidden,就呈现出了上面的效果,虚线边框及拖拽的8个点后文会讲到。下图比较直观地说明的它们的层级关系,第3层灰色部分为overflow:hidden隐藏的部分:

做完图发现左右两边框的位置不一样,但重在说明原理。接下来,选区部分可以拖动,用到拖拽原理:鼠标按下,记录var disx=event.clientX,var disy=event.clientY,拖动,计算当前event.clientX与disx的差值为x,当前event.clientY与disy的差值为y,设置第4层图片的left值为图片当前offsetLeft+disx,top值为offsetTop+disy。如选区往左移动px,由于第4层只能在第1层范围内移动,那么刚好第4层的left值等于负的第3层的left值,top值同理。拖拽原理图:

jQuery实现模拟flash头像裁切上传功能示例(jquery模拟表单提交)

选区大小是可以按比例改变的,这就需要用到选区周围的8个点,如下图可以分为4个部分:

每个部分里的点触发的事件是一样的,4个部分触发的事件都是改变选区大小,不一样的地方在于第1部分会同时改变选区的left和top值,第2和第4部分分别只改变的是选区的top、left值,第3部分不会改变选区的left和top值。4个部分原理都一样,拿第1部分说事,点击第1部分的点往左上角拖动,选区变大的同时设置其left和top值(会减小),而left减小的值刚好等于选区增大的值,这个值的计算方法同拖拽原理。拖拽过程中需要限制范围,不能超出整个图片的范围。

选中需要截取的部分后,获取当前选区(第4层)的左上角的坐标,即第4层的offsetLeft、offsetTop值,再获取选区的宽高,这4个值不能直接往后台传,因为此时的图片可能是被缩放过的,而后台是根据原图尺寸来截取的,那么需要在图片上传完之后获取图片原始宽高,与页面中图片显示宽高得出一个比例,将这4个值乘以这个比例得出的值才是后台需要的。

至于选区的边框,做得简单点可以直接设置border:1px dashed #fff,更好的方法是放四个position:absolute的div,分别固定在选区的上下左右,上下宽%,高1px,左右宽1px,高%,背景设为一个波浪纹的gif图片,repeat,出来的效果很是惊艳!

右边部分3张图片仅仅是展示用,显示的内容是左边选区选中的部分,而选区的大小是可以改变的,所以右边的图片大小及位置是随着选区的变化而变化。选择图片上传后,选区有个默认宽高,右边3个框宽高是固定的,根据选区宽与右边三个框的宽分别相除得出的比例可以算出右边三个框内的图片应该显示的尺寸,显示原理同左边,相比左边只是少了第1、2层。

这种方式的优点是纯js,兼容性也好,另外还可以做个特性检测,支持HTML5的浏览器可以直接在前端切割图片,缺点是裁切之前要选将图片上传。源码晚点贴上来。

三、源码

更多关于jQuery相关内容感兴趣的读者可查看本站专题:《jQuery常用插件及用法总结》、《jQuery扩展技巧总结》、《jQuery切换特效与技巧总结》、《jQuery遍历算法与技巧总结》、《jQuery常见经典特效汇总》、《jQuery动画与特效用法总结》及《jquery选择器用法总结》

希望本文所述对大家jQuery程序设计有所帮助。

jquery实现简单的瀑布流布局 是开头都会说的原理瀑布流布局有两种,一种是固定列,一种是非固定列。在此主要记述第一种的实现。固定列的特征是:无论页面如何缩放,每行的

jquery滚动条插件(可以自定义) 以后用起来就方便了把css文件引入linkrel="stylesheet"type="text/css"href="css/jquery.mCustomScrollbar.css"js引入scripttype="text/javascript"src="js/jquery.mCustomScrollbar.concat.min.js"

基于jquery实现的鼠标悬停提示案例 //这是JS里的代码MOMO.js因为刚学封装JQUERY插件所以就做的稍微麻烦一点,其实在前台页面直接就可以用mouseover,mouseout,mousemove三个事件就行了(function($){$.fn

标签: jquery模拟表单提交

本文链接地址:https://www.jiuchutong.com/biancheng/376258.html 转载请保留说明!

上一篇:基于jQuery实现的查看全文功能【实用】(基于jquery的框架有哪些)

下一篇:jquery实现简单的瀑布流布局(jquery技巧)

  • 房产税和土地使用税每年都要交吗
  • 放弃退税理由是什么
  • 减免所得税会影响工资发放吗
  • 税后营业利润怎么算出来的
  • 去年收到一张普票超范围了怎么办
  • 职工教育经费中其他费用包括
  • 开办期间的费用,没有发票,咋抵扣啊
  • 子公司计提的盈余公积如何抵消
  • 煤矿企业维简费税务规定
  • 国有资产如何保值
  • 外贸企业免税收入怎么申报
  • 承兑汇票兑现怎么填写
  • 营业外支出罚款要交税吗
  • 农产品收购发票是普票还是专票
  • 一般纳税人旅游服务差额征税税率
  • 发票查验平台查询官网手机版App
  • 增加以前年度收入是否需要更正申报年报
  • 自然人收税管理
  • win7更改电脑设置在哪里
  • 考勤扣款怎么算
  • 工会举办比赛,参赛人员差旅费可以在工会报销吗
  • 酒店装修期间的费用如何核算
  • cesium三维地球
  • 房屋权属登记撤销申请书
  • Error in render: “TypeError: Cannot read properties of undefined (reading ‘length‘)“,深层次数据处理报错????
  • framework怎么用
  • yum命令安装软件
  • Android AsyncTack 异步任务实例详解
  • 企业所得税预缴纳税申报表
  • mongodb 入门
  • 税务新法规
  • 企业进行材料清查盘点中盘盈的材料
  • 商业汇票如何申请操作
  • 货币市场基金的特点
  • mysql数据库在使用时的常见错误号和解决方法有哪些?
  • 实收资本属于限定性净资产吗
  • 增值税专用发票的税率是多少啊
  • 应收账款调增调减?
  • 分销佣金账务处理流程
  • 合同取得成本和销售费用
  • 固定资产税前一次性扣除会计处理与税务处理
  • 资本公积现金流量表里放在哪里
  • 费用利润率计算公式是怎样的?
  • 增值税年末结转的会计处理
  • 建筑企业包工包料业务的发票开具和涉税处理
  • 其他应收款项
  • 可供出售金融资产属于什么科目
  • 资金股东占股比例
  • 电子发票开具流程?
  • 培训费发票是否可以抵扣
  • 编制合并报表时最关键的一步
  • 个体户需要报税吗?需要报哪些税?
  • 升级完鸿蒙系统5G咋没有了
  • windows7 记事本
  • win7系统蓝牙搜索不到设备
  • 电脑图片打印不出来怎么办
  • 微软撤回快捷键
  • linux共享内存同步机制
  • debian怎么用
  • linux测试软件
  • window10安装时间太长
  • win7 c盘打不开
  • win8打开ie浏览器
  • nodejs rbac
  • Android Chronometer(定时器)
  • csshtml经典案例
  • shell替换文件中指定行的指定内容
  • 批处理 重命名
  • windows、linux
  • shell脚本查找
  • python中面向对象
  • node.js调用第三方物流跟踪api
  • node中的ejs
  • javascript 组件
  • h5实现微信分享
  • android界面设计规范
  • 衡水市地税局
  • 年终奖发4万扣多少税
  • 城市基础设施配套费由哪个部门收取
  • 北京昌平区租房价格
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设