- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我使用此代码来下载带有 css 文件中的图像的网页,但它在 pdf 文件中缩放得太大。图片宽度为 120 像素,显示宽度为 185 像素。对于比较,我构建了一条 10 像素线,以 12 像素显示。
但是为什么呢?我该如何解决这个问题?
如果没有更多详细信息,我无法发布问题,但我什么都不知道,这对您有用,但也许有帮助:
我在文件部门工作,负责归档可在其网页中访问的信息,但最终,外观并不是创建者想要的样子。我尝试使用本地 CSS 文件,但意识到这不是我想要的。我必须更频繁地使用我的工作流程,并且必须采用他们提供的 css 文件,然后将 html 页面正确转换为 PDF。
预先感谢您的阅读,我试图让代码包含所有需要了解的重要内容,但仅此而已。
该项目的依赖项是:
package ueberordnungen;
import java.io.IOException;
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
import org.jsoup.nodes.Element;
import com.itextpdf.html2pdf.ConverterProperties;
import com.itextpdf.html2pdf.HtmlConverter;
import com.itextpdf.kernel.pdf.PdfDocument;
import com.itextpdf.kernel.pdf.PdfWriter;
public class Worker3 {
public static void main(String[] args) throws IOException {
//eine spezielle URL heraus picken
String kongressURL = "https://www.egms.de/dynamic/de/meetings/vnda2019/index.htm";
Document doc = Jsoup.connect(kongressURL).get();
System.out.println("-----Titel: "+ doc.title());
Element content = doc.child(0);
content.getElementById("navigation_language").remove();
content.getElementById("navigation").remove();
content.getElementsByAttributeValue("href", "/static/css/gms-framework.css").first().remove();
content.getElementsByClass("hidden_navigation").first().remove();
content.getElementById("page").before(content.getElementById("header"));
content.getElementsByTag("script").remove();
content.getElementById("owner_links_container").attr("style", "border-top:10px solid #060");
ConverterProperties properties = new ConverterProperties();
properties.setBaseUri(kongressURL);
PdfWriter writer = new PdfWriter("content.pdf");
HtmlConverter.convertToPdf(content.html(), new PdfDocument(writer), properties);
}
}
最佳答案
iText 7 以每 pt 一个图像像素的比例添加背景图像,请参阅 AbstractRenderer.drawBackground
:
PdfXObject backgroundXObject = backgroundImage.getImage();
...
Rectangle imageRectangle = new Rectangle(backgroundArea.getX(), backgroundArea.getTop() - backgroundXObject.getHeight(),
backgroundXObject.getWidth(), backgroundXObject.getHeight());
...
drawContext.getCanvas().addXObject(backgroundXObject, imageRectangle);
正如您在代码中看到的,图像的宽度和高度值(包含位图图像的水平和垂直像素数)按原样用作矩形的宽度和高度,图像最终被缩放。由于 Canvas 绘制操作中使用的单位是用户空间单位,默认为 1/72in,因此图像以每英寸 72 个图像像素或每 pt 1 个图像像素显示.
网络浏览器通常默认以每像素 1 个图像像素或每英寸 96 个图像像素显示图像。
您的示例网页主要是使用 px = 1/96in 给出的绝对位置进行布局的。因此,网络浏览器或 iText 绘制图像的不同比例会导致不同的外观,特别是在当前情况下,iText 中的外观并不令人满意:
您可以通过将上面计算 imageRectangle
的中心代码行替换为
Rectangle imageRectangle = new Rectangle(backgroundArea.getX(), backgroundArea.getTop() - backgroundXObject.getHeight(),
backgroundXObject.getWidth() * .75f, backgroundXObject.getHeight() * .75f);
实际上,此代码位置似乎是开始添加对 background-size
的支持的适当位置,目前此处不支持该支持。
注意:我并没有真正深入了解 iText 7 HTML 到 PDF 转换代码,因此我无法真正判断此补丁是否具有不良副作用。
严格来说,事实并非如此,至少就我浏览 CSS 规范而言是这样:
HTML 页面未在此处设置background-size
。因此,应使用背景图像的固有尺寸。但不幸的是,CSS 并没有定义一般情况下如何找到内在尺寸。因此,网页基本上将背景图像的比例留给了 HTML 客户端的突发奇想......
如果 iText 7 HTML to PDF 的目标是生成与浏览器输出一致的结果,那么最好在此处更改其默认比例以匹配这些浏览器的比例。
<小时/>我刚刚意识到我修补的 AbstractRenderer
不在 html2pdf 项目中,而是在核心 iText 7 布局项目中。
因此,在此处更改大小可能是一个坏主意,至少如果您不仅将 iText 7 用于 html2pdf,而且还直接使用它。
尽管如此,该代码位置适合引入对某些背景大小属性的支持。然后,html2pdf 可以扩展 BackgroundApplierUtil
,以便它始终将新的核心属性设置为适合创建与浏览器显示内容一致的外观的值。
关于java - 为什么生成的 PDF 中使用的像素比源 html 中使用的像素更多?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57476868/
我正在开发一个带选项卡栏的 ios 应用程序。我的栏上有超过 5 个按钮,所以在 iphone 上我有更多的按钮。现在,假设我有这个按钮:Button1 Button2 Button3 Button4
我有一个带有 UITabBarController 的应用,其中有超过五个选项卡。 当我按更多选项卡时,我会转到moreNavigationController,它是一个UINavigationCon
我有一个导航 Controller 。 NAVC->MORE... 按钮,然后在“更多”下有一些额外的 VC。 如果我转到“更多...”下的 VC,然后转到不在“更多...”上的 VC,那么当我返回到
因此,我想出了这种方案,用于在多个线程同时具有读写访问权限的二叉树中旋转时锁定节点,这涉及每次旋转锁定四个节点,这似乎是一个很多吗?我想到了一种比我想出的方法更聪明的方法来减少所需的锁定,但谷歌并没有
所以我已经尝试了所有方法,但我似乎仍然无法将下拉内容与 dropbtn 对齐。我只希望内容始终位于更多菜单下方。 HTML: `
我正在尝试使用 expect 来自动接受在 --more-- 中提示的 EULA。 #!/usr/bin/expect spawn "./greenplum-perfmon-web-4.1.2.0-b
他们如何在下面提供的网站上制作“告诉我更多”效果。我读过 read more/less effect in jQuery,但我发现该站点的有趣之处在于,除非单击该按钮,否则无法滚动页面。 Effect
现在,Kim Stebel helped me understanding如何使用存在类型键入变量,我需要知道如何在继承中使用它们: 以下代码无法编译: class PagingListModel(s
在我的Cygwin中不可用。另一方面,提供了“ less”命令。也许Cygwin的制造商认为“更多”只是多余的。 我对此很好奇。 最佳答案 安装util-linux软件包,您将获得“更多”的信息 ht
基本上,我想知道是否有人有增加 DTU 与分片的经验。 DTU应该线性地提高性能。因此,如果您有 5 个 DTU,而您改为 10 个 DTU,那么(理论上)您应该获得大约两倍的性能。 因此,四个 SQ
我们使用 asp.net mvc、javascript 和 jQuery(托管在本地计算机上)创建了一个应用程序。基本设计是,当用户从一个页面导航到其他页面时,我们通过隐藏和显示 HTML 页面,将所
我想用 RMonad 做一些基本的事情。有没有办法使用“as monad”功能来 有一个身份 rmonad,可以应用 monad 转换器吗? 有诸如 StateT 变压器之类的常见东西吗? 向现有 m
我有一个 char*[] 数组。我需要能够为其分配字符串并再次删除它们,但我不知道: 如何检查一个元素中是否已经有一个字符串,这样我就不会覆盖它,如果它已经被占用,则继续处理下一个元素? 之后如何将其
基本上,我想知道是否有人有增加 DTU 与分片的经验。 DTU应该线性地提高性能。因此,如果您有 5 个 DTU,而您改为 10 个 DTU,那么(理论上)您应该获得大约两倍的性能。 因此,四个 SQ
我有一个程序可以同时吐出标准错误和标准输出,我想在标准错误上少运行寻呼机,但忽略标准输出。我该怎么做? 更新: 就是这样......我不想丢失标准输出......只是让它远离寻呼机 program 2
基本上,当单击具有类 "dropdown" 的链接时,我无法获取“更多...”链接来对下一个跨度的高度进行动画处理。它根本就没有动画。仅当更改为 Less... 链接并且单击 Less... 链接以折
我正在使用 ExtJS,并认为它是一个了不起的框架。但是,它们没有内置的状态图,这使得依赖于状态的应用程序开发非常痛苦。 我最近发现了这个: https://github.com/jakesgordo
我一直在研究数据结构和算法,遗憾的是在C中。我已经单独实现了一个双向链表,它保存整数并且工作正常,但是当节点(或pub)让它正常工作时我遇到了很多麻烦在本例中)保存多个不同类型的值。我可以创建一个列表
编辑拼写错误 你好, 这可能是一个愚蠢的问题,但如果它能帮助我遵循最佳实践,我不在乎:P 假设我想在 System.Data 命名空间...以及 System.Data.SqlClient 命名空间中
使用 bootstrap 3 CSS、font awesome CSS 和最新的 jQuery JS 文件。 我正在使用 javascript 在单击按钮时在另一个内容 div 之上隐藏/显示一个内容
我是一名优秀的程序员,十分优秀!