- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个项目要求我在一段文本中的一些带下划线的文本下放置一个 ID 字符串。
这是一个使用带有灰色边框的内联 SVG 对象来显示布局的示例:
我可以使用带有基线偏移的内联元素来接近,然后使用 SVG 来呈现文本。然而,这有一个缺点(我认为),我必须手动输入 SVG 的像素宽度,这对于这样一个简单的布局来说似乎非常复杂。
这是 XSL-FO 标记:
<fo:block>
Normal text
<fo:inline baseline-shift="-100%">
<fo:instream-foreign-object text-align="center" display-align="center" border="solid silver 1px">
<svg xmlns="http://www.w3.org/2000/svg" height="25" width="120" viewport="0 0 120 25">
<text x="60" y="10" fill="black" text-anchor="middle" text-decoration="underline" font-size="12pt">underlined text with id</text>
<text x="60" y="25" fill="black" text-anchor="middle" font-size="12pt">123</text>
</svg>
</fo:instream-foreign-object>
</fo:inline>
normal text.
</fo:block>
所以我的问题是:我可以在不使用 instream-foreign-object 和 SVG 的情况下在 Apache FOP XSL-FO 中执行此布局吗?如果我做不到,有没有什么办法可以不必将 SVG 中的宽度以像素为单位?或者有什么方法可以计算 SVG 渲染需要多少像素?
我还应该注意到 Apache FOP 不支持内联容器。
https://xmlgraphics.apache.org/fop/compliance.html
提前致谢! - 丹
最佳答案
这是一个示例,按照我建议的 RenderX 使用格式化树完成。
将所需的片段格式化为中间格式......对于单个片段来说是这样的:
<fo:root xmlns:fo="http://www.w3.org/1999/XSL/Format">
<fo:layout-master-set>
<fo:simple-page-master margin="0mm" master-name="MASTERsite1" page-width="214mm" page-height="29pt">
<fo:region-body margin="0mm"/>
</fo:simple-page-master>
</fo:layout-master-set>
<fo:page-sequence master-reference="MASTERsite1">
<fo:flow flow-name="xsl-region-body">
<fo:table>
<fo:table-body>
<fo:table-row>
<fo:table-cell><fo:block text-decoration="underline" text-align="center">This is Underlined Text with ID</fo:block></fo:table-cell>
</fo:table-row>
<fo:table-row>
<fo:table-cell><fo:block text-align="center">1234567</fo:block></fo:table-cell>
</fo:table-row>
</fo:table-body>
</fo:table>
</fo:flow>
</fo:page-sequence>
</fo:root>
输出结果是这样的:
<xep:document xmlns:xep="http://www.renderx.com/XEP/xep" producer="XEP 4.19 build 20110414" creator="Unknown" author="Unknown" title="Untitled">
<xep:page width="162708" height="29000" page-number="1" page-id="1">
<xep:word-spacing value="0"/>
<xep:letter-spacing value="0"/>
<xep:font-stretch value="1.0"/>
<xep:font family="Helvetica" weight="400" style="normal" variant="normal" size="12000"/>
<xep:gray-color gray="0.0"/>
<xep:text value="This is Underlined Text with ID" x="0" y="18734" width="162708"/>
<xep:line x-from="0" x-till="162708" y-from="17534" y-till="17534" thickness="600" style="solid"/>
<xep:text value="1234567" x="58002" y="4334" width="46704"/>
</xep:page>
</xep:document>
你会修改结果来改变页面宽度的地方,但是它恰好在文本中作为关注的文本元素的宽度,也就是改变:
<xep:page width="606614" height="29000" page-number="1" page-id="1">
因此宽度来自所关注的文本行,以编程方式从 xep:line 或 xep:text 行中获取 x-till(如上更改)。请注意,这与您的 SVG 示例完全相同,只是您可以通过编程方式访问此文件中的数字。
最后,使用这个"file"作为图像,然后可以使用:
<fo:external-graphic src="test19.xep" content-type="application/xepout" alignment-baseline="central"/>
现在,虽然您说要查看所有这些步骤,但这是一个解决方案,而且上述所有步骤都可以自动化到一个流程链中。首先循环并格式化所有关注的对象并从中生成小文件,然后第二遍将不格式化这些片段,而是将它们用作图像。
注意:结果的附图中显示的行间距不能用 FOP 完成(我相信),我认为这是 FOP 的限制。
注意#2:我不是 FOP 专家,我对它的实现一无所知,特别是在文档中使用区域树作为图像。如果 FOP 是必须的,我建议调查一下。您可以像使用它们的所有维度一样轻松地将区域树转换为 SVG 并使用它们,或者更好地将区域树读入第二个转换并从中直接内联生成流内异物 SVG。
关于xsl-fo - 使用 Apache FOP 在 XSL-FO 中的下划线文本下放置字母,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22253279/
执行此查询 INSERT INTO classes( '_fkUserID', 'date', 'time' ) VALUES ( '1', '2017-07-04', '8:15' ) 给
不知道它是否重复(无法找到要搜索的词,例如 “允许使用 java 字符”)。我在测试面试中遇到了这个问题: 考虑以下类: class _ {_ f; _(){}_(_ f){_ t = f; f =
我需要验证用户的屏幕名称以确保它不能有 多个连字符或下划线 我不希望人们的网名全是标点符号。 这是我到目前为止的验证: public boolean validateScreenName(String
我正在尝试检查我收到的新数据是否针对我持有的对象,我想知道的是,我正在发送的对象的键是否与我当前拥有的对象中的任何键匹配。 所以我捕获了一个像 myObj = [{"one": 1}, {"two":
这是我第一次使用下划线...我有这个简单的 json... "categories" : [ { "tag" : "cat1", "active" : true
一个很简单的问题: 为什么在WPF内容中看不到_(下划线)? 例如内容 显示为"testt"(未显示下划线)。 最佳答案 标签支持助记符(即您可以使用ctrl +(key)赋予它们焦点)。您可以使用
下面是我正在处理的简化逻辑,我想在数组中查找具有匹配位置(文件夹)的文件。 我能够使用普通的 JS 循环来实现此功能,您能建议更好/更简单/类似下划线的方法来实现此类功能吗? // source va
我正在尝试在对象的函数中查找和替换值 我的对象看起来像这样: var testStates = [{ "module": "module1", "customUrl": [
尝试让 _.uniq() 在以下结构上工作: [ {'x' : 1, 'y': 2}, {'x' : 1, 'y': 2}, {'x' : 2, 'y': 3}, {'
明白了: [{ "title": "qq", "dateValuePair": { "date": "2016-04-29T22:00:00.000Z", "va
我不知道这是否可能,但我试图做的是“清理”一个对象。基本想法是我有一个对象的表格(以 Angular ),然后单击我想添加一个新行(控制对象中的一个新项目,但我希望它没有值。我有下划线尝试一下。一些考
所以我有一大堆对象需要将其变成一个小对象。 它有 50-60 个对象,我需要过滤到一个新的对象数组中,其中只有 3 个。 所以看起来像 myOb = {{"ob1": 1},{"ob2": 1},{"
我有一个像这样的对象 - {"house" : red, "car" : green, "apple" : blue}; 并且正在发送另一个带有单个键/值的对象,如下所示 {"apple" : gre
我有一个包含多个对象的数组,例如 var val = [ _id: ["5412fc1bd123cf7016674a92", "5412cf270e9ca9b517b43ca3"],
所以我有一个对象列表,例如 var options = [{"car" : "red"},{"house": "green"},{"dog":"bark"}] 我正在尝试将其转换为一个值数组,
我正在尝试将此数组转换为对象。使用下划线,我想转换这个数组: [ { "id": "parentA", "children": [ { "nam
我正在尝试使用这样的链检索嵌套项目值。我正在遍历的对象如下所示: var testStates = [{ "module": "module1", "customUrl
我有一些内容可编辑的段落,我希望能够在双击时使某些单词加粗下划线。当我双击一个单词时,它会被选中,并显示一个包含 3 个选项的工具提示。但是,单击工具提示选项后,选择就会消失,并且文本不会发生任何更改
要在 CSS 中给文本加下划线,我们可以这样做: h3 {text-decoration:underline;} 然而,这只会强调包含在 h3 标签中的文本。如果想让下划线穿过页面怎么办? 谢谢 最佳
我正在尝试解决我的最后一个问题,但我仍然不知道如何解决它。我的任务是编写一个对数字进行排序的程序,但是:我们的导师给了我们一些处理数字的程序的额外要点,例如:000054667(实际上是 54667)
我是一名优秀的程序员,十分优秀!