成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

canvas入門實(shí)戰(zhàn)--邀請(qǐng)卡生成與下載

李義 / 3315人閱讀

摘要:大家看這篇文章之前,要了解的一些基礎(chǔ),也要看著了解一些的教程,菜鳥教程邀請(qǐng)卡實(shí)例邀請(qǐng)卡自動(dòng)生成這個(gè)會(huì)有的,畢竟有時(shí)候,很多邀請(qǐng)卡都是一樣的,就是被邀請(qǐng)的人不一樣而已,也就是說,整個(gè)邀請(qǐng)卡,就是一個(gè)名字不一樣,那么下面。代表是否是批量下載。

1.前言

寫了很多的javascript和css3的文章,是時(shí)候?qū)懸黄猚anvas的了。canvas是html5提供的一個(gè)新的功能!至于作用,就是一個(gè)畫布。然后畫筆就是javascript。canvas的用途非常的廣,特別是html5游戲以及數(shù)據(jù)可視化這兩個(gè)方面?,F(xiàn)在canvas給我的感覺就和css3一樣,可以不用太厲害,但是必須要會(huì)基礎(chǔ)的用法。但是以后對(duì)canvas的需求,肯定會(huì)越來越大。所以canvas很值得學(xué)習(xí),而且學(xué)好canvas,就是很好的一個(gè)加分項(xiàng)。對(duì)于這篇文章,我也是以canvas初學(xué)者的角度寫的,會(huì)有很多改善的地方。如果大家覺得我有什么可以改善的,或者建議,歡迎指點(diǎn)迷津!代碼已上傳github,需要的歡迎star(downloadImg)。

大家看這篇文章之前,要了解javascript的一些基礎(chǔ),也要看著了解一些canvas的api(canvas-MSN教程,canvas菜鳥教程)
2.邀請(qǐng)卡實(shí)例

邀請(qǐng)卡自動(dòng)生成這個(gè)會(huì)有的,畢竟有時(shí)候,很多邀請(qǐng)卡都是一樣的,就是被邀請(qǐng)的人不一樣而已,也就是說,整個(gè)邀請(qǐng)卡,就是一個(gè)名字不一樣,那么下面。就寫一套代碼,根據(jù)名字生成邀請(qǐng)卡!

2-1.運(yùn)行效果

html代碼



    
    下載圖片
    


畫布尺寸
背景圖片
用戶名
用戶名x坐標(biāo)

居中顯示

用戶名y坐標(biāo)

居中顯示

用戶名字體大小
文字顏色
圖片類型

效果如圖,那么大家細(xì)想一下,關(guān)于一張邀請(qǐng)卡,有什么東西是需要改變的!看到上圖相比不難發(fā)現(xiàn)!有如下需要改變的屬性:圖片的大小,圖片,用戶名,用戶名的坐標(biāo)(x,y,x軸是否居中,y軸是否居中),用戶名字體的大小,用戶名字體的顏色,以及下載圖片的類型。

這樣就得到了如下的參數(shù)(大家看到有些參數(shù)是有值的,可以想成默認(rèn)值就行了)

var option = {
    img: "111.jpg",
    width: 500,
    height: 350,
    fontSize: "20px Microsoft YaHei",
    color: "black",
    text: "守候",
    imgType: "jpg",
    x: 30,
    y: 30,
    xCenter: false,
    yCenter: false,
};
2-2.步驟 1.初步效果

根據(jù)上面的參數(shù),先初步畫一個(gè)效果,代碼基本都是一個(gè)寫法,沒什么技巧

//畫圖
function draw(obj) {
    var canvas = document.getElementById("thecanvas");
    //畫布大小
    canvas.width = obj.width;
    canvas.height = obj.height;
    //設(shè)置圖片
    var img = new Image();
    img.src = obj.img;
    var ctx = canvas.getContext("2d");
    //設(shè)置字體的坐標(biāo)
    var _x = obj.x, _y = obj.y;
    //是否居中顯示
    if (obj.xCenter) {
        _x = obj.width / 2;
    }
    if (obj.yCenter) {
        _y = obj.height / 2;
    }
    //圖片加載后
    img.onload = function () {
        //先畫圖片
        ctx.drawImage(img, 0, 0);
        //設(shè)置文字的大小
        ctx.font = obj.fontSize;
        //設(shè)置文字的顏色
        ctx.fillStyle = obj.color;
        //設(shè)置文字坐標(biāo)
        if (obj.xCenter) {
            ctx.textAlign = "center";
        }
        //畫文字
        ctx.fillText(obj.text, _x, _y);
    };
}

window.onload = function () {
    draw(option);
}

2.動(dòng)態(tài)改變參數(shù)

看到圖已經(jīng)畫好了,工作其實(shí)已經(jīng)完成一半了!

下面就是動(dòng)態(tài)改變參數(shù)!這一步其實(shí)很簡(jiǎn)單。
首先,改變畫布的尺寸

