function canvasUploadImg(image,imageName,imgType,callbackfn){

var img_width = image.width;
var img_height = image.height;
var canvas = document.getElementById("crop_canvas");
if(canvas== null){
canvas = document.createElement('canvas');
canvas.setAttribute("id",'crop_canvas');
var o = document.body;
var div = document.createElement('div');
div.style.display = "none";
o.appendChild(div);
div.appendChild(canvas);
}
var context = canvas.getContext("2d");
var x = $("#x").val(),y = $("#y").val(),w = $("#w").val(),
h = $("#h").val(),width = $("#width").val(),height = $("#height").val();
var rr = resetRatio(width, height, img_width, img_height);
var targetSize = getTargetSize(w*rr, h*rr,414,672);
canvas.width = targetSize.tw;
canvas.height = targetSize.th;
var srcSize = [x*rr, y*rr, w*rr, h*rr];
if(srcSize[0]<0) srcSize[0] = 0;
if(srcSize[1]<0) srcSize[1] = 0;
if(srcSize[2]>img_width) srcSize[2] = img_width;
if(srcSize[3]>img_height) srcSize[3] = img_height;
var tarSize = [0, 0, canvas.width,canvas.height];
var url ;
console.log("canvas@ w:"+canvas.width+" h:"+canvas.height);
console.log("image.onload@ x:"+x*rr+",y:"+y*rr+",w:"+w*rr+",h:"+h*rr+",x2:"+ 0+",y2:"+ 0+",w2:"+targetSize.tw+",h2:"+targetSize.th);
context.drawImage(image, srcSize[0],srcSize[1],srcSize[2],srcSize[3], tarSize[0], tarSize[1], tarSize[2], tarSize[3]);//这里取的是实际尺寸
//在图片裁剪重绘之后,添加切刀逻辑
//判断是否有切刀,如果有,则将切刀绘制到cut_canvas,将两个canvas做像素处理
//将cut_canvas中像素值满足条件(p[3]=)的点,与canvas中的对应点的p[3]值设为0(透明)
//console.log("有切刀?"+$(".jcrop-tracker").find("img").length);
if($(".jcrop-tracker").find("img").length>0){
var cutCanvas = document.getElementById("cut_canvas");
var cutContext = cutCanvas.getContext("2d");
cutCanvas.width = canvas.width;
cutCanvas.height = canvas.height;
var cutImg = new Image();
cutImg.crossOrigin = "";//"anonymous";
var cutImgSrc = $(".jcrop-tracker").find("img").attr("src");
cutImg.src = cutImgSrc+"?"+new Date().getTime();//使每次请求图片都是来自服务器而不是缓存
cutImg.onload = function(){
cutContext.drawImage(cutImg,0,0,cutImg.width,cutImg.height,0,0,canvas.width, canvas.height);
//像素级运算开始
var imgd = context.getImageData(0, 0, canvas.width, canvas.height);
var pix = imgd.data;
var imgd2 = cutContext.getImageData(0, 0, canvas.width, canvas.height);
var pix2 = imgd2.data;

for (var i = 0, n = pix2.length; i <n; i += 4)
{
if(pix2[i+3]!= 0 && pix2[i+3]< 128 && pix[i+3]!=0){
pix[i+3]=255-pix2[i+3];
}else if(pix2[i+3]== 128){
pix[i+3]=0;
}
//console.log(pix2[i] + "," + pix2[i+1] + "," + pix2[i+2] + "," + pix2[i+3]);
}
context.putImageData(imgd, 0, 0);
imgType = ".png";
imageName = imageName.toLowerCase();
imageName = imageName.replace(".jpg",".png");
url = canvas.toDataURL();
//console.log(canvas.toDataURL());
uploadImgBase64(imageName,url,callbackfn);
};
//切刀逻辑end
}else{
if(imgType.toLowerCase()==".png"){
url = canvas.toDataURL();
console.log(canvas.toDataURL());
}else{
url = canvas.toDataURL("image/jpeg");
console.log(canvas.toDataURL("image/jpeg"));
}
uploadImgBase64(imageName,url,callbackfn);
}

//所有图片按jpg处理,临时方案
/*imageName = imageName.toLowerCase();
imageName = imageName.replace("png","jpg");
url = canvas.toDataURL("image/jpeg");*/
}

