婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 移動端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頁面生成圖片解決方案的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    免费观看一级欧美片| 日韩精品高清不卡| 国产91精品久久久久久久网曝门| 成人激情文学综合网| 中文字幕一区日韩精品欧美| 99在线热播精品免费| 韩国av一区二区| 国产精品久久久爽爽爽麻豆色哟哟 | 一区二区三区四区亚洲| 一区二区久久久久久| 欧美人动与zoxxxx乱| 美女精品自拍一二三四| 欧美国产精品专区| 欧美丝袜自拍制服另类| 另类小说综合欧美亚洲| 日本一区二区三区视频视频| 99久久er热在这里只有精品66| 亚洲精品乱码久久久久久久久| 欧美日韩免费在线视频| 免费在线成人网| 久久久一区二区三区捆绑**| jizz一区二区| 免费成人美女在线观看.| 中文字幕一区二区在线观看| 欧美日韩一区中文字幕| 国产一区二区三区免费在线观看| 亚洲美女在线一区| 久久久另类综合| 欧美日韩国产精选| 成人午夜激情影院| 日本亚洲电影天堂| 亚洲日韩欧美一区二区在线| 欧美肥大bbwbbw高潮| 成人黄色在线视频| 国产又黄又大久久| 亚洲成人一区二区在线观看| 日本一区二区成人| 久久人人爽人人爽| 日韩视频国产视频| 欧美日韩国产另类一区| 色噜噜狠狠色综合中国| kk眼镜猥琐国模调教系列一区二区 | 亚洲欧洲国产专区| 精品国产免费一区二区三区四区| 色婷婷亚洲一区二区三区| 国产精品18久久久久久vr| 日本欧美加勒比视频| 亚洲最色的网站| 亚洲欧洲一区二区三区| 亚洲精品一线二线三线| 日韩欧美国产小视频| 91免费国产在线观看| 成人av在线一区二区三区| 韩国女主播成人在线观看| 日韩高清不卡一区二区三区| 亚洲高清免费在线| 亚洲免费成人av| 亚洲日本丝袜连裤袜办公室| 国产精品乱码一区二区三区软件| 久久综合狠狠综合久久综合88 | 国产精品久久久久久久久晋中| 欧美电影免费观看高清完整版在线观看| 99这里都是精品| av一区二区三区在线| 成人黄色小视频| 成人精品国产一区二区4080| 国产一区二区网址| 国产成人免费在线视频| 国产精品99久| 91香蕉视频黄| 欧美视频第二页| 欧美电影一区二区三区| 日韩欧美国产一区二区在线播放| 久久综合久色欧美综合狠狠| 欧美国产一区二区| 亚洲伦理在线精品| 日韩精品乱码免费| 九九久久精品视频| 国产aⅴ综合色| 91在线观看一区二区| 91蝌蚪porny九色| 3d成人动漫网站| 国产欧美va欧美不卡在线| 亚洲美女区一区| 视频一区欧美日韩| 国产suv精品一区二区6| 欧美三级韩国三级日本一级| 精品少妇一区二区| 亚洲欧洲另类国产综合| 日本系列欧美系列| 91在线视频18| 久久先锋影音av鲁色资源网| 有坂深雪av一区二区精品| 奇米精品一区二区三区在线观看| 国产成a人亚洲| 在线不卡免费av| 国产精品每日更新| 美女视频网站黄色亚洲| av在线播放一区二区三区| 日韩三级免费观看| 一个色在线综合| 狠狠色狠狠色综合| 欧洲精品在线观看| 国产亚洲污的网站| 奇米影视在线99精品| 色综合咪咪久久| 久久久久九九视频| 久久久精品日韩欧美| 欧美精品1区2区| 欧美日韩午夜在线| 中文一区二区在线观看| 日本欧美肥老太交大片| 色老汉一区二区三区| 精品av久久707| 午夜精品福利一区二区三区av| 国产精品1区2区3区在线观看| 在线观看免费成人| 国产精品的网站| 26uuu亚洲综合色欧美| 亚洲黄色片在线观看| 国产一区二区三区高清播放| 老司机一区二区| 在线观看91精品国产入口| 中文一区一区三区高中清不卡| 蜜臀av亚洲一区中文字幕| 97精品电影院| 国产精品视频一二三| 国产九九视频一区二区三区| 精品福利在线导航| 久久精品久久精品| 精品免费日韩av| 青青草国产精品亚洲专区无| 6080国产精品一区二区| 亚洲午夜av在线| 欧美亚洲国产一区二区三区| 亚洲欧美偷拍另类a∨色屁股| jlzzjlzz欧美大全| 亚洲精品ww久久久久久p站 | 欧美亚洲日本国产| 一级日本不卡的影视| 欧亚一区二区三区| 天堂蜜桃一区二区三区| 欧美群妇大交群中文字幕| 午夜日韩在线观看| 91精品国产一区二区三区| 午夜欧美2019年伦理| 日韩三级中文字幕| 国产一区 二区 三区一级| 久久久久久97三级| 色哟哟一区二区| 午夜精品福利一区二区三区av| 欧美一区二区久久久| 国产成人免费在线观看不卡| 亚洲欧美日韩一区二区| 欧美三电影在线| 九色综合狠狠综合久久| 国产精品欧美一区喷水| 在线视频你懂得一区| 青青草国产成人99久久| 国产亲近乱来精品视频 | 欧美精品三级在线观看| 激情欧美一区二区| 亚洲精品一卡二卡| 欧美一级视频精品观看| 国内精品伊人久久久久av影院| 国产精品你懂的在线| 99久久99久久免费精品蜜臀| 午夜不卡在线视频| 国产三级精品视频| 成人精品视频一区二区三区尤物| 国产精品久久久久影院| 免费av成人在线| 久久久久亚洲蜜桃| 91丨九色丨国产丨porny| 洋洋成人永久网站入口| 日韩精品影音先锋| 成人影视亚洲图片在线| 亚洲gay无套男同| 亚洲精品一区二区三区福利| 一本大道久久a久久精品综合| 久久精品国产在热久久| 日本一区二区三区国色天香| 在线视频你懂得一区| 国产一区不卡视频| 男男视频亚洲欧美| 亚洲一区二区三区三| 欧美激情一区二区三区蜜桃视频| 欧美日韩中文另类| 91视频在线看| 成人天堂资源www在线| 国产一区二区三区香蕉| 三级亚洲高清视频| 亚洲一区二区三区国产| 亚洲欧美欧美一区二区三区| 国产日韩高清在线| 久久久五月婷婷| 久久精品日韩一区二区三区| 日韩欧美亚洲国产精品字幕久久久| 欧美日韩一区不卡| 色成年激情久久综合|