//畫布尺寸
//獲取按鈕
var size = document.getElementById("size");
size.addEventListener("blur", function () {
    //根據(jù)空格,區(qū)分高寬
    var _width = parseInt(size.value.replace(/(^s*)|(s*$)/g, "").split(/s+/)[0]),
        _height = parseInt(size.value.replace(/(^s*)|(s*$)/g, "").split(/s+/)[1]);
    //把參數(shù)的width和height改掉
    option.width = _width || 100;
    option.height = _height || 100;
    //重新畫圖
    draw(option);
});

上面代碼設(shè)置了,只要輸入框失去了焦點(diǎn),就會(huì)改變畫布的大小,下面來運(yùn)行下,看下效果(gif圖差強(qiáng)人意,大家看懂就好)

canvas沒有層級(jí)的說法,只要改canvas,都要重繪。哪怕就是一個(gè)字移動(dòng)一個(gè)像素。

做好了這個(gè),下面做選擇圖片的功能!

//選擇圖片
//獲取圖片控件
var file = document.getElementById("file"), imagesFile, imageData;
file.addEventListener("change", function (e) {
    //獲取圖片
    imagesFile = e.target.files[0];
    //把圖片轉(zhuǎn)base64
    var reader = new FileReader();
    reader.readAsDataURL(imagesFile);
    //圖片加載后
    reader.onload = function (e) {
        //設(shè)置option的img屬性,再?zèng)_洗年繪制
        imageData = this.result;
        option.img = imageData;
        draw(option);
    }
});

下面開始改文字,用戶名這個(gè)有點(diǎn)不一樣,我以空格分割。如果輸入多個(gè)用戶名,以第一個(gè)用戶名重繪。下面代碼,注釋就不寫了,還是和上面的邏輯一樣!

//用戶名
var userName = document.getElementById("user-name");
userName.addEventListener("blur", function () {
    var _text = userName.value.replace(/(^s*)|(s*$)/g, "").split(/s+/);
    option.text = _text[0];
    draw(option);
});

下面開始用戶名的坐標(biāo),代碼方面,也是改option的相關(guān)屬性

    optionXCenter.addEventListener("change", function () {
        if (optionXCenter.checked) {
            option.xCenter = true;
        }
        else {
            option.xCenter = false;
            option.x = parseInt(optionX.value);
        }
        draw(option);
    });
    //縱坐標(biāo)
    var optionY = document.getElementById("text-option-y");
    optionY.value = option.y;
    var optionYCenter = document.getElementById("is-center-y");
    optionY.addEventListener("input", function () {
        if (optionYCenter.checked) {
            option.yCenter = true;
        }
        else {
            option.yCenter = false;
            option.y = parseInt(optionY.value);
        }
        draw(option);
    });
    //是否垂直居中顯示
    optionYCenter.addEventListener("change", function () {
        if (optionYCenter.checked) {
            option.yCenter = true;
        }
        else {
            option.yCenter = false;
            option.y = parseInt(optionY.value);
        }
        draw(option);
    });

是否水平居中顯示

其他的屬性,字體大小和顏色,基本是一樣的代碼,運(yùn)行的效果圖我不放了!

//字體顏色
var textColor = document.getElementById("text-color");
textColor.addEventListener("blur", function () {
    textColor.value === "" ? option.color = "#fff" : option.color = "#" + textColor.value;
    draw(option);
});
//字體大小
var textSize = document.getElementById("text-size");
textSize.addEventListener("input", function () {
    textSize.value === "" ? option.fontSize = "20px Microsoft YaHei" : option.fontSize = textSize.value + "px Microsoft YaHei";
    draw(option);
});
3.按鈕操作

效果預(yù)覽

就是預(yù)覽當(dāng)前canvas的一個(gè)效果,這個(gè)就很簡(jiǎn)單了,就是新開一個(gè)窗口,然后把圖片寫進(jìn)去而已

//預(yù)覽圖片
function saveImageInfo() {
    var mycanvas = document.getElementById("thecanvas");
    //生成圖片
    var image = mycanvas.toDataURL("image/png");
    var w = window.open("about:blank", "image from canvas");
    //把圖片新進(jìn)新的窗口
    w.document.write("");
}
var saveButton = document.getElementById("save-image");
saveButton.addEventListener("click", saveImageInfo);

下載當(dāng)前圖片

下載圖片這個(gè),基本也是寫法的,都是些記憶的東西

//圖片類型
var imgType = document.getElementById("img-type");
imgType.addEventListener("change",function () {
    option.imgType=this.value;
});
//下載圖片
function downloadImg(fileName) {
    //獲取canvas
    var myCanvas = document.getElementById("thecanvas");
    //設(shè)置圖片類型
    var image = myCanvas.toDataURL("image/" + option.imgType).replace("image/" + option.imgType, "image/octet-stream");
    var save_link = document.createElementNS("http://www.w3.org/1999/xhtml", "a");
    save_link.href = image;
    //設(shè)置下載圖片的名稱
    save_link.download = fileName + "." + option.imgType;
    //下載圖片
    var event = document.createEvent("MouseEvents");
    event.initMouseEvent("click", true, false, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null);
    save_link.dispatchEvent(event);
}

