- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试通过 PhantomJS 将 html 文件转换为 PDF,但不知道如何避免 dpi 缩放问题。只需有一个像 <div style=" display:block; background-color:red; width:96px; "> text </div>
这样简单的元素它的宽度减少到 77px。我的值(value)观viewPort
或paperSize
似乎没有改变这一点。我可以调整zoomFactor
到其他地方建议的1.25,这会缩放到大致预期的宽度,但会弄乱页面中的某些元素。
我有一个由 HighCharts 生成的 svg 图表,它设置为填充 100% 宽度,我也尝试过 width: 210mm
但这将按比例缩小,而不是匹配 210mm 的 paperSize 宽度。我知道 96dpi 的 A4 尺寸应为 794px x 1120px,通过 PDF 查看器在 100% 缩放时,这就是 px 测量值(根据我的理解,Windows 上的 PDF 以 96dpi 显示)。我能够通过 width:100%
获得我的 HighCharts div通过获取这些 px 尺寸并乘以 1.25,即 viewPort
的 992 x 1400 值,按预期渲染匹配 PDF 宽度。与 paperSize
设置为 A4 纵向且无边距。不幸的是,这并没有调整正在缩小的其余内容。
另一个选择是避免 A4 纸张大小并提供与 viewPort 相同的 px 值,这些值也会缩小以匹配文档,尽管这是针对需要 A4 PDF 的报告服务...内容是基于光栅的,有没有办法可以将其放大以填充/适合 A4 PDF 尺寸?理想情况下,浏览器和 pdf 版本在同一台机器上视觉上看起来大小相似(PhantomJS 通过 Atom-Shell 应用程序使用),也许这不能为用户提供一致的体验?
最佳答案
有一个 Fork 可以解决这个问题。您现在可以使用此分支设置 dpi:https://github.com/martonw/phantomjs/tree/issue-%2313553
您需要为您的操作系统编译它,然后您可以使用 page.dpi
设置 dpi
console.log('Loading a web page');
var page = require('webpage').create();
var url = 'http://phantomjs.org/';
page.open(url, function (status) {
//Page is loaded!
page.dpi=300; // this is where you actually set the DPI
page.render("test.pdf");
phantom.exit();
}
请确保在编译 phatomjs 时使用相同的操作系统,因为编译过程会从系统读取 dpi 并将其用于 phantomjs。这意味着:如果您在 Windows 上使用标准 dpi 96 编译它并在 centos 上使用它,您将得到 96/72 的比例,因为 centos 使用 72 dpi
关于pdf - PhantomJS PDF DPI 缩放问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28303995/
我 Handlebars 机图片尺寸调整为731*974,但还是有920KB。所以我想将图像分辨率从96dpi更改为72dpi(因为我发现iPhone中的图片是72dpi,看起来不错)。任何人都可以提
我制作了这个非常简单的计算器布局。但是我手机上的 480 DPI 和 420 DPI 是不同的。 420DPI 屏幕右侧有空闲空间,按钮比 480DPI 更细。我使用 dp 作为按钮的测量单位,sp
使用 phantomjs ,有没有办法控制使用 page.render(filename) 光栅化 Web 内容的图像时使用的 DPI 设置?方法? 我找不到任何可以通过 the interface
众所周知,Windows 7 可用的 DPI 缩放比例为 100%、125%、150% 和 200%。这四个DPI百分比的实际DPI值是 Percentage - DPI Values 100%
我试图找到 WinMerge 的替代方案来解决 150% DPI 下的文本模糊问题。虽然我的问题被关闭了(我认为这种心态没有帮助),但我找到了答案所以我分享它。 最佳答案 您可以继续使用 WinMer
我有一些我想打印出来的图像。这些图像可以采用不同的格式,从不同的 DPI 到不同的格式(JPEG、PNG 等) 现在我所做的是将图像加载到我的应用程序中并尝试 将 dpi 转换为 96。但是在这个过程
DPI 和 PPI 有什么区别吗?是这样吗:点 = 像素?最后,C#.net 中的 DpiX 和 DpiY 是什么?我们如何改变它们? 最佳答案 新闻部 代表每英寸点数,在打印时使用。它也被严重滥用于
我有一个可视化代码,例如: for cluster in ready_couples_2.cluster.unique(): sns.set(rc={'figure.figsize':(11.
我正在努力优化我的网络应用程序中的滚动性能,并在最新的 Chrome (v31) 上遇到了有趣的行为,该行为也在 Chrome Canary (v34) 上重现。 在这个简化的示例中,我有一个简单的可
我正在构建一个具有 hdpi 分辨率图形 Assets 的游戏(因此我将文件放在 drawable-hdpi 目录中)。我不希望图像具有相应的 mdpi 分辨率,我将在基于 240-dpi 的像素坐标
我必须重新布局一个非常复杂的 UI,因为我们发现它在高 dpi 系统上基本上不可用。这是因为为了在 Qt Creator 中获得我们想要的布局设计,我们对几乎所有内容都使用了固定大小。 我的问题是,如
我的系统上安装了 Win 8.1 系统。我曾经根据我的 WPF 应用程序 (Win 7) 中的以下内容计算 DPI: Matrix m = PresentationSource.FromVisual(
我有一个使用 Substance LookAndFeel 的 Java 应用程序,Windows 作为目标平台,我想增加我的应用程序的 DPI 设置, 不更改系统设置。 我想这样做是因为我不想强制用户
我有一个非常奇怪的问题......在我的 iPhone 应用程序中,用户可以打开相机胶卷中的图像,在我的示例中 1920 x 1080 像素 (72 dpi) 的壁纸。 现在,想要将图像的宽度调整为例
我遇到一个问题,应用程序(用 Delphi 编写)在所有系统上的默认 96 DPI 设置下表现正常,但在不同系统上的“150% 文本大小”(内部 144 dpi)设置下表现不一致。似乎在某些系统上,我
我看过官方Qt documentation以及 StackOverflow 上关于 Qt 中高 DPI 支持的许多文章和问题。他们都专注于移植旧的应用程序并让它们以尽可能少的更改工作。 但是,如果我要
在matplotlib中,我使用LineCollection绘制国家/地区的颜色,并指定了县/市的边界。当我将图形另存为pdf文件时: fig.savefig('filename.pdf',dpi=3
我想以编程方式确定用户显示器的 DPI,以便以精确的单位数(厘米/英寸)显示网页。我知道这是一个奇怪的要求:它是针对一个可视化研究项目的,它是一种控制。我们目前通过让用户将信用卡放在屏幕上并将可调整大
我使用 matplotlib 创建了一个图形,但我已经意识到绘图轴和绘制的线被缩小了。 阅读本文 earlier discussion thread ,它解释了如何设置图形大小。 fig, ax =
晚安,我正在与一些合作伙伴使用 javaFx 制作一个应用程序;我们的想法是它将在 Windows 和 Linux 中使用。我们进行了一些测试,发现应用程序在两种操作系统中的显示有所不同。 我们正在使
我是一名优秀的程序员,十分优秀!