成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識(shí)庫 > html2canvas實(shí)現(xiàn)dashed虛線邊框的示例

html2canvas實(shí)現(xiàn)dashed虛線邊框的示例

熱門標(biāo)簽:西安金倫外呼系統(tǒng) 智能語音電銷機(jī)器人客戶端 地圖標(biāo)注沿海城市房價(jià) 威海語音外呼系統(tǒng)平臺(tái) 高德地圖標(biāo)注廁所 地圖標(biāo)注員工作內(nèi)容 通遼地圖標(biāo)注app 江西ai電銷機(jī)器人如何 中國地圖標(biāo)注城市的

html2canvas是一個(gè)將html元素生成canvas的庫,繪制的canvas大部分樣式和CSS一致。比如截止1.0.0-alpha.12,虛線邊框依然繪制為實(shí)線,border-collapse依然有問題。

這里根據(jù)github issues里的一個(gè)思路,模擬實(shí)現(xiàn)了dashed邊框效果。

適用情況:單獨(dú)邊框較多,即不是完整邊框,同時(shí)不考慮border-radius

1、首先,在html2canvas繪制前,找出需要繪制canvas的元素中的所有虛線邊框的 方向和位置

findDashedBorders = (page) => {
        const tds = page.querySelectorAll("td");
        const borders = [];
        tds.forEach(td => {
            const computedStyle = window.getComputedStyle(td);
            const borderStyle = computedStyle.borderStyle ? computedStyle.borderStyle.split(' ') : [];
            const dashedIndex = findAll(borderStyle, 'dashed');
            if (dashedIndex.length) {
                const rect = td.getBoundingClientRect();
                dashedIndex.map(index => {
                    const border = {
                        rect,
                        border: dashedBorder[index]
                    }
                    borders.push(border);
                    td.style[`border${dashedBorder[index]}Color`] = 'transparent';
                });
            }
        });
        return borders;
    }

page是需要繪制canvas的元素,我這里有dashed邊框的都是td元素,所以查找所有td元素,使用getComputedStyle()方法查找它的borderStyle,如果它有dashed邊框,那么這個(gè)屬性的值的形式為"dashed dashed none none",所以根據(jù)findAll()這個(gè)自定義方法找到所有的dashed的方向(比如"dashed dashed none none"將返回[0, 1]),其中dashedBorder數(shù)組如下:

const dashedBorder = ["Top", "Right", "Bottom", "Left"];

找到方位后同時(shí)獲取它的位置,將方向和位置信息存入borders數(shù)組,同時(shí)將這條邊框設(shè)為透明,使html2canvas不繪制這條框,我們之后會(huì)單獨(dú)處理。 (注意:這個(gè)頁面的虛線邊框都會(huì)透明掉,這里并沒有考慮繪制完成后將透明邊框變回原來的顏色)

2、使用html2canvas得到繪制后的canvas

pages.forEach((page, idx) => {
    const borders = this.findDashedBorders(page);
    const parentRect = page.getBoundingClientRect();
    html2canvas(page, {scale: 2, logging: false, useCORS: true}).then((canvas) => {
       this.drawDashedBorder(canvas, borders, parentRect);
       ......
    })
})

pages是需要繪制canvas的所有元素,我們在獲取每個(gè)page的虛線邊框時(shí),同時(shí)獲取這個(gè)page的位置,以便我們繪制dashed邊框時(shí)得到邊框相對于這個(gè)頁面的位置。待html2canvas繪制canvas后,我們通過drawDashedBorder()方法進(jìn)一步繪制出dashed邊框,下面實(shí)現(xiàn)這個(gè)方法。

3、drawDashedBorder()在得到canvas后進(jìn)一步繪制虛線。

