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

資訊專欄INFORMATION COLUMN

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

付倫 / 1130人閱讀

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

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

實現(xiàn)的思路其實挺簡單的,主要是通過服務(wù)端獲取圖片鏈接,圖片寬度,圖片高度,然后利用簡單的遞歸實現(xiàn)就行了(注意移動端需要采用2倍數(shù)的比例,否則會出現(xià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 -  文字的粗細
     * @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中手機上一倍繪圖會模糊,需采用兩倍,pc端不會。    
        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));    
                })
            }

            //按比例計算不同手機的百分比間距
            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)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

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

相關(guān)文章

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

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

    Kyxy 評論0 收藏0
  • canvas拼圖功能實現(xiàn)

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

    entner 評論0 收藏0
  • 小程序—九宮格心形拼圖

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

    myeveryheart 評論0 收藏0
  • canvas自由拼圖

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

    megatron 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<