亚洲中字慕日产2020,大陆极品少妇内射AAAAAA,无码av大香线蕉伊人久久,久久精品国产亚洲av麻豆网站

資訊專欄INFORMATION COLUMN

canvas拼圖功能實(shí)現(xiàn)

entner / 3494人閱讀

摘要:繪制圖片文字按比例計(jì)算不同手機(jī)的百分比間距將閉包引用清除,釋放內(nèi)存不支持

最近做項(xiàng)目的時(shí)候遇到照片拼圖的功能,便在這里分享自己的封裝的canvas拼圖功能,可能代碼寫(xiě)的不好,如果有疑問(wèn)或者是有更好的方法的,可以私聊我,或者是評(píng)論指出,感謝各位

實(shí)現(xiàn)的思路其實(shí)挺簡(jiǎn)單的,主要是通過(guò)服務(wù)端獲取圖片鏈接,圖片寬度,圖片高度,然后利用簡(jiǎn)單的遞歸實(shí)現(xiàn)就行了(注意移動(dòng)端需要采用2倍數(shù)的比例,否則會(huì)出現(xiàn)圖片模糊的問(wèn)題)

/**

     * canvas繪圖數(shù)據(jù)
     * @param {Object[]} option.photoData
     * @param {string} option.photoData[].photo - 照片的鏈接地址
     * @param {number} option.photoData[].width -  照片的寬度
     * @param {number} option.photoData[].height -  照片的高度
     * @param {Object[]} option.wordData
     * @param {string} option.wordData[].color - 文字的顏色
     * @param {number} option.wordData[].fontSize - 文字的大小
     * @param {string} option.wordData[].fontWeight -  文字的粗細(xì)
     * @param {number} option.wordData[].left - 文字的左邊距
     * @param {number} option.wordData[].top -  文字的上邊距
     * @param {string} option.wordData[].word -  文字的內(nèi)容
     * @param {Object[]} option.iconData
     * @param {string} option.iconData[].photo - icon的鏈接地址
     * @param {number} option.iconData[].left -  icon的左邊距
     * @param {number} option.iconData[].top -  icon的上邊距
     * @param {number} option.iconData[].width -  icon的寬度
     * @param {number} option.iconData[].height -  icon的高度
     *
    */

function canvasDraw(option){

        var canvas = document.createElement("canvas"),
            ctx = canvas.getContext("2d"),
            clientWidth = document.documentElement.clientWidth,
            canvasHeight = 0,
            distance = 0,
            photoCount = 0,
            iconCount = 0;

        // canvas中手機(jī)上一倍繪圖會(huì)模糊,需采用兩倍,pc端不會(huì)。    
        clientWidth = clientWidth > 480? 480 * 2 : clientWidth * 2; 

        option.photoData.forEach(function(item,index,picArr){
            if (!index) {
                item.distance = 0;
            }else if(index){
                distance += Math.floor(clientWidth / option.photoData[index - 1].width * option.photoData[index - 1].height)
                item.distance = distance;
            }
            canvasHeight += Math.floor(clientWidth / item.width * item.height);
            item.imgHeight = Math.floor(clientWidth / item.width * item.height);
        })        

        console.log(option.photoData)

        if (ctx) {
            canvas.width = clientWidth;
            canvas.height  = canvasHeight + clientWidth / 4 * 2
        
            ctx.fillStyle = "#fff"
            ctx.fillRect(0, 0, canvas.width, canvas.height)

            // 繪制圖片文字
            if(option.wordData.length){
                option.wordData.forEach(function(item,index){
                    ctx.fillStyle = item.color;
                    ctx.font = "normal normal " + item.fontWeight + " " + calculate(item.fontSize) + "px Microsoft YaHei";
                    ctx.textAlign = "left";
                    ctx.fillText(item.word, calculate(item.left), canvasHeight + calculate(item.top));    
                })
            }

            //按比例計(jì)算不同手機(jī)的百分比間距
            function calculate(num){
                return Math.floor(clientWidth * num / 750)
            }

            drawPhoto("photo0")

            function drawPhoto(photoDom){
                var photoDom = new Image();    
                photoDom.setAttribute("crossOrigin", "Anonymous");
                photoDom.src = option.photoData[photoCount].photo;

                photoDom.onload = function(){
                    ctx.drawImage(photoDom, 0, option.photoData[photoCount].distance, clientWidth, option.photoData[photoCount].imgHeight);
                    photoCount++;

                    if (photoCount == option.photoData.length) {

                        drawIcon("icon0")

                        function drawIcon(iconDom){
                            var iconDom = new Image();    
                            iconDom.setAttribute("crossOrigin", "Anonymous");
                            iconDom.src = option.iconData[iconCount].icon;

                            iconDom.onload = function(){
                                ctx.drawImage(iconDom, calculate(option.iconData[iconCount].left), canvasHeight + calculate(option.iconData[iconCount].top), calculate(option.iconData[iconCount].width), calculate(option.iconData[iconCount].height))
                                iconCount++;

                                if (iconCount == option.iconData.length) {
                                    var imageURL = canvas.toDataURL("image/jpeg")
                                    document.getElementsByClassName("shareImg")[0].setAttribute("src", imageURL)

                                    //將閉包引用清除,釋放內(nèi)存;
                                    drawPhoto = null;

                                }else{
                                    drawIcon("icon" + iconCount)
                                }
                            }    
                        }                                 
                    }else{
                        drawPhoto("photo"+ photoCount)
                        
                    }    
                }                                                
            }

        }else{
            console.log("不支持canvas")
        }
    }

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

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