drawDashedBorder = (canvas, borders, parentRect) => {
        var ctx = canvas.getContext("2d");
        ctx.setLineDash([6, 3]);
        ctx.strokeStyle = '#3089c7';
        ctx.lineWidth = 1;
        ctx.globalAlpha = 1;

        borders.forEach(border => {
            var left = (border.rect.left + 0.5 - parentRect.left)*2;
            var right = (border.rect.right - 0.5 - parentRect.left)*2;
            var top = (border.rect.top + 0.5 - parentRect.top)*2;
            var bottom = (border.rect.bottom - 0.5 - parentRect.top)*2;

            switch (border.border) {
                case 'Top':
                    ctx.beginPath();
                    ctx.moveTo(left, top);
                    ctx.lineTo(right, top);
                    ctx.stroke();
                    break;
                case 'Right':
                    ctx.beginPath();
                    ctx.moveTo(right, top);
                    ctx.lineTo(right, bottom);
                    ctx.stroke();
                    break;
                case 'Bottom':
                    ctx.beginPath();
                    ctx.moveTo(left, bottom);
                    ctx.lineTo(right, bottom);
                    ctx.stroke();
                    break;
                case 'Left':
                    ctx.beginPath();
                    ctx.moveTo(left, top);
                    ctx.lineTo(left, bottom);
                    ctx.stroke();
                    break;
                default:
                    break;
            }
        })
    }

意思就是根據(jù)borders里dashed邊框的方向和位置信息,在canvas里獲取2d上下文后使用setLineDash方法把虛線繪制出來。位置都*2是因?yàn)槲覀冎癱anvas使用了2倍大小。

4、這個(gè)方法目前只在chrome測試可用,firefox無效,因?yàn)閒irefox下getComputedStyle返回的信息和chrome不同。

