canvas是一個可以讓我們使用腳本繪圖的標籤,它提供了一系列完整的屬性和方法。我們可以藉此來實現圖形繪製,圖像處理甚至實現簡單的動畫和遊戲製作。
canvas標籤只有兩個屬性:width和height,用來設定畫布的寬和高,如果沒有透過標籤屬性或腳本來設置,預設為300*150;
好了,canvas的介紹就先到這裡,下面我們來看看javascript結合canvas實作圖片的裁切程式碼:
var selectObj = null;
function ImageCrop(canvasId, imageSource, x, y, width, height) {
var canvas = $("#" canvasId);
if (canvas.length == 0 && imageSource) {
返回;
}
函數canvasMouseDown(e) {
停止選擇(e);
canvas.css("遊標", "預設");
}
函數canvasMouseMove(e) {
var canvasOffset = canvas.offset();
var pageX = e.pageX || event.targetTouches[0].pageX;
var pageY = e.pageY || event.targetTouches[0].pageY;
iMouseX = Math.floor(pageX - canvasOffset.left);
iMouseY = Math.floor(pageY - canvasOffset.top);
canvas.css("遊標", "預設");
if (selectObj.bDragAll) {
canvas.css("遊標", "移動");
canvas.data("拖曳", true);
var cx = iMouseX - selectObj.px;
CX = CX mx = ctx.canvas.width - selectObj.w;
cx=cx> MX? mx : cx;
selectObj.x = cx;
var cy = iMouseY - selectObj.py;
cy=cy< 0 ? 0 : cy;
my = ctx.canvas.height - selectObj.h;
cy=cy>我的 ?我的:cy;
selectObj.y = cy;
}
for (var i = 0; i selectObj.bHow[i] = false;
selectObj.iCSize[i] = selectObj.csize;
}
// 將滑鼠停留在調整大小的立方體上
if (iMouseX > selectObj.x - selectObj.csizeh && iMouseX iMouseY> selectObj.y - selectObj.csizeh && iMouseY canvas.css("遊標", "指標");
selectObj.bHow[0] = true;
selectObj.iCSize[0] = selectObj.csizeh;
}
if (iMouseX > selectObj.x selectObj.w - selectObj.csizeh && iMouseX iMouseY> selectObj.y - selectObj.csizeh && iMouseY canvas.css("遊標", "指標");
selectObj.bHow[1] = true;
selectObj.iCSize[1] = selectObj.csizeh;
}
if (iMouseX > selectObj.x selectObj.w - selectObj.csizeh && iMouseX iMouseY> selectObj.y selectObj.h - selectObj.csizeh && iMouseY selectObj.bHow[2] = true;
selectObj.iCSize[2] = selectObj.csizeh;
}
if (iMouseX > selectObj.x - selectObj.csizeh && iMouseX iMouseY> selectObj.y selectObj.h - selectObj.csizeh && iMouseY canvas.css("螢幕", "指標");
selectObj.bHow[3] = true;
selectObj.iCSize[3] = selectObj.csizeh;
}
if (iMouseX > selectObj.x && iMouseX selectObj.y && iMouseY canvas.css("左上角", "移動");
}
//如果拖曳調整立方體大小
var iFW、iFH、iFX、iFY、mx、我的;
if (selectObj.bDrag[0]) {
iFX = iMouseX - selectObj.px;
iFY = iMouseY - selectObj.py;
iFW = selectObj.w selectObj.x - iFX;
iFH = selectObj.h selectObj.y - iFY;
canvas.data("拖曳", true);
}
if (selectObj.bDrag[1]) {
iFX = selectObj.x;
iFY = iMouseY - selectObj.py;
iFW = iMouseX - selectObj.px - iFX;
iFH = selectObj.h selectObj.y - iFY;
canvas.data("拖曳", true);
}
if (selectObj.bDrag[2]) {
iFX = selectObj.x;
iFY = selectObj.y;
iFW = iMouseX - selectObj.px - iFX;
iFH = iMouseY - selectObj.py - iFY;
canvas.data("拖曳", true);
}
if (selectObj.bDrag[3]) {
iFX = iMouseX - selectObj.px;
iFY = selectObj.y;
iFW = selectObj.w selectObj.x - iFX;
iFH = iMouseY - selectObj.py - iFY;
canvas.data("拖曳", true);
}
if (iFW > selectObj.csizeh * 2 && iFH > selectObj.csizeh * 2) {
selectObj.w = iFW;
selectObj.h = iFH;
selectObj.x = iFX;
selectObj.y = iFY;
}
相關場景();
}
函數canvasMouseOut() {
$(canvas).trigger("mouseup");
}
函數canvasMouseUp() {
selectObj.bDragAll = false;
for (var i = 0; i selectObj.bDrag[i] = false;
}
canvas.css("遊標", "預設");
canvas.data("選擇", {
x: selectObj.x,
y: selectObj.y,
w: selectObj.w,
h: selectObj.h
});
selectObj.px = 0;
selectObj.py = 0;
}
函數選擇(x, y, w, h) {
這個.x = x; // 初始位置
this.y = y;
這個.w = w; // 和大小
this.h = h;
這個.px = x; // 用來拖曳計算的額外變數
this.py = y;
這個.csize = 4; // 調整立方體大小
this.csizeh = 6; // 調整立方體大小(懸停時)
this.bHow = [假,假,假,假]; // 懸停狀態
this.iCSize = [this.csize, this.csize, this.csize, this.csize]; // 調整立方體大小
this.bDrag = [假,假,假,假]; // 拖曳狀態
this.bDragAll = false; // 拖曳整個選擇
}
Selection.prototype.draw = function () {
ctx.StrongStyle = '#666';
ctx.lineWidth = 2;
ctx.lines(this.x, this.y, this.w, this.h);
// 繪製原始影像的一部份
if (this.w > 0 && this.h > 0) {
ctx.drawImage(映像, this.x, this.y, this.w, this.h, this.x, this.y, this.w, this.h);
}
// 繪製調整大小的立方體
ctx.fillStyle = '#999';
ctx.fillRect(this.x - this.iCSize[0], this.y - this.iCSize[0], this.iCSize[0] * 2, this.iCSize[0] * 2);
ctx.fillRect(this.x this.w - this.iCSize[1], this.y - this.iCSize[1], this.iCSize[1] * 2, this.iCSize[1] * 2);
ctx.fillRect(this.x this.w - this.iCSize[2], this.y this.h - this.iCSize[2], this.iCSize[2] * 2, this.iCSize[2] * 2) ;
ctx.fillRect(this.x - this.iCSize[3], this.y this.h - this.iCSize[3], this.iCSize[3] * 2, this.iCSize[3] * 2);
};
var drawScene = function () {
ctx.clearRect(0, 0, ctx.canvas.width, ctx.canvas.height); // 清除畫布
// 繪製來源影像
ctx.drawImage(image, 0, 0, ctx.canvas.width, ctx.canvas.height);
// 並使其變暗
ctx.fillStyle = 'rgba(0, 0, 0, 0.5)';
ctx.fillRect(0, 0, ctx.canvas.width, ctx.canvas.height);
// 繪製選區
selectObj.draw();
canvas.mousedown(canvasMouseDown);
canvas.on("touchstart", canvasMouseDown);
};
var createSelection = function (x, y, width, height) {
var content = $("#imagePreview");
x = x || Math.ceil((content.width() - 寬度) / 2);
y = y || Math.ceil((content.height() - 高度) / 2);
回新的選擇(x,y,寬度,高度);
};
var ctx = canvas[0].getContext("2d");
var iMouseX = 1;
var iMouseY = 1;
var image = new Image();
image.onload = function () {
selectObj = createSelection(x, y, 寬度, 高度);
canvas.data("選擇", {
x: selectObj.x,
y: selectObj.y,
w: selectObj.w,
h: selectObj.h
});
繪製場景();
};
image.src = imageSource;
canvas.mousemove(canvasMouseMove);
canvas.on("touchmove", canvasMouseMove);
var StopSelect = function (e) {
var canvasOffset = $(canvas).offset();
var pageX = e.pageX || event.targetTouches[0].pageX;
var pageY = e.pageY || event.targetTouches[0].pageY;
iMouseX = Math.floor(pageX - canvasOffset.left);
iMouseY = Math.floor(pageY - canvasOffset.top);
selectObj.px = iMouseX - selectObj.x;
selectObj.py = iMouseY - selectObj.y;
if (selectObj.bHow[0]) {
selectObj.px = iMouseX - selectObj.x;
selectObj.py = iMouseY - selectObj.y;
}
if (selectObj.bHow[1]) {
selectObj.px = iMouseX - selectObj.x - selectObj.w;
selectObj.py = iMouseY - selectObj.y;
}
if (selectObj.bHow[2]) {
selectObj.px = iMouseX - selectObj.x - selectObj.w;
selectObj.py = iMouseY - selectObj.y - selectObj.h;
}
if (selectObj.bHow[3]) {
selectObj.px = iMouseX - selectObj.x;
selectObj.py = iMouseY - selectObj.y - selectObj.h;
}
if (iMouseX > selectObj.x selectObj.csizeh &&
iMouseX iMouseY> selectObj.y selectObj.csizeh &&
iMouseY selectObj.bDragAll = true;
}
for (var i = 0; i if (selectObj.bHow[i]) {
selectObj.bDrag[i] = true;
}
}
};
canvas.mouseout(canvasMouseOut);
canvas.mouseup(canvasMouseUp);
canvas.on("touchend", canvasMouseUp);
this.getImageData = function (previewID) {
var tmpCanvas = $("")[0];
var tmpCtx = tmpCanvas.getContext("2d");
if (tmpCanvas && selectObj) {
tmpCanvas.width = selectObj.w;
tmpCanvas.height = selectObj.h;
tmpCtx.drawImage(image, selectObj.x, selectObj.y, selectObj.w, selectObj.h, 0, 0, selectObj.w, selectObj.h);
if (document.getElementById(previewID)) {
document.getElementById(previewID).src = tmpCanvas.toDataURL();
document.getElementById(previewID).style.border = "1px 實心#ccc";
}
return tmpCanvas.toDataURL();
}
};
}
函數 autoResizeImage(maxWidth, maxHeight, objImg) {
var img = new Image();
img.src = objImg.src;
var hRatio;
var wRatio;
無功分數 = 1;
var w = objImg.width;
var h = objImg.height;
wRatio = maxWidth / w;
hRatio = maxHeight / h;
if (w 返回;
}
if (maxWidth == 0 && maxHeight == 0) {
份數 = 1;
} else if (maxWidth == 0) {
if (hRatio 分別 = hRatio;
}
} else if (maxHeight == 0) {
if (wRatio 比例 = wRatio;
}
} else if (wRatio 其中 = (wRatio }其他{
其中 = (wRatio }
if (共有 if (比率 各個 = 1 - 各個;
}
w = w * 各;
h = h * 各;
}
objImg.height = h;
objImg.width = w;
}
朋友們拿去試試吧,希望大家能夠喜歡,有疑問就給我留言吧。

JavaScript是現代網站的核心,因為它增強了網頁的交互性和動態性。 1)它允許在不刷新頁面的情況下改變內容,2)通過DOMAPI操作網頁,3)支持複雜的交互效果如動畫和拖放,4)優化性能和最佳實踐提高用戶體驗。

