jQuery canvas draws picture verification code example

jQuery canvas draws picture verification code example

This article example shares the specific code of jquery canvas drawing picture verification code for your reference. The specific content is as follows

CSS

.identify-code{
    position: absolute;
    right: 6px;
    top: 50%;
    width: 118px;
    height: 40px;
    margin: -21px 0 0 0;
}

HTML

<span id="code" class="identify-code">
  <canvas class="show-captcha" id="canvas" style="width: 100%; height: 100%;"></canvas>
</span>

JS

/**Draw the verification code image**/
function drawPic() {
    var canvas = document.getElementById("canvas");
    var width = canvas.width;
    var height = canvas.height;
    //Get the 2D drawing environment of the canvas var ctx = canvas.getContext('2d'); 
    ctx.textBaseline = 'bottom';
    /**Draw the background color**/
    ctx.fillStyle = randomColor(180, 240);
    //If the color is too dark, it may not be clear ctx.fillRect(0,0,width,height);
    /**Draw text**/
    var str ='ABCEFGHJKLMNPQRSTWXY123456789abcefghjklmnpqrstwxy';
    var code="";
    //Generate four verification codes for(var i = 1;i <= 4; i++) {
        var txt = str[randomNum(0,str.length)];
        code=code+txt;
        ctx.fillStyle = randomColor(50,160);
        //Randomly generate font color ctx.font = randomNum(90,110) +'px SimHei';
        // Randomly generate font size var x = 10 + i * 50;
        var y = randomNum(100, 135);
        var deg = randomNum(-30, 30);
        //Modify the coordinate origin and rotation angle ctx.translate(x, y); 
        ctx.rotate(deg * Math.PI /180); 
        ctx.fillText(txt,0,0);
        //Restore the coordinate origin and rotation angle ctx.rotate(-deg * Math.PI /180);
        ctx.translate(-x, -y);
    }
        
    /**Draw interference line**/
    for(var i=0;i<3;i++) {
        ctx.strokeStyle = randomColor(40, 180);
        ctx.beginPath();
        ctx.moveTo(randomNum(0,width/2), randomNum(0,height/2));
        ctx.lineTo(randomNum(0,width/2), randomNum(0,height));
        ctx.stroke();
    }
    /**Draw interference points**/
    for(var i=0;i <50;i++) {
        ctx.fillStyle = randomColor(255);
        ctx.beginPath();
        ctx.arc(randomNum(0, width), randomNum(0, height),1,0,2* Math.PI);
        ctx.fill();
    }
    return code;
}
/**Generate a random number**/
function randomNum(min, max) {
    return Math.floor(Math.random() * (max - min) + min);
}
/**Generate a random color**/
function randomColor(min, max) {
    var r = randomNum(min, max);
    var g = randomNum(min, max);
    var b = randomNum(min, max);
    return "rgb(" + r + "," + g + "," + b + ")";
}

Calling Instance

$("#code").unbind('click').click(function(e){
    e.preventDefault();
    createCode();
});
//Generate verification code function createCode(){
  VerificationCodeErrCount = 0;
  randomCode = drawPic();
  return randomCode;
}

The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM.

You may also be interested in:
  • JQuery implements a simple verification code prompt solution
  • jQuery implements the countdown code for sending verification code by mobile phone
  • jQuery implements sending verification code and 60-second countdown function
  • Jquery plug-in to prevent re-obtaining within 60 seconds after clicking to obtain the verification code
  • jQuery plugin to implement static HTML verification code verification
  • jQuery click to get the verification code button and countdown function
  • jQuery implements verification code function
  • jQuery implements a simple verification code function
  • jQuery implements form to obtain SMS verification code
  • jQuery implements the countdown effect code sharing of sending verification code by mobile phone

<<:  Web page creation basic declaration document type description (DTD

>>:  Practical record of MySQL 5.6 master-slave error reporting

Recommend

SQL-based query statements

Table of contents 1. Basic SELECT statement 1. Qu...

Learn MySQL execution plan

Table of contents 1. Introduction to the Implemen...

Six-step example code for JDBC connection (connecting to MySQL)

Six steps of JDBC: 1. Register the driver 2. Get ...

How to mount a new disk on a Linux cloud server

background A new server was added in the company,...

Mysql Chinese sorting rules description

When using MySQL, we often sort and query a field...

Let's talk about the difference between containers and images in Docker

What is a mirror? An image can be seen as a file ...

Detailed tutorial on using VMware WorkStation with Docker for Windows

Table of contents 1. Introduction 2. Install Dock...

The most commonly used HTML escape sequence

In HTML, <, >, &, etc. have special mean...

Detailed explanation of box-sizing in CSS3 (content-box and border-box)

Box-sizing in CSS3 (content-box and border-box) T...

Analysis of MySQL's method of exporting to Excel

This article describes how to use MySQL to export...

CSS style solves the problem of displaying ellipsis when the text is too long

1. CSS style solves the problem of displaying ell...

Summary of MySql index, lock, and transaction knowledge points

This article summarizes the knowledge points of M...