首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > CSS >

HTML5(6)preserve and recover

2012-11-13 
HTML5(六)preserve and recoverHTML5(六)preserve and recover1. save the state of canvas context2. So

HTML5(六)preserve and recover
HTML5(六)preserve and recover

1. save the state of canvas context
2. So we have two method to save and restore the state of Context
save()
restore()

it works like stack.

3. magic change

translate(dx,dy)
change the (0,0) point from the original (0,0), the original point (x,y) will be
x'=x+dx
y'=y+dy
eg:ctx.translate(5,8)

scale(sx,sy)
sx,sy is the enlarge and reduce factor, the original point(x,y) will be
x' = x * sx
y' = y * sy

rotate(a)
angle, the original point(x,y) will be
x'=x cosA - y sinA
y'=x sinA + y cosA

transform(m11,m12,m21,m22,dx,dy)
m11m21dx
m12m22dy
001
translate(dx,dy):equal transform(1,0,0,1,dx,dy)
scale(sx,xy):equal transform(sx,0,0,sy,0,0)
rotate(A):equal transform(cosA,sinA,-sinA,cosA,0,0)

4. Group
Group is the situation that one picture in over another picture.
ctx.globalCompositeOperation = type
There are 12 types:
source-over 
source-in
source-out

5. Clip
my sample file test6.html:
<canvas id="canvas1" width="250" height="300"
    onmousedown="trans.transform(event);"
    onmouseup="trans.init(event);"
    onmousemove="trans.translate(event);"
    style="background-color:black">
    you are out!
</canvas>

<br/>
<input type="radio" name="r" id="r1" checked="checked">Move<br />
<input type="radio" name="r" id="r2">Large&Small<br />
<input type="radio" name="r"  id="r3">Circle<br />
<input type="radio" name="r"  id="r4">Large&Small&Circle<br />

<canvas id="canvas3" width="250" height="300" style="background-color:black">
    You are out!
</canvas><br/>
<input type="button" onclick="move(1);" value="Move1">
<input type="button" onclick="move(2);" value="Move2">
<input type="button" onclick="stop();" value="Stop"><br />
        <div>
            <table>
                <tr>
                    <td><canvas id="tut0" width="125" height="125"></canvas><br/><label id="lab0"></label></td>
                <td><canvas id="tut1" width="125" height="125"></canvas><br/><label id="lab1"></label></td>
                <td><canvas id="tut2" width="125" height="125"></canvas><br/><label id="lab2"></label></td>
                <td><canvas id="tut3" width="125" height="125"></canvas><br/><label id="lab3"></label></td>
                </tr>
                <tr>
                    <td><canvas id="tut4" width="125" height="125"></canvas><br/><label id="lab4"></label></td>
                <td><canvas id="tut5" width="125" height="125"></canvas><br/><label id="lab5"></label></td>
                <td><canvas id="tut6" width="125" height="125"></canvas><br/><label id="lab6"></label></td>
                <td><canvas id="tut7" width="125" height="125"></canvas><br/><label id="lab7"></label></td>
                </tr>
                <tr>
                    <td><canvas id="tut8" width="125" height="125"></canvas><br/><label id="lab8"></label></td>
                <td><canvas id="tut9" width="125" height="125"></canvas><br/><label id="lab9"></label></td>
                <td><canvas id="tut10" width="125" height="125"></canvas><br/><label id="lab10"></label></td>
                <td><canvas id="tut11" width="125" height="125"></canvas><br/><label id="lab11"></label></td>
                </tr>
            </table>
        </div>

