溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

小程序java后端生成海報(bào)的方法

發(fā)布時(shí)間:2020-12-11 14:04:50 來源:億速云 閱讀:444 作者:小新 欄目:移動(dòng)開發(fā)

這篇文章將為大家詳細(xì)講解有關(guān)小程序java后端生成海報(bào)的方法,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

實(shí)現(xiàn)方案

前端人員,提供相關(guān)的html頁(yè)面, 后端人員提供接口,前端人員通過參數(shù)設(shè)置html頁(yè)面需要渲染的內(nèi)容, 最后使用wkhtmltoimage或者phantomjs 對(duì)html 進(jìn)行截圖生成海報(bào), 個(gè)人感覺wkhtmltoiamge 比phantomjs 要快一點(diǎn),穩(wěn)定一點(diǎn)我主要說下wkhtmltoimage的實(shí)現(xiàn)方案

實(shí)現(xiàn)步驟

安裝環(huán)境

官網(wǎng)地址:https://wkhtmltopdf.org/

windows: 下載安裝包安裝即可

linux:  下載對(duì)應(yīng)的安裝包 ,還需安裝對(duì)應(yīng)中文字體(phantomjs 也需要安裝字體),html中需要聲明引用

yum install libjpeg libXrender libXext xorg-x11-fonts-75dpi.noarch xorg-x11-fonts-Type1 bitmap-fonts-cjk

rpm -ivh wkhtmltox-0.12.6-1.centos7.x86_64.rpm

安裝字體

yum install bitmap-fonts-cjk

mkdir /usr/share/fonts/win

拷貝字體到 /usr/share/fonts/win下

cd /usr/share/fonts/win
mkfontscale
mkfontdir
fc-cache

相關(guān)代碼

利用java 執(zhí)行命令 調(diào)用wkhtmltoImage 設(shè)置相關(guān)參數(shù),具體參數(shù)查看wkhtmltoImage 命令提示

package com.yumingzhu.wxweb.util;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

/**
 * @Description 
 * @Author yumigzhu
 * @Date 2020/7/22 20:12
 */

public class CustomWKHtmlToPdfUtil {
	private static String tempPath = "C:/apps/tmpFile";// 圖片保存目錄

	public static String getCommand(String htmlToImage, String sourceFilePath, String targetFilePath) {
		//--quality 設(shè)置為50 是比較合適的, 默認(rèn)的94 可能會(huì)導(dǎo)致圖片文件過大
		ProcessBuilder pb = new ProcessBuilder(htmlToImage, "--crop-w", "800", "--width", "800","--quality", "50",
				sourceFilePath, targetFilePath);
		Process process;
		try {
			process = pb.start();
			//注意,調(diào)用process.getErrorStream()而不是process.getInputStream()
			BufferedReader errStreamReader = new BufferedReader(new InputStreamReader(process.getErrorStream()));
			System.out.println("read errstreamreader");
			String line = null;
			line = errStreamReader.readLine();
			while (line != null) {
				System.out.println(line);
				line = errStreamReader.readLine();
			}
			process.destroy();
			System.out.println("destroyed process");
		} catch (IOException e) {
			e.printStackTrace();
		}
		return targetFilePath;
	}

	public static void main(String[] args) throws Exception {
		String imagePath = tempPath + "/" + System.currentTimeMillis() + ".png";//圖片路徑
		System.out.println(imagePath);
		String htmlToImage = "E:\\softwareAPP\\wkhtmltopdf\\bin\\wkhtmltoimage.exe";

		CustomWKHtmlToPdfUtil.getCommand(htmlToImage,
				"file:///G:/share/text_none_title_share/index.html",
				imagePath);

		System.out.println("執(zhí)行完成");
	}
}

踩坑記錄

  • 如果html頁(yè)面設(shè)置的寬高比較小, 這樣截出來的圖片也會(huì)比較小,比較模糊,,  增大html 的寬高,可以使圖片更清晰,這樣會(huì)導(dǎo)致截出來的圖片文件更大,這樣用戶在小程序下載過程會(huì)更慢,這里需要自己權(quán)衡

  • wkhtmlImage 對(duì) css3  linear-gradient  不支持,不能使用樣式下劃線,可以考慮使用圖片代替

  • 中文字體需要聲明引用,才能生效

關(guān)于小程序java后端生成海報(bào)的方法就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI