- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
背景
我在 Docker 镜像中运行的快速应用程序中使用 Puppeteer。我们有必要在 Docker 中运行,因为 Debian 需要我们无法安装的依赖项。使用 Docker 可以让我们安装我们需要的东西。
我们已经看到很多人在让他们的字体在 PDF 中正确呈现时遇到问题,在我见过的每种情况下,以接近于此的方式安装字体始终是答案,
apt-get install -yq --allow-unauthenticated ttf-mscorefonts-installer
在那种情况下,他们正在安装恰好有一个 apt-get
的特定字体。我看到其他人也使用 RUN apt-get install -yyq fonts-liberation
安装默认的 Puppeteer 字体。
代码示例
const browser = await puppeteer.launch({
args: ['--no-sandbox', '--disable-setuid-sandbox'],
ignoreHTTPSErrors: true,
dumpio: false,
});
const page = await browser.newPage();
await page.goto(
`http://localhost:3000/${template}?data=${JSON.stringify(req.body)}`,
);
const pdfBuffer = await page.pdf({
format: 'A4',
margin: {
top: '20px',
left: '20px',
right: '20px',
bottom: '20px',
},
});
await browser.close();
问题
我们需要安装大约 10 种字体,应用程序的不同部分将在不同场合使用。为此,我们有 ttf
和 woff
文件。我们决定将它们添加到系统中,就像 apt-get
对我们看到人们安装的其他字体所做的那样。我们通过将我们的字体添加到 Debian 目录来做到这一点,
/usr/local/share/fonts
我们可以通过运行看到系统中的字体设置正确,
fc-list
当我们像这样添加字体时,它们不会呈现。相反,我们在这些字体应该出现的地方得到了奇怪的符号。
示例
我们正在使用 Dockerfile 添加我们的字体,
RUN apt-get install -yyq fonts-liberation
COPY /fonts/*.ttf /usr/local/share/fonts/
COPY /fonts/*.woff /usr/local/share/fonts/
问题
由于我们有一堆 ttf
和 woff
字体文件需要使用 Puppeteer 在 PDF 中呈现,将它们添加到我们的 Debian 镜像的正确方法是什么在 Docker 中运行以便 Puppeteer 将按预期使用它们?
最佳答案
这是一个示例脚本,用于捕获网站上的屏幕截图和 pdf。两者在这个问题上的目的相同,以显示字体有效。
(async()=>{
const puppeteer = require('puppeteer')
const browser = await puppeteer.launch({
headless: true,
args: ["--no-sandbox", "--disable-setuid-sandbox"]
});
const page = await browser.newPage()
await page.goto('https://jp.quora.com/')
await page.screenshot({path: `/shared/_${Date.now()}.png`})
const pdfBuffer = await page.pdf({path: `/shared/_${Date.now()}.pdf`});
await browser.close()
})()
这是最小的 dockerfile,这是非常小的,它不包含任何额外的东西,比如 dumb-init 和各种清理黑客,因为这里不需要。
FROM node:8
# Install dependencies
RUN apt-get update && \
apt-get -yq install libatk1.0-0 libgtk2.0-0 libnotify-dev libgconf-2-4 libnss3 libxss1 libasound2 libxtst6 libasound2 xauth xvfb
# Cd into /app
WORKDIR /app
# Copy package.json into app folder
COPY package.json /app
# Install dependencies
RUN npm install
COPY . /app
# Start script on Xvfb
CMD ["xvfb-run","npm","start"]
运行时,这是日语 Quora 在 puppeteer 上的显示方式,它是这样显示的,因为缺少字体。
因为它是基于 jessie 的,我们可以使用几个不同的命令来安装字体。
下面会安装一些日文字体。
RUN apt-get -yq install xfonts-utils fonts-droid xfonts-intl-asian
如果我在 fonts 目录中有字体,那么命令是,
COPY fonts/*.* /usr/share/fonts/truetype/
这真的很简单。但是字体仍然无法工作,因为字体缓存的更新速度不够快。添加以下内容将确保它已更新。
RUN mkfontscale && mkfontdir && fc-cache
就是这样!让我们再次运行脚本。
关于node.js - 将字体添加到 Puppeteer PDF 渲染器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51033223/
你知道更好的写法吗 font = font ? font : defaultFont; 我所知道的是: if(!font) { font = defaultFont } 我知道这是一个小工具问
我正在编写代码,但无法编译,即使类(字体)已通过 import javafx.scene.text.*; 导入我知道这个方法font包含在字体中。 这是我的代码: package helloworld
我已经构建了一个按钮,但在格式设置(即平方、内联文本等)方面遇到了问题 我目前的问题是:正文分为2部分- 上线正常-下一行是较大的字体大小 我的动画 react 正确,但文本应该在箭头的顶线和底线内。
好的,所以我想在网页上使用固定系统作为字体。我可以使用 Cufon,但我希望人们能够在鼠标悬停时选择文本并复制它。 有人有什么吗? 最佳答案 我使用 fontsquirrel 的 @font-face
我找到了 iOS 4.2 可用字体列表(链接 here ),但该列表与早期版本的 SDK 略有不同(链接 here )。 我可以很好地更改代码中的字体,但如果我使用 iOS 4.2 列表中可用的字体,
我正在尝试更改 TableView 标题上的字体颜色,其中显示“加利福尼亚/纽约”。我该怎么做? 在黑色背景上,文本需要是白色的,但无法弄清楚这一点。 谢谢 最佳答案 如果您尝试更改标题颜色,可以使用
假设我想使用 java.awt.Graphics.drawString(String str, int x, int y)在某些特定坐标处绘制字符串的方法,例如 (300, 300)。然而drawSt
我想使用Puppeteer从HTML字符串生成图像。现在我有这样的事情: const html = _.template(` Hello {{ test }}!
我正在创建一个游戏。我有一些带有文本的用户界面。最近我们想添加日语版本,但我遇到字体问题。我使用 stb_freetype 来光栅化字体,并且我支持 Unicode,所以这应该不是问题。但大多数字体似
我可以在一个文本区域中使用不同的前景色吗?不同的字体? 我想添加类似“hh:mm:ss 昵称:消息”的内容,时间为灰色,名称 - 蓝色,消息 - 黑色。 最佳答案 我在评论中犯了一个错误:你想要的是
每次我更改字体时,它都会返回到默认大小,即 12,即使我之前使用“ Jade 野”菜单更改它,它每次也只会返回到 12,我的猜测是这样我使用deriveFont()更改大小,但现在没有其他方法可以更改
我的电脑上安装了一种名为“BMW1”的自定义字体。我试图循环遍历此字体中的所有条目并将它们显示在 JTextArea 中。 我有以下代码: JTextArea displayArea = new JT
我尝试通过 Squirrel 理解生成的代码,这里是输出: @font-face { font-family: 'someFont'; src: url('someFont.eot')
我知道有多种方法可以通过 JS/DHTML 动态更改网页的字体属性,或者用 Flash 呈现的字体(使用 sIFR 或 Cufon)替换文本。但是,我找不到任何根据用户选择动态更改网页上使用的字体的好
使用具有非标准样式名称(例如“Inline”或“Outline”)而不是标准样式(例如“Bold”和“Italic”)的字体系列,如何使用 css 选择字体的不同样式? 设置 font-family
我对 html/css 有点陌生,我正在制作我的第一个网站,但我只是想不通一些东西。 首先,我在 dreaweaver 中工作...在 dreaweaver 中,一切看起来都不错,但是当我预览时,我缺
有没有办法在 Allegro5 中只绘制(或显示)图像/字体的一部分? 例如,如果我有一个正方形 A 和一个图像 B,我只想绘制/显示 B 中与 A(在本例中为 C)重叠的部分,我该怎么做? 插图:
所以,我有一个正在生成的报告 html 文件,其中有需要白色文本/字体的黑框。在通用 html 显示中一切都很好,但是当我尝试打印页面时,ctrl + p 或自定义打印功能,文本/字体保持为标准颜色,
我正在尝试制作一个非常适合 LaTeX 文档的 matlab 图形。一个已知的问题是 XTickLabel 和 YTickLabels 不使用 LaTeX 解释器渲染,导致图形不好看。 (注意:我意识
我需要在一个公共(public)位置使用默认颜色和字体,以便在桌面应用程序的多个窗口窗体中使用它。 这方面的最佳做法是什么? 我正在考虑使用应用程序设置在那里定义它们,但我想确保这是推荐的方法或者是否
我是一名优秀的程序员,十分优秀!