function getTargetSize(tw,th,maxWidth,maxHeight){
if(tw/th>maxWidth/maxHeight&&tw>maxWidth){
th = th/tw*maxWidth;
tw = maxWidth;
}else if(tw/th<maxWidth/maxHeight&&th>maxHeight){
tw = tw/th*maxHeight;
th = maxHeight;
}
return {'tw':tw,'th':th};
}

function uploadImgBase64(imageName,url,callbackfn){
var data = {
'action' : 'UPLOADCANVAS',
'IMAGENAME':imageName,
'IMAGEDATA':url
//'currentElement':currentElement
};
Loading.show();
ajax({url:"/JDQW/AjaxChannel",data:data,success:function(json){
Loading.hide();
var id = $("#currentElement").val();
var filePath = json.FILEPATH;
var msg = json.MSG;
var picId = json.PIC_ID;
var pic={'id':picId,'path':filePath};
console.log("canvasUpload-msg:"+msg);
if(callbackfn){
callbackfn(id,pic,msg);
}
},
error: function(json){
jAlert("上传失败", "提示信息", "info");
}
});
}

//将$img jquery对象,修改为js对象
function uploadPicBase64($img,callbackfn,pltId){
var url = $($img).attr("src");
var imageName = $($img).data("name");
var id = $($img).parent().attr("id");
var data = {
'action' : 'UPLOADCANVAS',
'IMAGENAME':imageName,
'IMAGEDATA':url,
'PLTID':pltId
//'currentElement':currentElement
};
Loading.show();
ajax({url:"/JDQW/AjaxChannel",data:data,success:function(json){
Loading.hide();
//var id = $("#currentElement").val();
var filePath = json.FILEPATH;
var msg = json.MSG;
var picId = json.PIC_ID;
var pic={'id':picId,'path':filePath};
console.log("canvasUpload-msg:"+msg);
if(callbackfn){
callbackfn(id,pic,msg);
}
},
error: function(json){
jAlert("上传失败", "提示信息", "info");
}
});
}

function resetRatio(width, height, imgWidth, imgHeight) {
var ratio = 1;
// 先判断图片源的宽和高,是否是 宽》=高
//if (imgWidth >= imgHeight) {
//先判断是否按宽度放缩比例
//System.out.println((double)width/height+":"+(double)imgWidth/imgHeight);
if ( width/height <= imgWidth/imgHeight) {
// 再判断源宽》=最大宽度
if (imgWidth > width) {
ratio = imgWidth / width;
} else {
ratio = 1;
}
} else {
// 再判断源高》=最大高度
if (imgHeight > height) {
ratio = imgHeight / height;
} else {
ratio = 1;
}
}
return ratio;
}

