MUI(拍照+系统相册)图片上传剪切预览
- <!DOCTYPE html>
- <html>
- <head>
- <meta charset="utf-8">
- <title>裁剪头像</title>
- <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
- <link href="../css/mui.min.css" rel="stylesheet" />
- <link href="../css/cropper.css" rel="stylesheet" />
- <style type="text/css">
- body {
- background-color: #000000;
- }
- #cropper-example-1 {
- background-color: #000000;
- height: 93%;
- width: 100%;
- position: absolute;
- }
- #quxiao,
- #xuanzhuan,
- #xuanqu {
- font-size: 20px;
- }
- .divbut {
- width: 100%;
- text-align: center;
- position: fixed;
- z-index: 2;
- bottom: 0px;
- background-color: #000000;
- height: 7.5%;
- line-height: 50px;
- }
- .divbut>div:first-child {
- float: left;
- width: 20%;
- }
- .divbut>div:last-child {
- float: right;
- width: 20%;
- }
- img#im {
- height: 100%;
- width: 100%;
- }
- </style>
- </head>
- <body>
- <div id="cropper-example-1" class="mui-hidden">
- <img id="im" alt="Picture" />
- </div>
- <div class="divbut">
- <div>
- <p id="quxiao" class="iconfont icon-quxiao">取消</p>
- </div>
- <div>
- <p id="xuanqu" class="iconfont icon-queding">确认</p>
- </div>
- </div>
- <img src="" alt="" class="mui-hidden" id="im_exif" />
- <script src="../js/jquery-1.9.min.js"></script>
- <script src="../js/mui.min.js"></script>
- <script src="../js/exif.js"></script>
- <script src="../js/cropper.min.js"></script>
- <script src="../js/app.min.js"></script>
- <script>
- (function(c) {
- var Cro = function() {}
- c.extend(Cro.prototype, {
- orientation: null,
- urldata: null,
- view: null,
- num: 0,
- sbx: null,
- sby: null,
- n: 0,
- onReady: function() {
- var that = this;
- mui.init();
- that.bindEvent();
- that.view = plus.webview.currentWebview();
- var img = document.getElementById("im_exif");
- img.src = that.view.path;
- img.addEventListener("load", function() {
- //exif调整图片的横竖
- EXIF.getData(this, function() {
- var orientation = EXIF.getAllTags(this).Orientation;
- $("#im").attr("src", that.loadcopyImg(img, orientation));
- document.getElementById("cropper-example-1").classList.remove("mui-hidden"); //显示裁剪区域
- that.cropperImg();
- });
- })
- },
- cropperImg: function() {
- var that = this;
- $('#cropper-example-1 > img').cropper({
- aspectRatio: 1 / 1,
- autoCropArea: 1,
- strict: true,
- background: false,
- guides: false,
- highlight: false,
- dragCrop: false,
- movable: false,
- resizable: false,
- crop: function(data) {
- that.urldata = that.base64(data);
- }
- });
- },
- loadcopyImg: function(img, opt) {
- var that = this;
- var canvas = document.createElement("canvas");
- var square = 500;
- var imageWidth, imageHeight;
- if(img.width > img.height) {
- imageHeight = square;
- imageWidth = Math.round(square * img.width / img.height);
- } else {
- imageHeight = square; //this.width;
- imageWidth = Math.round(square * img.width / img.height);
- }
- canvas.height = imageHeight;
- canvas.width = imageWidth;
- if(opt == 6) {
- that.num = 90;
- } else if(opt == 3) {
- that.num = 180;
- } else if(opt == 8) {
- that.num = 270;
- }
- if(that.num == 360) {
- that.num = 0;
- }
- var ctx = canvas.getContext("2d");
- ctx.translate(imageWidth / 2, imageHeight / 2);
- ctx.rotate(that.num * Math.PI / 180);
- ctx.translate(-imageWidth / 2, -imageHeight / 2);
- ctx.drawImage(img, 0, 0, imageWidth, imageHeight);
- var dataURL = canvas.toDataURL("image/jpeg", 1);
- return dataURL;
- },
- bindEvent: function() {
- var that = this;
- document.getElementById("quxiao").addEventListener("tap", function() {
- mui.back(); //取消就直接返回
- });
- document.getElementById("xuanqu").addEventListener("tap", function() {
- var preView = plus.webview.getWebviewById('plus/headinfo.html');
- //触发上一个页面刷新图片事件
- mui.fire(preView,'updateHeadImg',{
- img_path:that.urldata
- });
- mui.back();
- });
- },
- base64: function(data) {
- var that = this;
- var img = document.getElementById("im");
- var canvas = document.createElement("canvas");
- //像素
- canvas.height = 500;
- canvas.width = 500;
- var bx = data.x;
- var by = data.y;
- var ctx = canvas.getContext("2d");
- ctx.drawImage(img, bx, by, data.width, data.height, 0, 0, 500, 500);
- var dataURL = canvas.toDataURL("image/jpeg", 1.0); //第二个参数是质量
- return dataURL;
- }
- });
- var cro = new Cro();
- c.plusReady(function() {
- cro.onReady();
- })
- })(mui)
- </script>
- </body>
- </html>
MUI(拍照+系统相册)图片上传剪切预览的更多相关文章
- MUI 图片上传剪切预览,可选(拍照+系统相册)
整合网上的例子..麻蛋.没跑通..没办法.自己就拿他们的例子完善了一下..已经可以使用了! 准备工作: 这几个文件要引入.特别是JS 文件!!! <link href="../css/ ...
- 小程序实现图片上传,预览以及图片base64位处理
最近一段时间在做小程序项目,第一期功也完工了.需要好好总结一下经验,把项目中遇到的问题好好总结一下,遇到的问题,踩过的坑.今天写一个小程序实现图片上传,预览,以及删除,图片base64位处理.下面就是 ...
- html之file标签 --- 图片上传前预览 -- FileReader
记得以前做网站时,曾经需要实现一个图片上传到服务器前,先预览的功能.当时用html的<input type="file"/>标签一直实现不了,最后舍弃了这个标签,使用了 ...
- ASP.NET MVC图片上传前预览
回老家过春节,大半个月,在家的日子里,吃好睡好,人也长了3.5Kg.没有电脑,没有网络,无需写代码,工作上相关的完全放下......开心与父母妻儿过个年,那样的生活令Insus.NET现在还在留恋.. ...
- 图片上传本地预览。兼容IE7+
基于JQUERY扩展,图片上传预览插件 目前兼容浏览器(IE 谷歌 火狐) 不支持safari 预览地址:http://www.jinbanmen.com/test/1.html js代码:/**名称 ...
- DevExpress控件使用系列--ASPxUploadControl(图片上传及预览)
1.控件功能 列表控件展示数据.弹框控件执行编辑操作.Tab控件实现多标签编辑操官方说明 2.官方示例 2.1 ASPxImage http: ...
- uploadPreview 兼容多浏览器图片上传及预览插件使用
uploadPreview兼容多浏览器图片上传及预览插件 http://www.jq22.com/jquery-info2757 Html 代码 <div class="form-gr ...
- js实现图片上传及预览---------------------->>兼容ie6-8 火狐以及谷歌
<head runat="server"> <title>图片上传及预览(兼容ie6/7/8 firefox/chrome)</title> & ...
- file标签 - 图片上传前预览 - FileReader & 网络图片转base64和文件流
记得以前做网站时,曾经需要实现一个图片上传到服务器前,先预览的功能.当时用html的<input type="file"/>标签一直实现不了,最后舍弃了这个标签,使用了 ...
随机推荐
- JS读取json 文件
json文件是一种轻量级的数据交互格式.一般在jquery中使用getJSON()方法读取. $.getJSON(url,[data],[callback]) url:加载的页面地址 data: 可选 ...
- yolo源码解析(一)
原文:https://www.cnblogs.com/zyly/p/9534063.html yolo源码来源于网址:https://github.com/hizhangp/yolo_tensorfl ...
- protobuf标准消息方法
protobuf标准消息方法 1.标准消息方法 每个消息类包含一些其他方法允许你检查和控制整个消息,包括: · IsInitialized() :检查是否所有必须(required)字段都已经被赋值了 ...
- spring mvc 接受前台json @RequestBody json 属性 空 使用 JsonProperty spring mvc 获取json转乘bean
请给json序列序列化成的javabean 属性加上 @JsonProperty(value = "real_name") 否则 springmvc 可能接受不到数据 ja ...
- 里诺全系列注册机+暗桩patch
一直有坛友私信更新里诺,今天花了一天时间,将里诺全系列更新完毕,权当送给坛友们的新年礼物吧! 全系列开放至元旦假期结束,后面就随机开放了. <ignore_js_op> 使用说明: 1.选 ...
- 解决ASP.NET中的各种乱码问题
解决ASP.NET中的各种乱码问题 阅读目录 开始 页面显示乱码问题 AJAX提交的数据乱码问题 JavaScript中正确的URL编码方式 ASP.NET中正确的URL编码方式 正确的URL编码方式 ...
- Spring Boot集成MyBatis开发Web项目
1.Maven构建Spring Boot 创建Maven Web工程,引入spring-boot-starter-parent依赖 <project xmlns="http://mav ...
- Android -- ViewPager切换动画,PageTransformer
transformPage(View view, float position) view就是滑动中的那个view,position这里是float类型,是当前滑动状态的一个表示,比如当滑动到正全屏时 ...
- 一文学会用 Tensorflow 搭建神经网络
http://www.jianshu.com/p/e112012a4b2d 本文是学习这个视频课程系列的笔记,课程链接是 youtube 上的,讲的很好,浅显易懂,入门首选, 而且在github有代码 ...
- Netflix推荐系统:从评分预测到消费者法则
http://in.sdo.com/?p=11 原文链接:Netflix recommendations: beyond the 5 stars (Part 1), (Part 2) 原文作者:Xav ...