国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > JavaScript > 正文

js生成縮略圖后上傳并利用canvas重繪

2019-11-20 15:22:03
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
一般在處理圖片上傳時(shí),通常的邏輯都是將源圖片上傳到服務(wù)器端,再由服務(wù)器端的語(yǔ)言進(jìn)行縮放大小的操作。

此種模式一般可以滿足大部分的需求,但當(dāng)我們所需要的圖片僅僅是一個(gè)符合規(guī)定大小的源圖片的縮略圖,再使用此種模式,將是一種浪費(fèi)服務(wù)端資源以及帶寬的方式,故我們考慮在瀏覽器端生成小圖后再進(jìn)行上傳操作。

//以下為源代碼
復(fù)制代碼 代碼如下:

function drawCanvasImage(obj,width, callback){

var $canvas = $('<canvas></canvas>'),
canvas = $canvas[0],
context = canvas.getContext('2d');

var img = new Image();

img.onload = function(){
if(width){
if(width > img.width){
var target_w = img.width;
var target_h = img.height;
}else{
var target_w = width;
var target_h = parseInt(target_w/img.width*img.height);
}
}else{
var target_w = img.width;
var target_h = img.height;
}
$canvas[0].width = target_w;
$canvas[0].height = target_h;

context.drawImage(img,0,0,target_w,target_h);

_canvas = canvas.toDataURL();
/*console.log(_canvas);*/
callback(obj,_canvas);
}
img.src = getFullPath(obj);

}

function getFullPath(obj)
{
if(obj)
{
//ie
if (window.navigator.userAgent.indexOf("MSIE")>=1)
{
obj.select();
return document.selection.createRange().text;
}
//firefox
else if(window.navigator.userAgent.indexOf("Firefox")>=1 || $.browser.opera || $.browser.mozilla)
{
if(obj.files && window.URL.createObjectURL)
{
return window.URL.createObjectURL(obj.files[0]);
}
return obj.value;
}else if($.browser.safari){
if(window.webkitURL.createObjectURL && obj.files){
return window.webkitURL.createObjectURL(obj.files[0]);
}
return obj.value;
}
return obj.value;
}
}

函數(shù)getFullPath為獲取選中的圖片的地址。

_canvas獲取到的是base64編碼的圖片編碼,將其傳輸?shù)胶蠖藢懭胛募纯伞?
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 师宗县| 涞源县| 弥勒县| 内黄县| 米脂县| 恩平市| 大化| 泰安市| 桐乡市| 锡林郭勒盟| 遂昌县| 邳州市| 镇安县| 新和县| 武川县| 江西省| 尼木县| 镇坪县| 诏安县| 乳源| 东平县| 周至县| 外汇| 大同市| 西宁市| 邹平县| 永宁县| 古田县| 安仁县| 大英县| 余干县| 广饶县| 武威市| 抚顺县| 吐鲁番市| 宜昌市| 马边| 永顺县| 重庆市| 永宁县| 元阳县|