本文實例講述了JS+HTML5 canvas繪制驗證碼。分享給大家供大家參考,具體如下:
css樣式:
<style> body{ text-align: center; } canvas{ background:#ddd; } </style>
HTML部分:
body中添加標簽canvas:
<canvas id="c3"></canvas>
js部分:
//創建兩個變量保存驗證碼的寬度和高度 var w = 120; var h = 30; //將變量值賦值給canvas c3.width = w; c3.height = h; //獲取畫筆 var ctx = c3.getContext("2d"); //創建兩個函數,返回指定范圍內的隨機數,隨機顏色 //隨機數 function rn(min,max){ var n = Math.random()*(max-min)+min; return Math.floor(n); } //隨機顏色 function rc(min,max){ var r = rn(min,max); var g = rn(min,max); var b = rn(min,max); return `rgb(${r},${g},$)`; } //填充的背景 ctx.fillStyle=rc(180,230); ctx.fillRect(0,0,w,h); //創建一個隨機的文字[字母和數字]4個 var pool = "ABCDEFGHIJKabced胡歌0123456789哈哼哈哈"; var str =""; for(var i = 0;i<4;i++){ var index = Math.floor(Math.random()*pool.length); str +=pool[index]; } //console.log(str); ctx.font = "30px SimHei"; ctx.fillStyle = rc(80,180);//文字顏色 ctx.textBaseline="top"; ctx.fillText(str,20,0);//在(20,0)處開始填充文字 //繪制6條干擾線 for(var i = 0;i<6;i++){ ctx.strokeStyle = rc(0,255); ctx.beginPath(); ctx.moveTo(rn(0,w),rn(0,h)); ctx.lineTo(rn(0,w),rn(0,h)); ctx.stroke(); } //繪制50個干擾點 for(var i = 0;i<50;i++){ ctx.fillStyle = rc(0,255); ctx.beginPath(); ctx.arc(rn(0,w),rn(0,h),1,0,2*Math.PI); ctx.fill(); }
感興趣的朋友可以使用在線HTML/CSS/JavaScript前端代碼調試運行工具:http://tools.jb51.net/code/WebCodeRun,測試上述代碼運行效果。
或者使用在線HTML/CSS/JavaScript代碼運行工具:http://tools.jb51.net/code/HtmlJsRun,測試如下完整示例代碼:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>www.jb51.net canvas繪制驗證碼</title> <style> body{ text-align: center; } canvas{ background:#ddd; } </style> </head> <body> <canvas id="c3"></canvas> <script> //創建兩個變量保存驗證碼的寬度和高度 var w = 120; var h = 30; //將變量值賦值給canvas c3.width = w; c3.height = h; //獲取畫筆 var ctx = c3.getContext("2d"); //創建兩個函數,返回指定范圍內的隨機數,隨機顏色 //隨機數 function rn(min,max){ var n = Math.random()*(max-min)+min; return Math.floor(n); } //隨機顏色 function rc(min,max){ var r = rn(min,max); var g = rn(min,max); var b = rn(min,max); return `rgb(${r},${g},$)`; } //填充的背景 ctx.fillStyle=rc(180,230); ctx.fillRect(0,0,w,h); //創建一個隨機的文字[字母和數字]4個 var pool = "ABCDEFGHIJKabced胡歌0123456789哈哼哈哈"; var str =""; for(var i = 0;i<4;i++){ var index = Math.floor(Math.random()*pool.length); str +=pool[index]; } //console.log(str); ctx.font = "30px SimHei"; ctx.fillStyle = rc(80,180);//文字顏色 ctx.textBaseline="top"; ctx.fillText(str,20,0);//在(20,0)處開始填充文字 //繪制6條干擾線 for(var i = 0;i<6;i++){ ctx.strokeStyle = rc(0,255); ctx.beginPath(); ctx.moveTo(rn(0,w),rn(0,h)); ctx.lineTo(rn(0,w),rn(0,h)); ctx.stroke(); } //繪制50個干擾點 for(var i = 0;i<50;i++){ ctx.fillStyle = rc(0,255); ctx.beginPath(); ctx.arc(rn(0,w),rn(0,h),1,0,2*Math.PI); ctx.fill(); } </script> </body> </html>
運行結果如下:
更多關于JavaScript相關內容還可查看本站專題:《JavaScript+HTML5特效與技巧匯總》、《JavaScript圖形繪制技巧總結》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結》
希望本文所述對大家JavaScript程序設計有所幫助。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。