<script type="text/javascript">
    IMG_SRC='';

    //==========================================
    //trans class
    //==========================================
    function Transform(){
        this.ctx = document.getElementById("canvas1").getContext("2d");
        this.img=new Image();
        this.img.src=IMG_SRC;
        this.interval = null;
        // mouse satus
        this.pressed=false;
        this.init();
    }
   
    //init picture
    Transform.prototype.init=function(){
        //mouse status
        this.pressed=false;
        //stop timer
        if(this.interval){
        clearInterval(this.interval);
        }
        //changing value
        this.delta = 0.06;
        //clear
        this.ctx.clearRect(0,0,250,300);
        //paint
        this.paint();
    }
   
    //paint
    Transform.prototype.paint=function(){
        var that=this;
        var img=this.img
        if(img.complete)
            that.ctx.drawImage(img,0,0);
        else
            var interval = setInterval(function(){
                if(img.complete){
                    that.ctx.drawImage(img,0,0);
                    clearInterval(interval);
                }
            },300);
    }
   
    //press, begin changing
    Transform.prototype.transform = function(){
        //get the point
        this.dx=event.offsetX;
        this.dy=event.offsetY;
        //get the point
        this.startx=event.offsetX;
        this.starty=event.offsetY;
        //scale
        this.sc=1;
        //circle
        this.angle=0;
       
        var that=this;
        if(document.getElementById("r1").checked)
            this.pressed=true;
        else if(document.getElementById("r2").checked)
            this.interval = setInterval(function(){that.scale()},50);
        else if((document.getElementById("r3").checked))
            this.interval = setInterval(function(){that.rotate()},50);
        else
            this.interval = setInterval(function(){that.scaleAndRotate()},50);
    }
   
    //move
    Transform.prototype.translate = function(){
        this.ddx=event.offsetX-this.startx;
        this.ddy=event.offsetY-this.starty;
        if(this.pressed){
            //clear
            this.ctx.clearRect(0,0,250,300);
            //save state
            this.ctx.save();
            //move
            this.ctx.translate(this.ddx,this.ddy);
            this.paint();
            this.ctx.fillStyle="red";
            this.ctx.fillRect(this.dx-5,this.dy-5,10,10);
            //restore
            this.ctx.restore();
        }
    }

    //small & large
    Transform.prototype.scale = function(){
        this.ctx.clearRect(0,0,250,300);
        this.sc=this.sc - this.delta;
        if(this.sc<0.2 || this.sc>2)
            this.delta = -this.delta;
        this.ctx.save();
        //from (dx,dy) (sx,sy):transform(sx, 0, 0, sy, dx(1-sx), dy(1-sy))
        this.ctx.transform(this.sc, 0, 0, this.sc, this.dx*(1-this.sc), this.dy*(1-this.sc))
        this.paint();
        this.ctx.fillStyle="red";
        this.ctx.fillRect(this.dx-5,this.dy-5,10,10);
        this.ctx.restore();
    }
   
    //circle
    Transform.prototype.rotate = function(){
        this.ctx.clearRect(0,0,250,300);
        var PI = Math.PI;
        this.angle=this.angle + PI/60;
        this.ctx.save();
        //from (dx,dy) circle A:transform(cosA, sinA, -sinA, cosA, dx(1-cosA) + dysinA, dy(1-cosA) - dxsinA)
        this.ctx.transform(Math.cos(this.angle), Math.sin(this.angle),
                -Math.sin(this.angle), Math.cos(this.angle),
                this.dx*(1-Math.cos(this.angle)) + this.dy*Math.sin(this.angle),
                this.dy*(1-Math.cos(this.angle)) - this.dx*Math.sin(this.angle))
        this.paint();
        this.ctx.fillStyle="red";
        this.ctx.fillRect(this.dx-5,this.dy-5,10,10);
        this.ctx.restore();
    }
   
    //Circle and large small
    Transform.prototype.scaleAndRotate = function(){
        this.ctx.clearRect(0,0,250,300);
        this.sc=this.sc - this.delta;
        if(this.sc<0.2 || this.sc>2)
            this.delta = -this.delta;
        var PI = Math.PI;
        this.angle=this.angle + PI/60;
        this.ctx.save();
        this.ctx.translate(this.dx,this.dy);
        this.ctx.scale(this.sc,this.sc);
        this.ctx.rotate(this.angle);
        this.ctx.translate(-this.dx,-this.dy);
        this.paint();
        this.ctx.fillStyle="red";
        this.ctx.fillRect(this.dx-5,this.dy-5,10,10);
        this.ctx.restore();
    }
   
    var trans = new Transform();
   
    //==========================================
    function Clip(){
        var canvas = document.getElementById("canvas3");
        this.ctx = canvas.getContext("2d");
        this.img=new Image();
        this.img.src=IMG_SRC;
        //move direct
        this.delta=[3,3];
        //begin point
        this.pos_x = 225;
        this.pos_y = 120;
        //circle
        this.radius = 40;
        this.w = parseInt(canvas.getAttribute("width"));
        this.h = parseInt(canvas.getAttribute("height"));
    }
   
    Clip.prototype.draw1=function(){
        //crach check
        if (this.pos_x < this.radius) {
            this.delta[0] = Math.random() % 4 + 5;
        } else if (this.pos_x > this.w - this.radius) {
            this.delta[0] = -(Math.random() % 4 + 5);
        }
        if (this.pos_y < this.radius) {
            this.delta[1] = Math.random() % 4 + 5;
        } else if (this.pos_y > this.h - this.radius) {
            this.delta[1] = -(Math.random() % 4 + 5);
        }
        this.pos_x += this.delta[0];
        this.pos_y += this.delta[1];
        this.ctx.clearRect(0, 0, this.w, this.h);
        this.ctx.save()
        this.ctx.translate(this.pos_x,this.pos_y);
        this.ctx.beginPath();
        this.ctx.arc(0 ,0,this.radius,0,Math.PI*2,true);
        this.ctx.clip();        
        this.ctx.drawImage(this.img, -this.pos_x, -this.pos_y,this.w, this.h);
        this.ctx.restore();
    }
   
    Clip.prototype.draw2=function(){
        if (this.pos_x < this.radius) {
            this.delta[0] = Math.random() % 4 + 5;
        } else if (this.pos_x > this.w - this.radius) {
            this.delta[0] = -(Math.random() % 4 + 5);
        }
        if (this.pos_y < this.radius) {
            this.delta[1] = Math.random() % 4 + 5;
        } else if (this.pos_y > this.h - this.radius) {
            this.delta[1] = -(Math.random() % 4 + 5);
        }
        this.pos_x += this.delta[0];
        this.pos_y += this.delta[1];

        this.ctx.clearRect(0, 0, this.w, this.h);
        this.ctx.fillStyle="rgba(125,125,125,0.1)"
        this.ctx.fillRect(0, 0, this.w, this.h);
        this.ctx.save()
        this.ctx.translate(this.pos_x,this.pos_y);
        this.ctx.globalCompositeOperation = "xor";  
        this.ctx.fillStyle="white"
        this.ctx.beginPath();
        this.ctx.arc(0 ,0,this.radius,0,Math.PI*2,true);
        this.ctx.fill();      
        this.ctx.globalCompositeOperation = "destination-over";  
        this.ctx.drawImage(this.img, -this.pos_x, -this.pos_y,this.w, this.h);
        this.ctx.restore();
    }

    var cl=new Clip();
    cl.interval=null;
   
    function move(id){     
        if(cl.interval)
            clearInterval(cl.interval)
        if(id==1){
            cl.ctx.clearRect(0, 0, 450, 300);   
            cl.interval=setInterval(function(){cl.draw1()},20);
        }
        else{
            cl.ctx.clearRect(0, 0, 450, 300);   
            cl.interval=setInterval(function(){cl.draw2()},20);
        }
    }

    function stop(){
        clearInterval(cl.interval)
    }
   
    var compositeTypes = [
        'source-over','source-in','source-out','source-atop',
        'destination-over','destination-in','destination-out','destination-atop',
        'lighter','darker','copy','xor'
    ];
    function drawComp(){
        for (i=0;i<compositeTypes.length;i++){
            var label = document.createTextNode(compositeTypes[i]);
            document.getElementById('lab'+i).appendChild(label);
            var ctx = document.getElementById('tut'+i).getContext('2d');

            // draw rectangle
            ctx.fillStyle = "#09f";
            ctx.fillRect(15,15,70,70);

            // set composite property
            ctx.globalCompositeOperation = compositeTypes[i];

            // draw circle
            ctx.fillStyle = "#f30";
            ctx.beginPath();
            ctx.arc(75,75,35,0,Math.PI*2,true);
            ctx.fill();
        }
    }
    drawComp();
</script>

references:
http://www.blogjava.net/myqiao/category/46360.html

热点排行