国产探花免费观看_亚洲丰满少妇自慰呻吟_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ā)表
主站蜘蛛池模板: 汝阳县| 措勤县| 晋州市| 东乌珠穆沁旗| 原阳县| 县级市| 磴口县| 股票| 抚州市| 田阳县| 永平县| 沁源县| 福贡县| 防城港市| 临安市| 池州市| 根河市| 孟津县| 海兴县| 合川市| 慈溪市| 南平市| 微山县| 江达县| 靖边县| 婺源县| 遂宁市| 桃园市| 诸暨市| 松溪县| 西贡区| 丰台区| 北票市| 墨玉县| 龙里县| 阳谷县| 五原县| 康保县| 芜湖市| 孟津县| 桂平市|