亚洲中字慕日产2020,大陆极品少妇内射AAAAAA,无码av大香线蕉伊人久久,久久精品国产亚洲av麻豆网站

資訊專欄INFORMATION COLUMN

移動(dòng)端H5頁(yè)面生成圖片解決方案

Neilyo / 798人閱讀

摘要:現(xiàn)在有很多微信公眾號(hào)運(yùn)營(yíng)活動(dòng),都有生成圖片的需求,生成圖片后可以發(fā)送給好友和發(fā)到朋友圈擴(kuò)散,利于產(chǎn)品的宣傳生成圖片可以用但是由于已經(jīng)有了這個(gè)開源庫(kù),所以為了節(jié)省時(shí)間就沒有自己寫了地址少啰嗦,先看東西根據(jù)獲取像素比將傳入值轉(zhuǎn)為整數(shù)繪制獲取想要

現(xiàn)在有很多微信公眾號(hào)運(yùn)營(yíng)活動(dòng),都有生成圖片的需求,生成圖片后可以發(fā)送給好友和發(fā)到朋友圈擴(kuò)散,利于產(chǎn)品的宣傳!

1.

生成圖片可以用canvas,但是由于已經(jīng)有了html2canvas這個(gè)開源庫(kù),所以為了節(jié)省時(shí)間就沒有自己寫了

github地址: html2canvas

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

