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

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

JS+HTML5 canvas繪制驗(yàn)證碼示例

2019-11-19 12:24:24
字體:
供稿:網(wǎng)友

本文實(shí)例講述了JS+HTML5 canvas繪制驗(yàn)證碼。分享給大家供大家參考,具體如下:

css樣式:

<style>body{  text-align: center;}canvas{  background:#ddd;}</style>

HTML部分:

body中添加標(biāo)簽canvas:

<canvas id="c3"></canvas>

js部分:

//創(chuàng)建兩個(gè)變量保存驗(yàn)證碼的寬度和高度  var w = 120;  var h = 30;//將變量值賦值給canvas  c3.width = w;  c3.height = h;//獲取畫筆  var ctx = c3.getContext("2d");//創(chuàng)建兩個(gè)函數(shù),返回指定范圍內(nèi)的隨機(jī)數(shù),隨機(jī)顏色//隨機(jī)數(shù)  function rn(min,max){    var n = Math.random()*(max-min)+min;    return Math.floor(n);  }//隨機(jī)顏色  function rc(min,max){    var r = rn(min,max);    var g = rn(min,max);    var b = rn(min,max);    return `rgb(${r},${g},${b})`;}//填充的背景  ctx.fillStyle=rc(180,230);  ctx.fillRect(0,0,w,h);//創(chuàng)建一個(gè)隨機(jī)的文字[字母和數(shù)字]4個(gè)  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個(gè)干擾點(diǎn)  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前端代碼調(diào)試運(yùn)行工具http://tools.VeVB.COm/code/WebCodeRun,測(cè)試上述代碼運(yùn)行效果。

或者使用在線HTML/CSS/JavaScript代碼運(yùn)行工具http://tools.VeVB.COm/code/HtmlJsRun,測(cè)試如下完整示例代碼:

<!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>m.survivalescaperooms.com canvas繪制驗(yàn)證碼</title><style>body{  text-align: center;}canvas{  background:#ddd;}</style></head><body><canvas id="c3"></canvas><script>//創(chuàng)建兩個(gè)變量保存驗(yàn)證碼的寬度和高度  var w = 120;  var h = 30;//將變量值賦值給canvas  c3.width = w;  c3.height = h;//獲取畫筆  var ctx = c3.getContext("2d");//創(chuàng)建兩個(gè)函數(shù),返回指定范圍內(nèi)的隨機(jī)數(shù),隨機(jī)顏色//隨機(jī)數(shù)  function rn(min,max){    var n = Math.random()*(max-min)+min;    return Math.floor(n);  }//隨機(jī)顏色  function rc(min,max){    var r = rn(min,max);    var g = rn(min,max);    var b = rn(min,max);    return `rgb(${r},${g},${b})`;}//填充的背景  ctx.fillStyle=rc(180,230);  ctx.fillRect(0,0,w,h);//創(chuàng)建一個(gè)隨機(jī)的文字[字母和數(shù)字]4個(gè)  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個(gè)干擾點(diǎn)  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>

運(yùn)行結(jié)果如下:

更多關(guān)于JavaScript相關(guān)內(nèi)容還可查看本站專題:《JavaScript+HTML5特效與技巧匯總》、《JavaScript圖形繪制技巧總結(jié)》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)

希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 定远县| 泰州市| 太和县| 临颍县| 浮山县| 巴彦县| 昌乐县| 沂南县| 阿克陶县| 肃南| 乐业县| 辽阳市| 阿坝| 建阳市| 固安县| 蒲江县| 子长县| 普陀区| 宜城市| 疏附县| 交口县| 昌乐县| 保定市| 东乌| 蒲城县| 那坡县| 广灵县| 凯里市| 大竹县| 漳州市| 武川县| 泰和县| 武乡县| 政和县| 壤塘县| 阜康市| 鄂尔多斯市| 辽阳市| 澳门| 夏河县| 明星|