亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

移動端Html5頁面生成圖片解決方案

2024-08-26 00:20:53
字體:
來源:轉載
供稿:網友

現在有很多微信公眾號運營活動,都有生成圖片的需求,生成圖片后可以發送給好友和發到朋友圈擴散,利于產品的宣傳!

1.生成圖片可以用canvas,但是由于已經有了html2canvas這個開源庫,所以為了節省時間就沒有自己寫了

github地址: html2canvas

少啰嗦,先看東西!??!

LiveDemo

/**     * 根據window.devicePixelRatio獲取像素比     */    function DPR() {        if (window.devicePixelRatio && window.devicePixelRatio > 1) {            return window.devicePixelRatio;        }        return 1;    }    /**     *  將傳入值轉為整數     */    function parseValue(value) {        return parseInt(value, 10);    };    /**     * 繪制canvas     */    async function drawCanvas (selector) {        // 獲取想要轉換的 DOM 節點        const dom = document.querySelector(selector);        const box = window.getComputedStyle(dom);        // DOM 節點計算后寬高        const width = parseValue(box.width);        const height = parseValue(box.height);        // 獲取像素比        const scaleBy = DPR();        // 創建自定義 canvas 元素        var canvas = document.createElement('canvas');        // 設定 canvas 元素屬性寬高為 DOM 節點寬高 * 像素比        canvas.width = width * scaleBy;        canvas.height = height * scaleBy;        // 設定 canvas css寬高為 DOM 節點寬高        canvas.style.width = `${width}px`;        canvas.style.height = `${height}px`;        // 獲取畫筆        const context = canvas.getContext('2d');        // 將所有繪制內容放大像素比倍        context.scale(scaleBy, scaleBy);        let x = width;        let y = height;        return await html2canvas(dom, {canvas}).then(function () {            convertCanvasToImage(canvas, x ,y)        })    }    /**     * 圖片轉base64格式     */    function convertCanvasToImage(canvas, x, y) {        let image = new Image();        let _container = document.getElementsByClassName('container')[0];        let _body = document.getElementsByTagName('body')[0];        image.width = x;        image.height = y;        image.src = canvas.toDataURL("image/png");        _body.removeChild(_container);        document.body.appendChild(image);        return image;    }    drawCanvas('.container')

2.由于現在的手機都是高清屏,所以如果你不做處理就會出現模糊的情況,為什么會出現模糊的情況?這個就涉及到設備像素比 devicePixelRatio js 提供了 window.devicePixelRatio 可以獲取設備像素比

function DPR() {        if (window.devicePixelRatio && window.devicePixelRatio > 1) {            return window.devicePixelRatio;        }        return 1;    }

這個DPR函數就是獲取設備的像素比, 那獲取像素比之后要做什么呢?

var canvas = document.createElement('canvas');        // 設定 canvas 元素屬性寬高為 DOM 節點寬高 * 像素比        canvas.width = width * scaleBy;        canvas.height = height * scaleBy;        // 設定 canvas css寬高為 DOM 節點寬高        canvas.style.width = `${width}px`;        canvas.style.height = `${height}px`;        // 獲取畫筆        const context = canvas.getContext('2d');        // 將所有繪制內容放大像素比倍        context.scale(scaleBy, scaleBy);

3.獲取設備像素比之后將canavs.width 和 canvas.height 去乘以設備像素比 也就是 scaleBy; 這個時候在去設置canvas.style.width 和 canvas.style.height 為dom的寬和高。想想為什么要這么寫?最后在繪制的餓時候將所繪制的內容放大像素比倍

舉個例子iphone6S是設備寬高是375 X 667 ,6S的 window.devicePixelRatio = 物理像素 / dips(2=750/375)所以設計師一般給你的設計稿是不是都是750*1334的?所以如果按照一比一去繪制在高清屏下就會模糊,看圖說話6S DPR=2

移動端,Html5,生成圖片

6plus DPR=3

移動端,Html5,生成圖片

4.最后調用canvas.toDataURL("image/png");賦值給image.src,由于微信里面無法保存圖片,所以只能生成圖片文件,調用微信自帶的長按保存到圖片到相冊功能,如圖:

移動端,Html5,生成圖片

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲xxx大片| 欧美精品成人91久久久久久久| 国产精品天天狠天天看| 91久久国产婷婷一区二区| 国产精品视频自在线| 日韩激情视频在线播放| 国产视频自拍一区| 日韩av在线免播放器| 国产精品夜色7777狼人| 国产精品久久久久99| 亚洲美女av在线播放| 97视频免费观看| 成人看片人aa| 中文字幕精品影院| 国产欧美精品va在线观看| 国产91免费观看| 亚洲欧美日韩国产中文| 国产精品久久久久久五月尺| 亚洲精品成人久久电影| 免费不卡欧美自拍视频| 久久综合久中文字幕青草| 亚洲国产高清高潮精品美女| 色多多国产成人永久免费网站| 精品久久久久久久大神国产| 国产va免费精品高清在线| 国产精品视频999| 国产精品91在线观看| 久久久久北条麻妃免费看| 国产美女直播视频一区| 精品欧美aⅴ在线网站| 国产亚洲精品成人av久久ww| 日本亚洲欧美成人| 日韩精品久久久久久福利| 日韩有码在线视频| 国产精品最新在线观看| 国产精品久久久久影院日本| 日韩av一区二区在线| 国产999精品久久久| 国产午夜精品全部视频在线播放| 国产欧美一区二区三区久久人妖| 亲爱的老师9免费观看全集电视剧| 欧美日韩国产中字| 欧美xxxx综合视频| 欧美在线观看网址综合| 日韩av在线免播放器| 亚洲高清av在线| 一级做a爰片久久毛片美女图片| 555www成人网| 精品国产成人在线| 91麻豆桃色免费看| 国内精品久久久久久影视8| 国产精品久久久久99| 久久成人综合视频| 欧美亚洲午夜视频在线观看| 在线观看视频99| 欧美中文字幕精品| 日韩在线观看视频免费| 日韩精品久久久久久福利| 亚洲欧美制服综合另类| 深夜成人在线观看| 国产热re99久久6国产精品| 成人中文字幕在线观看| 久热精品视频在线观看| 中文.日本.精品| 国产视频观看一区| 国产精品精品久久久| 日韩中文字幕亚洲| 国产精品第七影院| 一区二区欧美亚洲| 久久夜色精品国产欧美乱| 亚洲欧美999| 成人天堂噜噜噜| 久久99国产精品自在自在app| 国产主播欧美精品| 57pao成人永久免费视频| 国产精品爱久久久久久久| 97在线视频一区| 久久香蕉国产线看观看av| 欧美裸体男粗大视频在线观看| 精品国产91久久久久久老师| 日本久久久久久久| 国产精品无av码在线观看| 亚洲女人被黑人巨大进入| 日韩经典一区二区三区| 夜夜嗨av色一区二区不卡| 91精品久久久久久久久不口人| 国内精品美女av在线播放| 5252色成人免费视频| 中文字幕亚洲一区二区三区| 日韩在线观看精品| 久久99久国产精品黄毛片入口| 亚洲欧美制服第一页| 国产精品美女视频网站| 北条麻妃一区二区在线观看| 亚洲精品女av网站| 欧美一级片免费在线| 都市激情亚洲色图| 亚洲黄色www| 亚洲人成亚洲人成在线观看| 国产精品爱久久久久久久| www.久久撸.com| 日韩欧美亚洲成人| 成人在线观看视频网站| 亚洲精品福利在线观看| 国产精品第2页| 久久艳片www.17c.com| 欧美性猛交xxxx乱大交| 欧美大全免费观看电视剧大泉洋| 亚洲成人在线视频播放| 久久精品视频播放| 国产一区二区三区精品久久久| 国产日韩在线观看av| 久热精品视频在线观看一区| 欧美性猛交xxxx乱大交极品| 国产美女精品免费电影| 姬川优奈aav一区二区| 日本精品va在线观看| 影音先锋欧美在线资源| 97视频在线观看免费高清完整版在线观看| 日韩经典中文字幕在线观看| 国产91露脸中文字幕在线| 中文字幕亚洲欧美一区二区三区| 91精品在线影院| 国产伦精品一区二区三区精品视频| 日本国产一区二区三区| 最近2019中文字幕大全第二页| 久久综合久久美利坚合众国| 国产精品日韩久久久久| 日韩av电影院| 日韩视频免费在线| 国产日产欧美a一级在线| 亚洲视频在线播放| 欧美性在线视频| 亚洲福利视频在线| 中文字幕日韩综合av| 日韩久久免费视频| 国产精品成人播放| 国产精品久久久久久一区二区| 日韩精品在线免费播放| 亚洲香蕉av在线一区二区三区| 久久久久久国产三级电影| 亚洲人成网在线播放| 亚洲日本成人女熟在线观看| 91精品国产91久久| 亚洲国产一区二区三区在线观看| 欧洲亚洲女同hd| 国产精品稀缺呦系列在线| 中文欧美日本在线资源| 欧美老少做受xxxx高潮| 久久综合伊人77777蜜臀| 色777狠狠综合秋免鲁丝| 精品人伦一区二区三区蜜桃免费| 久久久久久国产精品久久| 国产精品吹潮在线观看| 亚洲深夜福利视频| 91av在线播放| 精品国产成人在线| 国产精品一香蕉国产线看观看| 久久久久久国产精品久久| 91免费看片在线| 国产不卡av在线免费观看| 91九色国产视频| 色777狠狠综合秋免鲁丝| 91久久精品久久国产性色也91|