LiveDemo

    /**
     * 根據(jù)window.devicePixelRatio獲取像素比
     */
    function DPR() {
        if (window.devicePixelRatio && window.devicePixelRatio > 1) {
            return window.devicePixelRatio;
        }
        return 1;
    }
    /**
     *  將傳入值轉(zhuǎn)為整數(shù)
     */
    function parseValue(value) {
        return parseInt(value, 10);
    };
    /**
     * 繪制canvas
     */
    async function drawCanvas (selector) {
        // 獲取想要轉(zhuǎn)換的 DOM 節(jié)點(diǎn)
        const dom = document.querySelector(selector);
        const box = window.getComputedStyle(dom);
        // DOM 節(jié)點(diǎn)計(jì)算后寬高
        const width = parseValue(box.width);
        const height = parseValue(box.height);
        // 獲取像素比
        const scaleBy = DPR();
        // 創(chuàng)建自定義 canvas 元素
        var canvas = document.createElement("canvas");
        // 設(shè)定 canvas 元素屬性寬高為 DOM 節(jié)點(diǎn)寬高 * 像素比
        canvas.width = width * scaleBy;
        canvas.height = height * scaleBy;
        // 設(shè)定 canvas css寬高為 DOM 節(jié)點(diǎn)寬高
        canvas.style.width = `${width}px`;
        canvas.style.height = `${height}px`;

        // 獲取畫筆
        const context = canvas.getContext("2d");

        // 將所有繪制內(nèi)容放大像素比倍
        context.scale(scaleBy, scaleBy);

        let x = width;
        let y = height;
        return await html2canvas(dom, {canvas}).then(function () {
            convertCanvasToImage(canvas, x ,y)
        })
    }

    /**
     * 圖片轉(zhuǎn)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.

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

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

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

var canvas = document.createElement("canvas");
        // 設(shè)定 canvas 元素屬性寬高為 DOM 節(jié)點(diǎn)寬高 * 像素比
        canvas.width = width * scaleBy;
        canvas.height = height * scaleBy;
        // 設(shè)定 canvas css寬高為 DOM 節(jié)點(diǎn)寬高
        canvas.style.width = `${width}px`;
        canvas.style.height = `${height}px`;

        // 獲取畫筆
        const context = canvas.getContext("2d");

        // 將所有繪制內(nèi)容放大像素比倍
        context.scale(scaleBy, scaleBy);
3.

獲取設(shè)備像素比之后將canavs.width 和 canvas.height 去乘以設(shè)備像素比 也就是 scaleBy; 這個(gè)時(shí)候在去設(shè)置canvas.style.width 和 canvas.style.height 為dom的寬和高。想想為什么要這么寫?最后在繪制的餓時(shí)候?qū)⑺L制的內(nèi)容放大像素比倍

舉個(gè)例子iphone6S是設(shè)備寬高是375 X 667 ,6S的 window.devicePixelRatio = 物理像素 / dips(2=750/375)所以設(shè)計(jì)師一般給你的設(shè)計(jì)稿是不是都是750*1334的?

所以如果按照一比一去繪制在高清屏下就會(huì)模糊,看圖說(shuō)話6S DPR=2

6plus DPR=3

4.

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

5.

參考文章

一次 H5 「保存頁(yè)面為圖片」 的踩坑之旅

設(shè)備像素比devicePixelRatio簡(jiǎn)單介紹

html5 canvas在高倍屏下變模糊的處理辦法

基于html2canvas實(shí)現(xiàn)網(wǎng)頁(yè)保存為圖片及圖片清晰度優(yōu)化

Window.devicePixelRatio

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://www.ezyhdfw.cn/yun/96685.html

相關(guān)文章

  • 移動(dòng)H5頁(yè)面注意事項(xiàng)

    摘要:移動(dòng)端活動(dòng)頁(yè)面常常需要能夠分享到各種社交中,常用的有微信等。微信二維碼問(wèn)題同一個(gè)頁(yè)面里要是有兩個(gè)二維碼,長(zhǎng)按掃描總是只能掃出左側(cè)第一個(gè)二維碼。 首發(fā)于簡(jiǎn)書博客:http://www.jianshu.com/p/e958... 2017-11-25 更新:5. 使用 Gulp 拼合圖片 1. 單個(gè)頁(yè)面內(nèi)容不能過(guò)多 設(shè)計(jì)常用尺寸:750 x 1334 / 640 x 1134,包含了手機(jī)頂...

    weknow619 評(píng)論0 收藏0
  • 移動(dòng)H5頁(yè)面注意事項(xiàng)

    摘要:移動(dòng)端活動(dòng)頁(yè)面常常需要能夠分享到各種社交中,常用的有微信等。微信二維碼問(wèn)題同一個(gè)頁(yè)面里要是有兩個(gè)二維碼,長(zhǎng)按掃描總是只能掃出左側(cè)第一個(gè)二維碼。 首發(fā)于簡(jiǎn)書博客:http://www.jianshu.com/p/e958... 2017-11-25 更新:5. 使用 Gulp 拼合圖片 1. 單個(gè)頁(yè)面內(nèi)容不能過(guò)多 設(shè)計(jì)常用尺寸:750 x 1334 / 640 x 1134,包含了手機(jī)頂...

    madthumb 評(píng)論0 收藏0
  • 移動(dòng)H5頁(yè)面生成圖片解決方案

    摘要:現(xiàn)在有很多微信公眾號(hào)運(yùn)營(yíng)活動(dòng),都有生成圖片的需求,生成圖片后可以發(fā)送給好友和發(fā)到朋友圈擴(kuò)散,利于產(chǎn)品的宣傳生成圖片可以用但是由于已經(jīng)有了這個(gè)開源庫(kù),所以為了節(jié)省時(shí)間就沒有自己寫了地址少啰嗦,先看東西根據(jù)獲取像素比將傳入值轉(zhuǎn)為整數(shù)繪制獲取想要 現(xiàn)在有很多微信公眾號(hào)運(yùn)營(yíng)活動(dòng),都有生成圖片的需求,生成圖片后可以發(fā)送給好友和發(fā)到朋友圈擴(kuò)散,利于產(chǎn)品的宣傳! 1. 生成圖片可以用canvas,但...

    sewerganger 評(píng)論0 收藏0
  • 移動(dòng) - 收藏集 - 掘金

    摘要:使用移動(dòng)設(shè)備查看頁(yè)面時(shí)會(huì)發(fā)現(xiàn),在微信瀏覽器中有頂部導(dǎo)航欄有效解決圖片使用單位邊角缺失的問(wèn)題前端掘金起因在移動(dòng)端使用布局時(shí)圖片也需要用單位。移動(dòng)端實(shí)踐前端掘金說(shuō)起,相信大家并不陌生。 Sticky Footer,完美的絕對(duì)底部 - 前端 - 掘金寫在前面 做過(guò)網(wǎng)頁(yè)開發(fā)的同學(xué)想必都遇到過(guò)這樣尷尬的排版問(wèn)題:在主體內(nèi)容不足夠多或者未完全加載出來(lái)之前,就會(huì)導(dǎo)致出現(xiàn)(圖一)的這種情況,原因是因?yàn)?..

    Jochen 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<