C 和JavaScript通過WebAssembly實現互操作性。 1)C 代碼編譯成WebAssembly模塊,引入到JavaScript環境中,增強計算能力。 2)在遊戲開發中,C 處理物理引擎和圖形渲染,JavaScript負責遊戲邏輯和用戶界面。

JavaScript在網站、移動應用、桌面應用和服務器端編程中均有廣泛應用。 1)在網站開發中,JavaScript與HTML、CSS一起操作DOM,實現動態效果,並支持如jQuery、React等框架。 2)通過ReactNative和Ionic,JavaScript用於開發跨平台移動應用。 3)Electron框架使JavaScript能構建桌面應用。 4)Node.js讓JavaScript在服務器端運行,支持高並發請求。

Python更適合數據科學和自動化,JavaScript更適合前端和全棧開發。 1.Python在數據科學和機器學習中表現出色,使用NumPy、Pandas等庫進行數據處理和建模。 2.Python在自動化和腳本編寫方面簡潔高效。 3.JavaScript在前端開發中不可或缺,用於構建動態網頁和單頁面應用。 4.JavaScript通過Node.js在後端開發中發揮作用,支持全棧開發。

C和C 在JavaScript引擎中扮演了至关重要的角色,主要用于实现解释器和JIT编译器。1)C 用于解析JavaScript源码并生成抽象语法树。2)C 负责生成和执行字节码。3)C 实现JIT编译器,在运行时优化和编译热点代码,显著提高JavaScript的执行效率。

JavaScript在現實世界中的應用包括前端和後端開發。 1)通過構建TODO列表應用展示前端應用,涉及DOM操作和事件處理。 2)通過Node.js和Express構建RESTfulAPI展示後端應用。

JavaScript在Web開發中的主要用途包括客戶端交互、表單驗證和異步通信。 1)通過DOM操作實現動態內容更新和用戶交互;2)在用戶提交數據前進行客戶端驗證,提高用戶體驗;3)通過AJAX技術實現與服務器的無刷新通信。

理解JavaScript引擎內部工作原理對開發者重要,因為它能幫助編寫更高效的代碼並理解性能瓶頸和優化策略。 1)引擎的工作流程包括解析、編譯和執行三個階段;2)執行過程中,引擎會進行動態優化,如內聯緩存和隱藏類;3)最佳實踐包括避免全局變量、優化循環、使用const和let,以及避免過度使用閉包。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

Atom編輯器mac版下載
最受歡迎的的開源編輯器

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

SublimeText3漢化版
中文版,非常好用

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。