麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > 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教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 美女被免费网站在线软件 | 久久久日韩精品一区二区三区 | 9999视频| 精品久久久久久中文字幕 | 一夜新娘第三季免费观看 | 欧美视频一二区 | 中文黄色一级片 | 国产精品aⅴ | 毛片免费一区二区三区 | 国产妇女乱码一区二区三区 | 在线播放91 | 欧美成人综合视频 | chinese18 xxxx videos | 国产亚洲综合一区二区 | 成人视屏免费看 | 免费欧美一级视频 | 国产成人在线网址 | 曰韩在线视频 | 国产精品久久久久久久久久久久午夜 | 久久久国产一级片 | 日本成人一区二区 | 精品成人av一区二区在线播放 | 又黄又爽又色无遮挡免费 | 把娇妻调教成暴露狂 | 成人免费区| 蜜桃av鲁一鲁一鲁一鲁 | 色屁屁xxxxⅹ在线视频 | 欧美成人免费一区二区三区 | 亚洲一级片在线观看 | 91看片在线观看视频 | 九九热视频这里只有精品 | 欧美一级特黄aaaaaaa什 | 亚洲欧美国产高清 | 免费观看9x视频网站在线观看 | 成年性羞羞视频免费观看无限 | 久色免费视频 | xnxx 日本免费| 精品国产一区二区三区蜜殿 | 日韩毛片在线看 | 亚洲欧美国产高清 | a级高清免费毛片av在线 |