批量下載圖片

這個(gè)復(fù)雜一點(diǎn),但也不難,下面一步一步來!

1.首先批量導(dǎo)出,那么用戶名我這里是使用空格分割,那么現(xiàn)在我在option里面,弄一個(gè)字段textAll,所有文字的集合。all代表是否是批量下載。fn屬性代表回調(diào)函數(shù)

//批量導(dǎo)出
var downloadAll = document.getElementById("download-all");
downloadAll.addEventListener("click", function () {
    var _text = userName.value.replace(/(^s*)|(s*$)/g, "").split(/s+/);
    option.textAll = _text;
    option.all = true;
    option.fn = downloadImg;
    draw(option);
});

2.然后修改繪制的函數(shù)draw,判斷是否是全部繪制的情況!

function draw(obj) {
    var canvas = document.getElementById("thecanvas");
    //畫布大小
    canvas.width = obj.width;
    canvas.height = obj.height;
    //設(shè)置圖片
    var img = new Image();
    img.src = obj.img;
    var ctx = canvas.getContext("2d");
    //設(shè)置字體的坐標(biāo)
    var _x = obj.x, _y = obj.y;
    //是否居中顯示
    if (obj.xCenter) {
        _x = obj.width / 2;
    }
    if (obj.yCenter) {
        _y = obj.height / 2;
    }
    //圖片加載后
    img.onload = function () {
        //是否是全部打印
        if(obj.all){
            //遍歷textAll
            for(var i=0;i

3.小結(jié)

關(guān)于canvas入門的第一篇文章,就寫到這里了。寫完之后,也發(fā)現(xiàn)自己對(duì)canvas的也是有很多的不懂!上文的這例子,知識(shí)canvas很簡(jiǎn)單的一個(gè)入門實(shí)例。canvas如果深入學(xué)習(xí),能做到很多讓人驚訝的效果,這個(gè)得以后要加強(qiáng)學(xué)習(xí),如果發(fā)現(xiàn)些值得記錄的知識(shí),我也會(huì)寫文章。canvas是一個(gè)非常值得學(xué)習(xí)的知識(shí),也是很有趣的一個(gè)知識(shí)。期待與大家有更多的交流和學(xué)習(xí)!

-------------------------華麗的分割線--------------------
想了解更多,關(guān)注關(guān)注我的微信公眾號(hào):守候書閣

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/112883.html

相關(guān)文章

  • canvas入門實(shí)戰(zhàn)--邀請(qǐng)生成下載

    摘要:大家看這篇文章之前,要了解的一些基礎(chǔ),也要看著了解一些的教程,菜鳥教程邀請(qǐng)卡實(shí)例邀請(qǐng)卡自動(dòng)生成這個(gè)會(huì)有的,畢竟有時(shí)候,很多邀請(qǐng)卡都是一樣的,就是被邀請(qǐng)的人不一樣而已,也就是說,整個(gè)邀請(qǐng)卡,就是一個(gè)名字不一樣,那么下面。代表是否是批量下載。 1.前言 寫了很多的javascript和css3的文章,是時(shí)候?qū)懸黄猚anvas的了。canvas是html5提供的一個(gè)新的功能!至于作用,就是一...

    jay_tian 評(píng)論0 收藏0
  • 重磅 | 完備的 AI 學(xué)習(xí)路線,最詳細(xì)的資源整理!

    摘要:是你學(xué)習(xí)從入門到專家必備的學(xué)習(xí)路線和優(yōu)質(zhì)學(xué)習(xí)資源。的數(shù)學(xué)基礎(chǔ)最主要是高等數(shù)學(xué)線性代數(shù)概率論與數(shù)理統(tǒng)計(jì)三門課程,這三門課程是本科必修的。其作為機(jī)器學(xué)習(xí)的入門和進(jìn)階資料非常適合。書籍介紹深度學(xué)習(xí)通常又被稱為花書,深度學(xué)習(xí)領(lǐng)域最經(jīng)典的暢銷書。 showImg(https://segmentfault.com/img/remote/1460000019011569); 【導(dǎo)讀】本文由知名開源平...

    荊兆峰 評(píng)論0 收藏0
  • 7月份前端資源分享

    摘要:更多資源請(qǐng)文章轉(zhuǎn)自月份前端資源分享的作用數(shù)組元素隨機(jī)化排序算法實(shí)現(xiàn)學(xué)習(xí)筆記數(shù)組隨機(jī)排序個(gè)變態(tài)題解析上個(gè)變態(tài)題解析下中的數(shù)字前端開發(fā)筆記本過目不忘正則表達(dá)式聊一聊前端存儲(chǔ)那些事兒一鍵分享到各種寫給剛?cè)腴T的前端工程師的前后端交互指南物聯(lián)網(wǎng)世界的 更多資源請(qǐng)Star:https://github.com/maidishike... 文章轉(zhuǎn)自:https://github.com/jsfr...

    pingan8787 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<