canvas 多种形状绘图方法的更多相关文章

  1. html --- canvas --- javascript --- 绘图方法

    Canvas元素是HTML5的一部分,允许脚本语言动态渲染位图像. 如有疑问请访问链接:http://javascript.ruanyifeng.com/htmlapi/canvas.html < ...

  2. Canvas绘图方法和图像处理方法(转)

    转自:http://javascript.ruanyifeng.com/htmlapi/canvas.html 概述 Canvas API(画布)用于在网页实时生成图像,并且可以操作图像内容,基本上它 ...

  3. 如何使用canvas进行2d绘图

    canvas 的 2D context 可以绘制简单的 2D 图形.它的 2D context 坐标开始于 <canvas> 元素的左上角,原点坐标是(0,0).所有的坐标值都基于这个原点 ...

  4. HTML5 canvas 在线画笔绘图工具(三)

    组装画板(TDrawBuilder) 在这一小节中我们要把工具条和画板组装起来,让他们可以协同进行工作. 画板通过一个命名为TDrawBuilder来进行组装.在详细讲解TDrawBuilder对象之 ...

  5. Java Graphics2D类的绘图方法

    Graphics2D继承自Graphics,它扩展了Graphics的绘图功能,拥有更强大的二维图形处理能力,提供对几何形状.坐标转换.颜色管理以及文字布局等更精确的控制. Graphics2D定义了 ...

  6. HTML5 canvas 在线画笔绘图工具(一)

    HTML5 canvas 在线画笔绘图工具(一) 功能介绍 这是我用Javascript写的第一个程序,在写的过程中走了很多弯路,所以写完之后想分享出来,给与我一样的初学者做为学习的参考,同时在编写这 ...

  7. Java知多少(98)Graphics类的绘图方法

    Graphics类提供基本绘图方法,Graphics2D类提供更强大的绘图能力.本节讲解Graphics类,下节讲解Graphics2D. Graphics类提供基本的几何图形绘制方法,主要有:画线段 ...

  8. Java知多少(99)Graphics2D类的绘图方法

    Java语言在Graphics类提供绘制各种基本的几何图形的基础上,扩展Graphics类提供一个Graphics2D类,它拥用更强大的二维图形处理能力,提供.坐标转换.颜色管理以及文字布局等更精确的 ...

  9. 十一. 图形、图像与多媒体5.Graphics2D类的绘图方法

    Java语言在Graphics类提供绘制各种基本的几何图形的基础上,扩展Graphics类提供一个Graphics2D类,它拥用更强大的二维图形处理能力,提供.坐标转换.颜色管理以及文字布局等更精确的 ...

随机推荐

  1. K - K.Bro Sorting

    Description Matt’s friend K.Bro is an ACMer. Yesterday, K.Bro learnt an algorithm: Bubble sort. Bubb ...

  2. BZOJ 3391: [Usaco2004 Dec]Tree Cutting网络破坏( dfs )

    因为是棵树 , 所以直接 dfs 就好了... ---------------------------------------------------------------------------- ...

  3. Spring MVC整体处理流程

    一.spring整体结构 首先俯视一下spring mvc的整体结构 二.处理流程 1.请求处理的第一站就是DispatcherServlet.它是整个spring mvc的控制核心.与大多数的jav ...

  4. JAVA ANDROID SOCKET通信检测(SERVER)连接是否断开

    Pre 解决思路 代码后记: 客户端app上的部分代码 调用: 服务器上: 客户端判断服务器是否还活着代码: PRE 在利用socket写通讯程序的时候,想检测服务器是否还活着. 从网上找了很多资料, ...

  5. 嵌入式:使用dd命令制作烧写文件

    1. 使用dd命令制作烧写文件 环境: bootargs=mem=64M console=ttyAMA0,115200 root=/dev/mtdblock2 rootfstype=jffs2 mtd ...

  6. 【CSDN博客之星评选】我为什么坚持写博客

    今天无意中在CSDN的博客之星评选活动看到自己竟然是候选人之一,真的是十分的惊讶也十分的高兴.对于喜欢写东西.喜欢分享的我来说,已经忍不住用文字来记录一下今天的美好心情,同时也让我回想起我是如何开始在 ...

  7. Cloud Engine

    Cloud Engine:大杀器如何炼成   郑昀 创建于2016/6/18 最后更新于2016/6/19 点击查看我的<如何从零搭建一个技术平台>,这是一个系列.转载时请注明“转载自旁观 ...

  8. [Boost]boost的时间和日期处理-(1)日期的操作

    <开篇> Boost.DateTime库提供了时间日期相关的计算.格式化.转换.输入输出等等功能,为C++的编程提供了便利.不过它有如下特点: 1. Boost.DateTime 只支持1 ...

  9. BIRT使用2:安装、一般使用顺序

    上篇博客介绍的关于的birt的一些概念和设计器等知识,这篇博客介绍一下安装和一般使用顺序. 安装:安装分为两种,一种是下载已经安装好birt的eclipseIDE环境,配置环境变量之后即可使用,具体方 ...

  10. SAP 金税接口介绍

    一.金税发票与SAP系统发票的税额差异分析 1.1 金税系统中的税额说明 国内企业销售产品给国内客户时,正常产品须要缴纳17%的增值税,而金税(Golden Tax)系统就是用来出具纸面的增值税发票的 ...