相關(guān)文章

  • canvas拼圖功能實(shí)現(xiàn)

    摘要:繪制圖片文字按比例計(jì)算不同手機(jī)的百分比間距將閉包引用清除,釋放內(nèi)存不支持 最近做項(xiàng)目的時(shí)候遇到照片拼圖的功能,便在這里分享自己的封裝的canvas拼圖功能,可能代碼寫(xiě)的不好,如果有疑問(wèn)或者是有更好的方法的,可以私聊我,或者是評(píng)論指出,感謝各位 實(shí)現(xiàn)的思路其實(shí)挺簡(jiǎn)單的,主要是通過(guò)服務(wù)端獲取圖片鏈接,圖片寬度,圖片高度,然后利用簡(jiǎn)單的遞歸實(shí)現(xiàn)就行了(注意移動(dòng)端需要采用2倍數(shù)的比例,否則會(huì)...

    付倫 評(píng)論0 收藏0
  • canvas拼圖功能實(shí)現(xiàn)

    摘要:繪制圖片文字按比例計(jì)算不同手機(jī)的百分比間距將閉包引用清除,釋放內(nèi)存不支持 最近做項(xiàng)目的時(shí)候遇到照片拼圖的功能,便在這里分享自己的封裝的canvas拼圖功能,可能代碼寫(xiě)的不好,如果有疑問(wèn)或者是有更好的方法的,可以私聊我,或者是評(píng)論指出,感謝各位 實(shí)現(xiàn)的思路其實(shí)挺簡(jiǎn)單的,主要是通過(guò)服務(wù)端獲取圖片鏈接,圖片寬度,圖片高度,然后利用簡(jiǎn)單的遞歸實(shí)現(xiàn)就行了(注意移動(dòng)端需要采用2倍數(shù)的比例,否則會(huì)...

    Kyxy 評(píng)論0 收藏0
  • 小程序—九宮格心形拼圖

    摘要:而微信小程序中也剛好有進(jìn)度條這個(gè)組件。推薦和意見(jiàn)反饋推薦給朋友意見(jiàn)反饋這個(gè)兩個(gè)功能就是用了,微信小程序的組件,這里需要注意的就是,在清除的默認(rèn)樣式時(shí),需要把的偽元素的邊框也去掉??偨Y(jié)這次做的這個(gè)九宮格心形拼圖的小程序,第一版已經(jīng)上線了。 說(shuō)明 前幾天在朋友圈看到好幾次這種圖片。 showImg(https://segmentfault.com/img/bVbeAoX?w=321&h=3...

    myeveryheart 評(píng)論0 收藏0
  • canvas自由拼圖

    摘要:自由拼圖自由拼圖是美圖秀秀中的一個(gè)功能,它可以讓用戶在背景圖片上插入自己的圖片,并可以對(duì)插入圖片旋轉(zhuǎn),拖拽,縮放。效果本屌之前用實(shí)現(xiàn)過(guò),參見(jiàn)仿美圖秀秀的自由拼圖注意里面基本上沒(méi)代碼說(shuō)明這里用的實(shí)現(xiàn)。 自由拼圖? 自由拼圖是美圖秀秀中的一個(gè)功能,它可以讓用戶在背景圖片上插入自己的圖片,并可以對(duì)插入圖片旋轉(zhuǎn),拖拽,縮放。當(dāng)然,如果用戶對(duì)插入的圖片不滿意,可以用另一張圖片替換選中的圖片,或者...

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

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

0條評(píng)論

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