好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 移動端Html5頁面生成圖片解決方案

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

熱門標簽:四川點撥外呼系統 南寧點撥外呼系統哪家公司做的好 當涂高德地圖標注 成都智能外呼系統平臺 電銷機器人電話用什么卡 黃島區地圖標注 鎮江智能外呼系統有效果嗎 云南大理400電話申請官方 江蘇智能電銷機器人哪家好

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

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

6plus DPR=3

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

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

標簽:淮安 酒泉 佳木斯 十堰 咸寧 南京 西寧 廣西

巨人網絡通訊聲明:本文標題《移動端Html5頁面生成圖片解決方案》,本文關鍵詞  移動,端,Html5,頁面,生成,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《移動端Html5頁面生成圖片解決方案》相關的同類信息!
  • 本頁收集關于移動端Html5頁面生成圖片解決方案的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 乱女1一7第一章乱女小丹| 男人舔女人下面视频在线观看| 老妇激情毛片| 国产精品久久久久精品三级潮浪| 农村黄a三级三级三级| 逼逼视频| 欧美xxxxhdvideos| _日本一级特黄大片床片| 欧美AV无码吞精久久久网站| 亚洲人成色77777推荐合集| 嗯嗯嗯啊啊不要| 国产成人精品实拍在线| 操老师的逼| 国产一级特黄无码视频| 亚洲欧美??va天堂人熟伦| 一级片影院| japanese强迫第一次护士| 周晓琳50厘米全部进入直肠| 欧美成人做爰高潮片免费野花谷| 99精品视频免费版的特色功能| 男女操操视频| 亚洲色图制服丝袜| 亚洲女同制服中文字幕| 国产精品久久久久亚洲| 另一类ZOOM孕妇| 性爱技巧| 揉我奶头?啊?嗯小雪电影| 日韩大片高清播放器好| 日本高清在线观看视频你懂的| 高清欧美一区二区免费影视| 91久久精品国产亚洲Av麻| 女人呻吟双腿大开男女H漫画 | 在线 偷拍 欧美 动漫| 韩国电影巜大胸女友的滋味| 国产成人啪精品视频免费网站软件| 喷??????流水高c网站| chinese老头hdsexasiantube| 亚洲 日韩 中文 无码 制服| 婬乱生活H肉承欲欢| 高(h)bl总攻| 国产极品粉嫩福利在线观看|