(17.05.26)(46)canvas的弧形、文字、线性/径向渐变、获取canvas图片、添加事件、jcanvas、变形、引入图片背景、引入图片、像素级操作、读取文件

Canvas

复习:

    获取绘图上下文
    var gd = oC.getContext('2d');
    设置起点
    gd.moveTo()
    设置终点
    gd.lineTo()
    描边
    gd.stroke()
    填充
    gd.fill()
    描边颜色
    gd.strokeStyle
    填充颜色
    gd.fillStyle
    重新开始路径
    gd.beginPath()
    清屏
    gd.clearRect()
    闭合路径
    gd.closePath()
    矩形
        a).
        gd.rect()
        gd.stroke()/fill()
        b).
        gd.fillRect()/strokeRect()

弧形

        gd.arc(cx,cy,r,s,e,b)
            cx,cy       圆心位置
            r           半径
            s           开始弧度
            e           结束弧度
            b           是否逆时针

文字

        gd.font = '字体大小 字体类型';

        水平对齐方式
        gd.textAlign                center

        基线对齐方式
        gd.textBaseline             middel

        gd.fillText(str,x,y);
        gd.strokeText(str,x,y);

线性渐变

        var lg = gd.createLinearGradient(x1,y1,x2,y2);
        lg.addColorStop(系数(0-1),color);

径向渐变

        var rg = gd.createRadialGradient(cx1,cy1,r1,cx2,cy2,r2);
        rg.addColorStop(系数(0-1),color);

获取canvas图片

        oC.toDataURL(Mime-Type)
                image/png       默认
                image/jpeg 

    base64      文件流
        直接可以放在src或者background里

    Mime-Type
        abc.html        text/html
        abc.jpg         image/jpg
        abc.png         image/png
        abc.avi         video/avi
        abc.mp3         audio/mp3

    canvas添加事件
        给canvas添加事件
        判断范围

    gd.isPointInPath(x,y);


jcanvas         javascript canvas的库
    http://jcscript.com/


变形
    旋转
        gd.rotate(弧度);

    平移
        gd.translate(x,y);

    缩放
        gd.scale(x,y);

    注意:
        canvas的变形圆心永远都是画布的左上角
        操作的并不是图形,而是画布
        图形一旦画上去,就不变了

        保存      gd.save();
        变形操作    
        画图
        还原      gd.restore();

    引入图片背景

        var cp = gd.createPattern(oImg,'平铺方式')

        repeat
        repeat-x
        repeat-y
        no-repeat

    引入图片

        gd.drawImage(
            oImg,
            dx,dy
        );

        gd.drawImage(
            oImg,
            dx,dy,dw,dh
        );

        gd.drawImage(
            oImg,
            sx,sy,sw,sh,
            dx,dy,dw,dh
        );

    像素级操作

    var result = gd.getImageData(x,y,w,h);
    var d = result.data;
        d所有像素点
            四个为一组
            r,g,b,a,r,g,b,a,r,g,b,a...
        操作
    gd.putImageData(result,0,0);

读取文件

    ondrop = function(ev){
        var oFile = ev.dataTransfer.files[0];
        oFile.name;         名字
        oFile.size;         大小
        oFile.type;         类型

        var reader = new FileReader();

        进度
        reader.onprogress = function(ev){
            ev.loaded       已加载
            ev.total        总数
            var scale = ev.loaded/ev.total;
        };

        完成
        reader.onload = function(ev){
            ev.target.result    文件内容
            相等
            reader.result       文件内容
        };


        以文本形式读取
        reader.readAsText(oFile);
        以Base64形式读取
        reader.readAsDataURL
    };

sum(4)(5).sub(1)            最终返回结果8

function sum(a){
    return function(b){
        return {
            sub:function(c){
                return a+b-c;
            }
        };
    };
}

function show(a,b){
    arguments[0].push(5);
    arguments[1] = 6;
    alert(a.length,b);      4
}
var arr = [1,2,3,5];
var b = 3;
show(arr,b);
alert(arr);                 1,2,3,5
alert(b);                   3
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,658评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,482评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,213评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,395评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,487评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,523评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,525评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,300评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,753评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,048评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,223评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,905评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,541评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,168评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,417评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,094评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,088评论 2 352

推荐阅读更多精彩内容