由于對canvas理解不深無法pr,只能期待html2canvas的官方實(shí)現(xiàn)了。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:眉山 河池 晉中 營口 青海 崇左 北海 阜陽

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《html2canvas實(shí)現(xiàn)dashed虛線邊框的示例》,本文關(guān)鍵詞  html2canvas,實(shí)現(xiàn),dashed,虛線,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《html2canvas實(shí)現(xiàn)dashed虛線邊框的示例》相關(guān)的同類信息!
  • 本頁收集關(guān)于html2canvas實(shí)現(xiàn)dashed虛線邊框的示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    亚洲精品免费网站| 97人妻精品一区二区三区动漫| 日韩在线一二三区| 亚洲级视频在线观看免费1级| 香蕉视频色在线观看| 国产后进白嫩翘臀在线观看视频| 亚洲精品午夜级久久久久| 亚洲一级电影视频| 国产一区二区三区无遮挡| 精品一区国产| 国产精品久av福利在线观看| 一区二区三区| 国产亚洲精品自拍| 亚洲区一区二区| 欧美成人三级在线视频| 美女黄视频在线观看| 深爱激情综合| 日产国产欧美视频一区精品| 无码人妻丰满熟妇区毛片蜜桃精品| 92久久精品| 国产1卡2卡三卡四卡网站| 精品中文字幕在线播放| 色窝窝无码一区二区三区成人网站| 午夜美女福利视频| 欧美色男人天堂| 成年人二级毛片| 亚洲色图视频网| 欧美专区日韩视频| 免费在线观看污| 久久精选视频| 少妇光屁股影院| 狠狠色2019综合网| a级黄色片免费| 中文字幕第22页| 久久综合免费视频影院| 国产精品视频久| 91精品尤物| 色婷婷综合成人av| 国产一区亚洲| 亚洲熟妇无码乱子av电影| 欧美日韩国产小视频在线观看| 综合久久国产| 在线视频免费在线观看一区二区| 国产美女主播在线观看| 最新国产精品亚洲| 国产日韩欧美综合精品| 亚洲精品第一| 国产精品第五页| 免费男女羞羞的视频网站中文版| 国产厕所精品在线观看| ww久久中文字幕| 国产日韩欧美二区| 亚洲娇小娇小娇小| 色哟哟在线观看| 日韩精品第二页| 在线视频在线视频7m国产| 4hu四虎永久在线影院成人| 一区二区三区四区在线观看视频| 欧美美女网站色| 国产精品乱码一区二区视频| 91系列在线播放| 久久久亚洲精品一区二区三区| 精品人妻一区二区三区含羞草| 国产亚洲亚洲国产一二区| 国产精品美女xx| 四虎4hutv紧急入口| 欧美成人一区二区三区在线观看| 欧美日韩一级在线观看| youjizz.com国产| 91在线资源| 午夜欧美一区二区三区在线播放| 日韩欧美激情一区二区| 欧美另类99xxxxx| www.91av视频.com| av网址在线观看免费| 91嫩草国产线观看亚洲一区二区| 91精品国产高清一区二区三蜜臀| aaa大片在线观看| 午夜久久久影院| 日本一区精品| 精品裸体bbb| 亚洲午夜激情视频| 国产不卡精品视频| 一本色道久久综合无码人妻| 美日韩精品免费观看视频| 欧美视频在线视频| 成人毛片18女人毛片| 一区二区三区午夜探花| 国产精品成人一区二区网站软件| 亚洲第一视频网站| 久久er99精品| 性欧美xxxx免费岛国不卡电影| aa成人免费视频| chinese偷拍一区二区三区| 一个人看的www在线免费视频| 黑人巨大xxx| 91网址在线看| 精品久久久中文字幕| 久久精品2019中文字幕| a中文字幕www| 久久精品夜色噜噜亚洲a∨| 日本在线一区二区三区| 激情小视频在线| 红桃视频成人在线观看| 中国xxxx性xxxx产国| 亚洲爆乳无码精品aaa片蜜桃| 欧美黄色网页| 51成人做爰www免费看网站| 中文字幕一区二区三区域| 视频直播国产精品| 国产乱人乱偷精品视频a人人澡| 欧美图区在线视频| 中国黄色片免费看| 先锋资源在线视频| 欧洲成人在线视频| 国产无遮挡又黄又爽免费网站| 欧美日韩一区二区综合| 欧美性生活一级片| 九九热久久66| 天天综合天天色| 一本大道一区二区三区| 日韩伦理三区| 欧美视频观看一区| 久久99蜜桃| 欧美亚洲国产精品久久| 波多野结衣家庭教师视频| 婷婷电影在线观看| 国产日韩在线精品av| 国产伦精品一区二区三区高清版| 成人午夜亚洲| 午夜欧美在线| 国产1区2区视频| 国产欧美日韩不卡| 给我免费播放日韩视频| 国产女人伦码一区二区三区不卡| 成人精品视频在线| 免费在线成人av| 国产精品国码视频| 国产亚洲精品一区二555| 欧美日韩国产123| 中文字幕中文字幕在线中高清免费版| 中文字幕在线2018| 久久激情av| 丝瓜av网站精品一区二区| 日本成人在线免费| 日本久久网站| 69成人免费视频| 日韩欧美国产成人精品免费| 日韩av手机在线看| 国产精品高潮粉嫩av| 亚洲欧洲精品在线| 欧美成a人片在线观看久| 欧美视频在线观看免费| 在线观看黄网址| 好吊色视频一区二区| 欧美日韩mp4| aaa人片在线| 亚洲日产国产精品| 久久久久久97三级| 国产一区二区三区av电影| av网站在线观看不卡| av小次郎在线| 国产淫片免费看| 第一区免费在线观看| av中文字幕亚洲| 91久久人澡人人添人人爽欧美| 漂亮人妻被中出中文字幕| 久操久操久操| 可以在线看的av网站| 日韩欧美亚洲国产一区| 古典武侠综合av第一页| 美日韩一区二区三区| 激情综合色播五月| 污污网站在线免费观看| 国产一区二区高清不卡| 欧美精品小视频| 麻豆传媒在线观看| 亚洲第一欧美| 99久久99久久免费精品小说| 人妻无码一区二区三区| 激情综合激情五月| 小日子的在线观看免费第8集| 色综合天天综合网天天狠天天| 久久精品国内一区二区三区水蜜桃| 中文字幕在线视频一区二区| 水蜜桃精品av一区二区| 国产免费内射又粗又爽密桃视频| 亚洲高清视频免费观看| 婷婷成人在线| 亚洲人成网站色在线观看| 日韩情涩欧美日韩视频| 手机免费观看av| 日韩精品一区二区三区中文| 日韩和欧美一区二区| 亚洲一区二区三区加勒比| av在线私库| 亚洲图片你懂的| 国产精品tv| 欧美乱大交xxxxx另类| 亚洲第一香蕉视频| 免费大秀视频在线播放| 欧美精品一区二区三区免费播放| 二区视频在线观看| 久久这里只有精品免费| 欧美一级在线免费观看| 91视频成人免费| 午夜影院久久久| 精品国模在线视频| 亚洲va电影大全| 粉嫩aⅴ一区二区三区| 欧美国产精品人人做人人爱| 亚洲视频视频在线| 国产资源中文字幕| 欧美激情 亚洲a∨综合| 亚洲精品v天堂中文字幕| 国产中文字幕一区二区三区| 小明成人免费视频一区| 18视频在线观看娇喘| 国产精品视频一区在线观看| 91浏览器在线观看| 亚洲国产成人久久综合| 国产精品永久入口久久久| 中文字幕av一区 二区| 中文字幕久久久久| 综合久久99| 成人www视频网站免费观看| 黄色片视频在线观看| 小嫩苞一区二区三区| 国产91在线高潮白浆在线观看| 91黄色免费观看| 视频一区视频二区视频三区高| 福利二区91精品bt7086| 欧美男人亚洲天堂| 成人黄色小视频在线观看| 97人人澡人人爽人人模亚洲| 你懂的视频在线免费| 精品国产一区二区三区免费| 欧美日韩和欧美的一区二区| 亚洲影视九九影院在线观看| 成人性爱视频在线观看| 欧美亚洲国产一区二区三区| 亚洲a成v人在线观看| 911亚洲精品| 黄色片视频免费| www.777色| 午夜视频在线网站| 美女写真理伦片在线看| 国产精品久一| 成人小视频在线观看| 制服丝袜激情欧洲亚洲| 92看片淫黄大片一级| 丰满大乳奶做爰ⅹxx视频| 久久免费福利视频| 神马久久影视大全| 国产激情一区二区三区| 精品人伦一区二区三区| 久久黄色片网站| 日本女优天堂99伊人| 久久aⅴ乱码一区二区三区| 国产成人一区二区三区小说| 暗呦丨小u女国产精品| 99精品国产一区二区三区2021| 97婷婷大伊香蕉精品视频| 色婷婷一区二区| 久久影院一区二区三区| 濑亚美莉vs黑人在线观看| 韩国精品美女www爽爽爽视频| 国产视频福利一区| 97超碰人人爽| 亚洲精品网址在线观看| 麻豆一区区三区四区产品精品蜜桃| 日韩最新中文字幕电影免费看| 国产又粗又爽视频| 国产精品三p一区二区| 免费黄色的网站| 欧美成人tv| 日韩中文一区二区三区| 成人综合婷婷国产精品久久蜜臀| 成人av小说网| 亚洲精品视频大全| 动漫精品视频| 久久久久久久久久久人体| 91成人性视频| 女教师淫辱の教室蜜臀av软件| 中文国产字幕在线观看| 亚洲黄色片免费| 亚洲福利电影网| 久久精品一区二区三区不卡免费视频| 久久99国产精品视频| 99re6这里只有精品| 91福利免费在线| 免费一级肉体全黄毛片| 色网站在线视频| 国产a一区二区| 伊人久久五月天| www黄色日本| 第四色在线一区二区| 亚洲欧美乱综合图片区小说区| 涩涩视频网站在线观看| 在线观看天堂av| av蜜臀在线| 久久男人中文字幕资源站| 亚洲裸体俱乐部裸体舞表演av| 久久精品人人做人人爽电影蜜月| 久久久久久久有限公司| 中文字幕亚洲综合| 国产成人在线视频播放| 人妻少妇精品视频一区二区三区| 国产探花在线播放| 亚洲黄色三级视频| 加勒比中文字幕精品| 国产精品9999| 国产成人精品亚洲日本在线桃色| 免费毛片网站在线观看| 麻豆视频免费在线播放| 2025国产精品自拍| 成人高潮成人免费观看| 一区二区三区.www| 亚洲欧洲日产国码无码久久99| 日本r级电影在线观看| 成人影院网站ww555久久精品| 日本免费在线视频观看| 亚洲男人的天堂在线观看| 自己做鸭怎么接单寻找客源| 欧美影院一区二区三区| 91手机在线视频| 2020久久国产精品| 国产露脸无套对白在线播放|